rspec 1.1.12 → 1.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (267) hide show
  1. data/.autotest +2 -1
  2. data/.document +7 -0
  3. data/History.txt +58 -0
  4. data/License.txt +1 -1
  5. data/Manifest.txt +45 -82
  6. data/README.txt +3 -6
  7. data/Rakefile +33 -13
  8. data/Ruby1.9.markdown +32 -0
  9. data/TODO.txt +10 -4
  10. data/Upgrade.markdown +63 -0
  11. data/bin/spec +1 -1
  12. data/cucumber.yml +3 -0
  13. data/examples/failing/{failing_autogenerated_docstrings_example.rb → failing_implicit_docstrings_example.rb} +0 -0
  14. data/examples/failing/pending_example.rb +9 -0
  15. data/examples/failing/spec_helper.rb +1 -1
  16. data/examples/passing/{custom_expectation_matchers.rb → custom_matchers.rb} +0 -0
  17. data/examples/passing/filtered_formatter.rb +18 -0
  18. data/examples/passing/filtered_formatter_example.rb +31 -0
  19. data/examples/passing/implicit_docstrings_example.rb +18 -0
  20. data/examples/passing/spec_helper.rb +1 -1
  21. data/examples/ruby1.9.compatibility/access_to_constants_spec.rb +17 -18
  22. data/features/before_and_after_blocks/before_and_after_blocks.feature +4 -4
  23. data/features/example_groups/example_group_with_should_methods.feature +1 -1
  24. data/features/example_groups/{autogenerated_docstrings.feature → implicit_docstrings.feature} +7 -9
  25. data/features/example_groups/nested_groups.feature +1 -1
  26. data/features/heckle/heckle.feature +56 -0
  27. data/features/interop/examples_and_tests_together.feature +1 -1
  28. data/features/interop/test_but_not_test_unit.feature +1 -1
  29. data/features/interop/test_case_with_should_methods.feature +1 -1
  30. data/features/matchers/create_matcher.feature +115 -0
  31. data/features/mock_framework_integration/use_flexmock.feature +22 -4
  32. data/features/mock_framework_integration/use_mocha.feature +27 -0
  33. data/features/mock_framework_integration/use_rr.feature +27 -0
  34. data/features/mocks/mix_stubs_and_mocks.feature +22 -0
  35. data/features/pending/pending_examples.feature +81 -0
  36. data/features/step_definitions/running_rspec.rb +5 -3
  37. data/features/support/env.rb +1 -1
  38. data/features/support/matchers/smart_match.rb +2 -2
  39. data/lib/autotest/rspec.rb +1 -1
  40. data/lib/spec.rb +1 -1
  41. data/lib/{adapters → spec/adapters}/mock_frameworks/flexmock.rb +0 -0
  42. data/lib/{adapters → spec/adapters}/mock_frameworks/mocha.rb +0 -0
  43. data/lib/{adapters → spec/adapters}/mock_frameworks/rr.rb +0 -0
  44. data/lib/{adapters → spec/adapters}/mock_frameworks/rspec.rb +0 -1
  45. data/lib/spec/autorun.rb +3 -0
  46. data/lib/spec/dsl.rb +3 -1
  47. data/lib/spec/dsl/matchers.rb +13 -0
  48. data/lib/spec/example.rb +4 -0
  49. data/lib/spec/example/before_and_after_hooks.rb +5 -20
  50. data/lib/spec/example/errors.rb +3 -3
  51. data/lib/spec/example/example_description.rb +15 -0
  52. data/lib/spec/example/example_group.rb +0 -15
  53. data/lib/spec/example/example_group_factory.rb +34 -46
  54. data/lib/spec/example/example_group_hierarchy.rb +53 -0
  55. data/lib/spec/example/example_group_methods.rb +101 -211
  56. data/lib/spec/example/example_methods.rb +61 -81
  57. data/lib/spec/example/module_reopening_fix.rb +23 -1
  58. data/lib/spec/example/pending.rb +3 -2
  59. data/lib/spec/example/predicate_matchers.rb +47 -0
  60. data/lib/spec/example/subject.rb +91 -0
  61. data/lib/spec/expectations.rb +1 -1
  62. data/lib/spec/expectations/differs/default.rb +0 -1
  63. data/lib/spec/expectations/extensions.rb +0 -1
  64. data/lib/spec/expectations/handler.rb +13 -6
  65. data/lib/spec/interop/test.rb +5 -0
  66. data/lib/spec/interop/test/unit/testcase.rb +5 -22
  67. data/lib/spec/matchers.rb +22 -8
  68. data/lib/spec/matchers/be.rb +4 -9
  69. data/lib/spec/matchers/be_close.rb +20 -5
  70. data/lib/spec/matchers/be_instance_of.rb +45 -0
  71. data/lib/spec/matchers/be_kind_of.rb +45 -0
  72. data/lib/spec/matchers/change.rb +8 -6
  73. data/lib/spec/matchers/compatibility.rb +14 -0
  74. data/lib/spec/matchers/eql.rb +24 -6
  75. data/lib/spec/matchers/equal.rb +24 -6
  76. data/lib/spec/matchers/exist.rb +21 -5
  77. data/lib/spec/matchers/extensions/instance_exec.rb +25 -0
  78. data/lib/spec/matchers/generated_descriptions.rb +2 -2
  79. data/lib/spec/matchers/has.rb +28 -11
  80. data/lib/spec/matchers/have.rb +2 -2
  81. data/lib/spec/matchers/include.rb +2 -2
  82. data/lib/spec/matchers/match.rb +25 -7
  83. data/lib/spec/matchers/match_array.rb +3 -3
  84. data/lib/spec/matchers/matcher.rb +51 -0
  85. data/lib/spec/matchers/method_missing.rb +2 -2
  86. data/lib/spec/matchers/operator_matcher.rb +12 -5
  87. data/lib/spec/matchers/raise_error.rb +3 -3
  88. data/lib/spec/matchers/respond_to.rb +3 -3
  89. data/lib/spec/matchers/satisfy.rb +7 -7
  90. data/lib/spec/matchers/throw_symbol.rb +3 -5
  91. data/lib/spec/mocks.rb +3 -3
  92. data/lib/spec/mocks/argument_expectation.rb +15 -15
  93. data/lib/spec/mocks/{argument_constraints.rb → argument_matchers.rb} +19 -23
  94. data/lib/spec/mocks/error_generator.rb +5 -8
  95. data/lib/spec/mocks/framework.rb +1 -1
  96. data/lib/spec/mocks/message_expectation.rb +5 -13
  97. data/lib/spec/mocks/mock.rb +4 -5
  98. data/lib/spec/mocks/proxy.rb +9 -5
  99. data/lib/spec/mocks/spec_methods.rb +10 -1
  100. data/lib/spec/rake/spectask.rb +0 -1
  101. data/lib/spec/runner.rb +6 -28
  102. data/lib/spec/runner/configuration.rb +3 -3
  103. data/lib/spec/runner/drb_command_line.rb +2 -1
  104. data/lib/spec/runner/example_group_runner.rb +3 -2
  105. data/lib/spec/runner/formatter/base_text_formatter.rb +34 -19
  106. data/lib/spec/runner/formatter/failing_example_groups_formatter.rb +3 -5
  107. data/lib/spec/runner/formatter/html_formatter.rb +2 -3
  108. data/lib/spec/runner/formatter/nested_text_formatter.rb +7 -25
  109. data/lib/spec/runner/formatter/progress_bar_formatter.rb +1 -1
  110. data/lib/spec/runner/formatter/snippet_extractor.rb +1 -1
  111. data/lib/spec/runner/formatter/specdoc_formatter.rb +1 -7
  112. data/lib/spec/runner/heckle_runner.rb +3 -6
  113. data/lib/spec/runner/heckle_runner_unsupported.rb +1 -1
  114. data/lib/spec/runner/option_parser.rb +19 -21
  115. data/lib/spec/runner/options.rb +32 -27
  116. data/lib/spec/runner/reporter.rb +8 -9
  117. data/lib/spec/test/unit.rb +10 -0
  118. data/lib/spec/version.rb +2 -2
  119. data/{features/support → resources}/helpers/cmdline.rb +2 -2
  120. data/resources/rake/verify_rcov.rake +1 -1
  121. data/resources/spec/example_group_with_should_methods.rb +1 -1
  122. data/resources/spec/simple_spec.rb +1 -1
  123. data/resources/test/spec_and_test_together.rb +2 -3
  124. data/resources/test/spec_including_test_but_not_unit.rb +1 -1
  125. data/resources/test/test_case_with_should_methods.rb +2 -3
  126. data/spec/autotest/autotest_helper.rb +0 -1
  127. data/spec/autotest/rspec_spec.rb +95 -98
  128. data/spec/spec/dsl/main_spec.rb +3 -3
  129. data/spec/spec/dsl/matchers_spec.rb +25 -0
  130. data/spec/spec/example/example_group_class_definition_spec.rb +14 -15
  131. data/spec/spec/example/example_group_factory_spec.rb +31 -44
  132. data/spec/spec/example/example_group_methods_spec.rb +86 -52
  133. data/spec/spec/example/example_group_spec.rb +32 -79
  134. data/spec/spec/example/example_matcher_spec.rb +10 -10
  135. data/spec/spec/example/example_methods_spec.rb +108 -242
  136. data/spec/spec/example/nested_example_group_spec.rb +2 -2
  137. data/spec/spec/example/pending_module_spec.rb +66 -41
  138. data/spec/spec/example/shared_example_group_spec.rb +4 -4
  139. data/spec/spec/{matchers → expectations}/handler_spec.rb +52 -4
  140. data/spec/spec/interop/test/unit/resources/spec_that_fails.rb +2 -2
  141. data/spec/spec/interop/test/unit/resources/spec_that_passes.rb +2 -2
  142. data/spec/spec/interop/test/unit/resources/spec_with_errors.rb +2 -2
  143. data/spec/spec/interop/test/unit/resources/spec_with_options_hash.rb +2 -2
  144. data/spec/spec/interop/test/unit/resources/test_case_that_fails.rb +2 -2
  145. data/spec/spec/interop/test/unit/resources/test_case_that_passes.rb +2 -2
  146. data/spec/spec/interop/test/unit/resources/test_case_with_errors.rb +2 -2
  147. data/spec/spec/interop/test/unit/resources/testsuite_adapter_spec_with_test_unit.rb +2 -2
  148. data/spec/spec/interop/test/unit/testcase_spec.rb +0 -4
  149. data/spec/spec/matchers/be_close_spec.rb +1 -1
  150. data/spec/spec/matchers/be_instance_of_spec.rb +29 -0
  151. data/spec/spec/matchers/be_kind_of_spec.rb +29 -0
  152. data/spec/spec/matchers/change_spec.rb +20 -0
  153. data/spec/spec/matchers/compatibility_spec.rb +34 -0
  154. data/spec/spec/matchers/description_generation_spec.rb +0 -12
  155. data/spec/spec/matchers/eql_spec.rb +2 -2
  156. data/spec/spec/matchers/equal_spec.rb +2 -2
  157. data/spec/spec/matchers/exist_spec.rb +8 -4
  158. data/spec/spec/matchers/have_spec.rb +4 -4
  159. data/spec/spec/matchers/match_spec.rb +2 -2
  160. data/spec/spec/matchers/matcher_methods_spec.rb +1 -1
  161. data/spec/spec/matchers/matcher_spec.rb +97 -0
  162. data/spec/spec/matchers/throw_symbol_spec.rb +8 -8
  163. data/spec/spec/mocks/{bug_report_496.rb → bug_report_496_spec.rb} +0 -0
  164. data/spec/spec/mocks/{failing_mock_argument_constraints_spec.rb → failing_argument_matchers_spec.rb} +2 -2
  165. data/spec/spec/mocks/hash_including_matcher_spec.rb +4 -4
  166. data/spec/spec/mocks/hash_not_including_matcher_spec.rb +3 -3
  167. data/spec/spec/mocks/mock_spec.rb +27 -2
  168. data/spec/spec/mocks/nil_expectation_warning_spec.rb +1 -1
  169. data/spec/spec/mocks/partial_mock_spec.rb +18 -3
  170. data/spec/spec/mocks/{passing_mock_argument_constraints_spec.rb → passing_argument_matchers_spec.rb} +6 -6
  171. data/spec/spec/mocks/stubbed_message_expectations_spec.rb +13 -1
  172. data/spec/spec/package/bin_spec_spec.rb +2 -2
  173. data/spec/spec/runner/configuration_spec.rb +12 -12
  174. data/spec/spec/runner/drb_command_line_spec.rb +71 -73
  175. data/spec/spec/runner/formatter/base_text_formatter_spec.rb +82 -1
  176. data/spec/spec/runner/formatter/failing_example_groups_formatter_spec.rb +8 -8
  177. data/spec/spec/runner/formatter/failing_examples_formatter_spec.rb +4 -4
  178. data/spec/spec/runner/formatter/html_formatted-1.8.6.html +8 -8
  179. data/spec/spec/runner/formatter/html_formatted-1.8.7.html +38 -26
  180. data/spec/spec/runner/formatter/html_formatted-1.9.1.html +61 -53
  181. data/spec/spec/runner/formatter/html_formatter_spec.rb +100 -48
  182. data/spec/spec/runner/formatter/nested_text_formatter_spec.rb +20 -34
  183. data/spec/spec/runner/formatter/profile_formatter_spec.rb +2 -1
  184. data/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +9 -6
  185. data/spec/spec/runner/formatter/specdoc_formatter_spec.rb +6 -6
  186. data/spec/spec/runner/formatter/text_mate_formatted-1.8.6.html +20 -20
  187. data/spec/spec/runner/formatter/text_mate_formatted-1.8.7.html +38 -26
  188. data/spec/spec/runner/formatter/text_mate_formatted-1.9.1.html +55 -47
  189. data/spec/spec/runner/formatter/{spec_mate_formatter_spec.rb → text_mate_formatter_spec.rb} +11 -9
  190. data/spec/spec/runner/heckle_runner_spec.rb +1 -1
  191. data/spec/spec/runner/heckler_spec.rb +1 -1
  192. data/spec/spec/runner/option_parser_spec.rb +28 -11
  193. data/spec/spec/runner/options_spec.rb +34 -0
  194. data/spec/spec/runner/reporter_spec.rb +66 -62
  195. data/spec/spec/runner/resources/utf8_encoded.rb +1 -0
  196. data/spec/spec/runner/spec_drb.opts +1 -0
  197. data/spec/spec/runner_spec.rb +7 -5
  198. data/spec/spec_helper.rb +24 -2
  199. metadata +49 -90
  200. data/examples/passing/autogenerated_docstrings_example.rb +0 -25
  201. data/examples/passing/before_and_after_example.rb +0 -40
  202. data/examples/passing/behave_as_example.rb +0 -45
  203. data/examples/passing/legacy_spec.rb +0 -11
  204. data/examples/passing/priority.txt +0 -1
  205. data/features/support/helpers/story_helper.rb +0 -16
  206. data/lib/spec/expectations/extensions/string_and_symbol.rb +0 -17
  207. data/lib/spec/runner/formatter/story/html_formatter.rb +0 -174
  208. data/lib/spec/runner/formatter/story/plain_text_formatter.rb +0 -194
  209. data/lib/spec/runner/formatter/story/progress_bar_formatter.rb +0 -42
  210. data/lib/spec/story.rb +0 -10
  211. data/lib/spec/story/extensions.rb +0 -3
  212. data/lib/spec/story/extensions/main.rb +0 -86
  213. data/lib/spec/story/extensions/regexp.rb +0 -9
  214. data/lib/spec/story/extensions/string.rb +0 -9
  215. data/lib/spec/story/given_scenario.rb +0 -14
  216. data/lib/spec/story/runner.rb +0 -57
  217. data/lib/spec/story/runner/plain_text_story_runner.rb +0 -48
  218. data/lib/spec/story/runner/scenario_collector.rb +0 -18
  219. data/lib/spec/story/runner/scenario_runner.rb +0 -54
  220. data/lib/spec/story/runner/story_mediator.rb +0 -137
  221. data/lib/spec/story/runner/story_parser.rb +0 -247
  222. data/lib/spec/story/runner/story_runner.rb +0 -74
  223. data/lib/spec/story/scenario.rb +0 -14
  224. data/lib/spec/story/step.rb +0 -70
  225. data/lib/spec/story/step_group.rb +0 -89
  226. data/lib/spec/story/step_mother.rb +0 -38
  227. data/lib/spec/story/story.rb +0 -39
  228. data/lib/spec/story/world.rb +0 -124
  229. data/resources/spec/spec_with_flexmock.rb +0 -19
  230. data/rspec.gemspec +0 -32
  231. data/spec/spec/matchers/mock_constraint_matchers_spec.rb +0 -24
  232. data/spec/spec/runner/formatter/story/html_formatter_spec.rb +0 -135
  233. data/spec/spec/runner/formatter/story/plain_text_formatter_spec.rb +0 -600
  234. data/spec/spec/runner/formatter/story/progress_bar_formatter_spec.rb +0 -82
  235. data/spec/spec/spec_spec.rb +0 -21
  236. data/spec/spec/story/builders.rb +0 -46
  237. data/spec/spec/story/extensions/main_spec.rb +0 -161
  238. data/spec/spec/story/extensions_spec.rb +0 -14
  239. data/spec/spec/story/given_scenario_spec.rb +0 -27
  240. data/spec/spec/story/runner/plain_text_story_runner_spec.rb +0 -90
  241. data/spec/spec/story/runner/scenario_collector_spec.rb +0 -27
  242. data/spec/spec/story/runner/scenario_runner_spec.rb +0 -214
  243. data/spec/spec/story/runner/story_mediator_spec.rb +0 -143
  244. data/spec/spec/story/runner/story_parser_spec.rb +0 -401
  245. data/spec/spec/story/runner/story_runner_spec.rb +0 -294
  246. data/spec/spec/story/runner_spec.rb +0 -93
  247. data/spec/spec/story/scenario_spec.rb +0 -18
  248. data/spec/spec/story/step_group_spec.rb +0 -157
  249. data/spec/spec/story/step_mother_spec.rb +0 -84
  250. data/spec/spec/story/step_spec.rb +0 -272
  251. data/spec/spec/story/story_helper.rb +0 -2
  252. data/spec/spec/story/story_spec.rb +0 -84
  253. data/spec/spec/story/world_spec.rb +0 -423
  254. data/story_server/prototype/javascripts/builder.js +0 -136
  255. data/story_server/prototype/javascripts/controls.js +0 -972
  256. data/story_server/prototype/javascripts/dragdrop.js +0 -976
  257. data/story_server/prototype/javascripts/effects.js +0 -1117
  258. data/story_server/prototype/javascripts/prototype.js +0 -4140
  259. data/story_server/prototype/javascripts/rspec.js +0 -149
  260. data/story_server/prototype/javascripts/scriptaculous.js +0 -58
  261. data/story_server/prototype/javascripts/slider.js +0 -276
  262. data/story_server/prototype/javascripts/sound.js +0 -55
  263. data/story_server/prototype/javascripts/unittest.js +0 -568
  264. data/story_server/prototype/lib/server.rb +0 -24
  265. data/story_server/prototype/stories.html +0 -176
  266. data/story_server/prototype/stylesheets/rspec.css +0 -136
  267. data/story_server/prototype/stylesheets/test.css +0 -90
@@ -1,4 +1,5 @@
1
1
  require 'spec/runner/formatter/base_formatter'
2
+ require 'fileutils'
2
3
 
3
4
  module Spec
4
5
  module Runner
@@ -23,27 +24,31 @@ module Spec
23
24
  end
24
25
 
25
26
  def example_pending(example, message, pending_caller)
26
- @pending_examples << [example.full_description, message, pending_caller]
27
+ @pending_examples << ["#{@example_group.description} #{example.description}", message, pending_caller]
27
28
  end
28
29
 
29
30
  def dump_failure(counter, failure)
30
31
  @output.puts
31
32
  @output.puts "#{counter.to_s})"
32
- @output.puts colourise("#{failure.header}\n#{failure.exception.message}", failure)
33
+ @output.puts colorize_failure("#{failure.header}\n#{failure.exception.message}", failure)
33
34
  @output.puts format_backtrace(failure.exception.backtrace)
34
35
  @output.flush
35
36
  end
36
37
 
37
- def colourise(s, failure)
38
- if(failure.expectation_not_met?)
39
- red(s)
40
- elsif(failure.pending_fixed?)
41
- blue(s)
42
- else
43
- magenta(s)
44
- end
38
+ def colorize_failure(message, failure)
39
+ failure.pending_fixed? ? blue(message) : red(message)
45
40
  end
46
-
41
+
42
+ def colourise(message, failure)
43
+ Kernel.warn <<-NOTICE
44
+ DEPRECATED: BaseTextFormatter#colourise is deprecated and will be
45
+ removed from a future version of RSpec.
46
+
47
+ Please use colorize_failure instead.
48
+ NOTICE
49
+ colorize_failure(message, failure)
50
+ end
51
+
47
52
  def dump_summary(duration, example_count, failure_count, pending_count)
48
53
  return if dry_run?
49
54
  @output.puts
@@ -78,9 +83,7 @@ module Spec
78
83
  end
79
84
 
80
85
  def close
81
- if IO === @output && @output != $stdout
82
- @output.close
83
- end
86
+ @output.close if (IO === @output) & (@output != $stdout)
84
87
  end
85
88
 
86
89
  def format_backtrace(backtrace)
@@ -91,11 +94,15 @@ module Spec
91
94
  protected
92
95
 
93
96
  def colour?
94
- @options.colour ? true : false
97
+ !!@options.colour
95
98
  end
96
99
 
97
100
  def dry_run?
98
- @options.dry_run ? true : false
101
+ !!@options.dry_run
102
+ end
103
+
104
+ def autospec?
105
+ !!@options.autospec
99
106
  end
100
107
 
101
108
  def backtrace_line(line)
@@ -103,7 +110,7 @@ module Spec
103
110
  end
104
111
 
105
112
  def colour(text, colour_code)
106
- return text unless colour? && output_to_tty?
113
+ return text unless ENV['RSPEC_COLOR'] || (colour? & (autospec? || output_to_tty?))
107
114
  "#{colour_code}#{text}\e[0m"
108
115
  end
109
116
 
@@ -117,10 +124,18 @@ module Spec
117
124
 
118
125
  def green(text); colour(text, "\e[32m"); end
119
126
  def red(text); colour(text, "\e[31m"); end
120
- def magenta(text); colour(text, "\e[35m"); end
121
127
  def yellow(text); colour(text, "\e[33m"); end
122
128
  def blue(text); colour(text, "\e[34m"); end
123
-
129
+
130
+ def magenta(text)
131
+ Kernel.warn <<-NOTICE
132
+ DEPRECATED: BaseTextFormatter#magenta is deprecated and will be
133
+ removed from a future version of RSpec.
134
+
135
+ Please use red instead (it is red/green/refactor after all).
136
+ NOTICE
137
+ red(text)
138
+ end
124
139
  end
125
140
  end
126
141
  end
@@ -6,21 +6,19 @@ module Spec
6
6
  class FailingExampleGroupsFormatter < BaseTextFormatter
7
7
  def example_failed(example, counter, failure)
8
8
  if @example_group
9
- description_parts = @example_group.description_parts.collect do |description|
10
- description =~ /(.*) \(druby.*\)$/ ? $1 : description
11
- end
12
- @output.puts ::Spec::Example::ExampleGroupMethods.description_text(*description_parts)
9
+ @output.puts @example_group.filtered_description(/(.*) \(druby.*\)$/)
13
10
 
14
11
  @output.flush
15
12
  @example_group = nil
16
13
  end
17
14
  end
18
-
15
+
19
16
  def dump_failure(counter, failure)
20
17
  end
21
18
 
22
19
  def dump_summary(duration, example_count, failure_count, pending_count)
23
20
  end
21
+
24
22
  end
25
23
  end
26
24
  end
@@ -38,7 +38,6 @@ module Spec
38
38
  def add_example_group(example_group)
39
39
  super
40
40
  @example_group_red = false
41
- @example_group_red = false
42
41
  @example_group_number += 1
43
42
  unless example_group_number == 1
44
43
  @output.puts " </dl>"
@@ -214,7 +213,7 @@ EOF
214
213
  def global_styles
215
214
  <<-EOF
216
215
  #rspec-header {
217
- background: #65C400; color: #fff; height: 42px;
216
+ background: #65C400; color: #fff; height: 4em;
218
217
  }
219
218
 
220
219
  .rspec-report h1 {
@@ -222,7 +221,7 @@ EOF
222
221
  padding: 10px;
223
222
  font-family: "Lucida Grande", Helvetica, sans-serif;
224
223
  font-size: 1.8em;
225
- float: left;
224
+ position: absolute;
226
225
  }
227
226
 
228
227
  #summary {
@@ -4,33 +4,25 @@ module Spec
4
4
  module Runner
5
5
  module Formatter
6
6
  class NestedTextFormatter < BaseTextFormatter
7
- attr_reader :previous_nested_example_groups
8
7
  def initialize(options, where)
9
8
  super
10
- @previous_nested_example_groups = []
9
+ @last_nested_descriptions = []
11
10
  end
12
11
 
13
12
  def add_example_group(example_group)
14
13
  super
15
14
 
16
- current_nested_example_groups = described_example_group_chain
17
- current_nested_example_groups.each_with_index do |nested_example_group, i|
18
- unless nested_example_group == previous_nested_example_groups[i]
19
- output.puts "#{' ' * i}#{nested_example_group.description_args.join}"
15
+ example_group.nested_descriptions.each_with_index do |nested_description, i|
16
+ unless nested_description == @last_nested_descriptions[i]
17
+ output.puts "#{' ' * i}#{nested_description}"
20
18
  end
21
19
  end
22
20
 
23
- @previous_nested_example_groups = described_example_group_chain
21
+ @last_nested_descriptions = example_group.nested_descriptions
24
22
  end
25
23
 
26
24
  def example_failed(example, counter, failure)
27
- message = if failure.expectation_not_met?
28
- "#{current_indentation}#{example.description} (FAILED - #{counter})"
29
- else
30
- "#{current_indentation}#{example.description} (ERROR - #{counter})"
31
- end
32
-
33
- output.puts(failure.expectation_not_met? ? red(message) : magenta(message))
25
+ output.puts(red("#{current_indentation}#{example.description} (FAILED - #{counter})"))
34
26
  output.flush
35
27
  end
36
28
 
@@ -47,17 +39,7 @@ module Spec
47
39
  end
48
40
 
49
41
  def current_indentation
50
- ' ' * previous_nested_example_groups.length
51
- end
52
-
53
- def described_example_group_chain
54
- example_group_chain = []
55
- example_group.__send__(:example_group_hierarchy).each do |example_group_class|
56
- unless example_group_class.description_args.empty?
57
- example_group_chain << example_group_class
58
- end
59
- end
60
- example_group_chain
42
+ ' ' * @last_nested_descriptions.length
61
43
  end
62
44
  end
63
45
  end
@@ -5,7 +5,7 @@ module Spec
5
5
  module Formatter
6
6
  class ProgressBarFormatter < BaseTextFormatter
7
7
  def example_failed(example, counter, failure)
8
- @output.print colourise('F', failure)
8
+ @output.print colorize_failure('F', failure)
9
9
  @output.flush
10
10
  end
11
11
 
@@ -4,7 +4,7 @@ module Spec
4
4
  # This class extracts code snippets by looking at the backtrace of the passed error
5
5
  class SnippetExtractor #:nodoc:
6
6
  class NullConverter; def convert(code, pre); code; end; end #:nodoc:
7
- begin; require 'rubygems'; require 'syntax/convertors/html'; @@converter = Syntax::Convertors::HTML.for_syntax "ruby"; rescue LoadError => e; @@converter = NullConverter.new; end
7
+ begin; require 'syntax/convertors/html'; @@converter = Syntax::Convertors::HTML.for_syntax "ruby"; rescue LoadError => e; @@converter = NullConverter.new; end
8
8
 
9
9
  def snippet(error)
10
10
  raw_code, line = snippet_for(error.backtrace[0])
@@ -12,13 +12,7 @@ module Spec
12
12
  end
13
13
 
14
14
  def example_failed(example, counter, failure)
15
- message = if failure.expectation_not_met?
16
- "- #{example.description} (FAILED - #{counter})"
17
- else
18
- "- #{example.description} (ERROR - #{counter})"
19
- end
20
-
21
- output.puts(failure.expectation_not_met? ? red(message) : magenta(message))
15
+ output.puts(red("- #{example.description} (FAILED - #{counter})"))
22
16
  output.flush
23
17
  end
24
18
 
@@ -1,6 +1,5 @@
1
- unless Spec::Ruby.version.to_f == 1.9
1
+ if Spec::Ruby.version.to_f < 1.9
2
2
  begin
3
- require 'rubygems'
4
3
  require 'heckle'
5
4
  rescue LoadError ; raise "You must gem install heckle to use --heckle" ; end
6
5
 
@@ -56,16 +55,14 @@ unless Spec::Ruby.version.to_f == 1.9
56
55
  end
57
56
  end
58
57
 
59
- #Supports Heckle 1.2 and prior (earlier versions used Heckle::Base)
60
- class Heckler < (Heckle.const_defined?(:Base) ? Heckle::Base : Heckle)
58
+ class Heckler < Heckle
61
59
  def initialize(klass_name, method_name, rspec_options)
62
60
  super(klass_name, method_name)
63
61
  @rspec_options = rspec_options
64
62
  end
65
63
 
66
64
  def tests_pass?
67
- success = @rspec_options.run_examples
68
- success
65
+ @rspec_options.run_examples
69
66
  end
70
67
 
71
68
  end
@@ -3,7 +3,7 @@ module Spec
3
3
  # Dummy implementation for Windows that just fails (Heckle is not supported on Windows)
4
4
  class HeckleRunner
5
5
  def initialize(filter)
6
- raise "Heckle not supported on Windows"
6
+ raise "Heckle is not supported on Windows or Ruby 1.9"
7
7
  end
8
8
  end
9
9
  end
@@ -46,20 +46,15 @@ module Spec
46
46
  "not specified. The --format option may be specified several times",
47
47
  "if you want several outputs",
48
48
  " ",
49
- "Builtin formats for code examples:",
50
- "progress|p : Text-based progress bar",
49
+ "Builtin formats:",
50
+ "silent|l : No output", "progress|p : Text-based progress bar",
51
51
  "profile|o : Text-based progress bar with profiling of 10 slowest examples",
52
52
  "specdoc|s : Code example doc strings",
53
- "nested|n : Code example doc strings with nested groups intented",
53
+ "nested|n : Code example doc strings with nested groups indented",
54
54
  "html|h : A nice HTML report",
55
55
  "failing_examples|e : Write all failing examples - input for --example",
56
56
  "failing_example_groups|g : Write all failing example groups - input for --example",
57
57
  " ",
58
- "Builtin formats for stories:",
59
- "plain|p : Plain Text",
60
- "html|h : A nice HTML report",
61
- "progress|r : Text progress",
62
- " ",
63
58
  "FORMAT can also be the name of a custom formatter class",
64
59
  "(in which case you should also specify --require to load it)"],
65
60
  :require => ["-r", "--require FILE", "Require FILE before running specs",
@@ -112,19 +107,24 @@ module Spec
112
107
  on(*OPTIONS[:timeout]) {|timeout| @options.timeout = timeout.to_f}
113
108
  on(*OPTIONS[:heckle]) {|heckle| @options.load_heckle_runner(heckle)}
114
109
  on(*OPTIONS[:dry_run]) {@options.dry_run = true}
115
- on(*OPTIONS[:options_file]) {|options_file| parse_options_file(options_file)}
110
+ on(*OPTIONS[:options_file]) {|options_file|}
116
111
  on(*OPTIONS[:generate_options]) {|options_file|}
117
112
  on(*OPTIONS[:runner]) {|runner| @options.user_input_for_runner = runner}
118
113
  on(*OPTIONS[:drb]) {}
119
114
  on(*OPTIONS[:version]) {parse_version}
115
+ on("--autospec") {@options.autospec = true}
120
116
  on_tail(*OPTIONS[:help]) {parse_help}
121
117
  end
122
118
 
123
119
  def order!(argv, &blk)
124
120
  @argv = argv.dup
125
- @argv = (@argv.empty? && self.class.spec_command?) ? ['--help'] : @argv
121
+ @argv = (@argv.empty? & self.class.spec_command?) ? ['--help'] : @argv
122
+
123
+ # Parse options file first
124
+ parse_file_options(:options_file, :parse_options_file)
125
+
126
126
  @options.argv = @argv.dup
127
- return if parse_generate_options
127
+ return if parse_file_options(:generate_options, :write_generated_options)
128
128
  return if parse_drb
129
129
 
130
130
  super(@argv) do |file|
@@ -145,16 +145,14 @@ module Spec
145
145
  def parse_options_file(options_file)
146
146
  option_file_args = IO.readlines(options_file).map {|l| l.chomp.split " "}.flatten
147
147
  @argv.push(*option_file_args)
148
- # TODO - this is a brute force solution to http://rspec.lighthouseapp.com/projects/5645/tickets/293.
149
- # Let's look for a cleaner way. Might not be one. But let's look. If not, perhaps
150
- # this can be moved to a different method to indicate the special handling for drb?
151
- parse_drb(@argv)
152
148
  end
153
149
 
154
- def parse_generate_options
155
- # Remove the --generate-options option and the argument before writing to file
150
+ def parse_file_options(option_name, action)
151
+ # Remove the file option and the argument before handling the file
156
152
  options_file = nil
157
- ['-G', '--generate-options'].each do |option|
153
+ options_list = OPTIONS[option_name][0..1]
154
+ options_list[1].gsub!(" PATH", "")
155
+ options_list.each do |option|
158
156
  if index = @argv.index(option)
159
157
  @argv.delete_at(index)
160
158
  options_file = @argv.delete_at(index)
@@ -162,7 +160,7 @@ module Spec
162
160
  end
163
161
 
164
162
  if options_file
165
- write_generated_options(options_file)
163
+ send(action, options_file)
166
164
  return true
167
165
  else
168
166
  return false
@@ -178,8 +176,8 @@ module Spec
178
176
  @options.examples_should_not_be_run
179
177
  end
180
178
 
181
- def parse_drb(argv = nil)
182
- argv ||= @options.argv # TODO - see note about about http://rspec.lighthouseapp.com/projects/5645/tickets/293
179
+ def parse_drb
180
+ argv = @options.argv
183
181
  is_drb = false
184
182
  is_drb ||= argv.delete(OPTIONS[:drb][0])
185
183
  is_drb ||= argv.delete(OPTIONS[:drb][1])
@@ -6,6 +6,8 @@ module Spec
6
6
  }
7
7
 
8
8
  EXAMPLE_FORMATTERS = { # Load these lazily for better speed
9
+ 'silent' => ['spec/runner/formatter/base_formatter', 'Formatter::BaseFormatter'],
10
+ 'l' => ['spec/runner/formatter/base_formatter', 'Formatter::BaseFormatter'],
9
11
  'specdoc' => ['spec/runner/formatter/specdoc_formatter', 'Formatter::SpecdocFormatter'],
10
12
  's' => ['spec/runner/formatter/specdoc_formatter', 'Formatter::SpecdocFormatter'],
11
13
  'nested' => ['spec/runner/formatter/nested_text_formatter', 'Formatter::NestedTextFormatter'],
@@ -23,17 +25,8 @@ module Spec
23
25
  'textmate' => ['spec/runner/formatter/text_mate_formatter', 'Formatter::TextMateFormatter']
24
26
  }
25
27
 
26
- STORY_FORMATTERS = {
27
- 'plain' => ['spec/runner/formatter/story/plain_text_formatter', 'Formatter::Story::PlainTextFormatter'],
28
- 'p' => ['spec/runner/formatter/story/plain_text_formatter', 'Formatter::Story::PlainTextFormatter'],
29
- 'html' => ['spec/runner/formatter/story/html_formatter', 'Formatter::Story::HtmlFormatter'],
30
- 'h' => ['spec/runner/formatter/story/html_formatter', 'Formatter::Story::HtmlFormatter'],
31
- 'progress' => ['spec/runner/formatter/story/progress_bar_formatter', 'Formatter::Story::ProgressBarFormatter'],
32
- 'r' => ['spec/runner/formatter/story/progress_bar_formatter', 'Formatter::Story::ProgressBarFormatter']
33
-
34
- }
35
-
36
28
  attr_accessor(
29
+ :autospec, # hack to tell
37
30
  :filename_pattern,
38
31
  :backtrace_tweaker,
39
32
  :context_lines,
@@ -94,11 +87,14 @@ module Spec
94
87
  runner.load_files(files_to_load)
95
88
  @files_loaded = true
96
89
  end
90
+
91
+ define_predicate_matchers
92
+ plugin_mock_framework
97
93
 
98
94
  # TODO - this has to happen after the files get loaded,
99
95
  # otherwise the before_suite_parts are not populated
100
96
  # from the configuration. There is no spec for this
101
- # directly, but stories/configuration/before_blocks.story
97
+ # directly, but features/before_and_after_blocks/before_and_after_blocks.story
102
98
  # will fail if this happens before the files are loaded.
103
99
  before_suite_parts.each do |part|
104
100
  part.call
@@ -115,7 +111,7 @@ module Spec
115
111
  end
116
112
  ensure
117
113
  after_suite_parts.each do |part|
118
- part.call(success)
114
+ part.arity < 1 ? part.call : part.call(success)
119
115
  end
120
116
  end
121
117
  end
@@ -136,11 +132,6 @@ module Spec
136
132
  @examples_should_be_run = false
137
133
  end
138
134
 
139
- def predicate_matchers
140
- # TODO - don't like this dependency - perhaps store these in here instead?
141
- Spec::Runner.configuration.predicate_matchers
142
- end
143
-
144
135
  def mock_framework
145
136
  # TODO - don't like this dependency - perhaps store this in here instead?
146
137
  Spec::Runner.configuration.mock_framework
@@ -151,7 +142,6 @@ module Spec
151
142
  if @colour && RUBY_PLATFORM =~ /mswin|mingw/ ;\
152
143
  begin ;\
153
144
  replace_output = @output_stream.equal?($stdout) ;\
154
- require 'rubygems' ;\
155
145
  require 'Win32/Console/ANSI' ;\
156
146
  @output_stream = $stdout if replace_output ;\
157
147
  rescue LoadError ;\
@@ -199,11 +189,6 @@ module Spec
199
189
  @formatters ||= load_formatters(@format_options, EXAMPLE_FORMATTERS)
200
190
  end
201
191
 
202
- def story_formatters
203
- @format_options ||= [['plain', @output_stream]]
204
- @formatters ||= load_formatters(@format_options, STORY_FORMATTERS)
205
- end
206
-
207
192
  def load_formatters(format_options, formatters)
208
193
  format_options.map do |format, where|
209
194
  formatter_type = if formatters[format]
@@ -217,9 +202,10 @@ module Spec
217
202
  end
218
203
 
219
204
  def load_heckle_runner(heckle)
220
- suffix = [/mswin/, /java/].detect{|p| p =~ RUBY_PLATFORM} ? '_unsupported' : ''
205
+ @format_options ||= [['silent', @output_stream]]
206
+ suffix = ([/mswin/, /java/].detect{|p| p =~ RUBY_PLATFORM} || Spec::Ruby.version.to_f == 1.9) ? '_unsupported' : ''
221
207
  require "spec/runner/heckle_runner#{suffix}"
222
- @heckle_runner = HeckleRunner.new(heckle)
208
+ @heckle_runner = ::Spec::Runner::HeckleRunner.new(heckle)
223
209
  end
224
210
 
225
211
  def number_of_examples
@@ -247,7 +233,26 @@ module Spec
247
233
  @dry_run == true
248
234
  end
249
235
 
250
- protected
236
+ protected
237
+
238
+ def define_predicate_matchers
239
+ Spec::Runner.configuration.predicate_matchers.each_pair do |matcher_method, method_on_object|
240
+ Spec::Example::ExampleMethods::__send__ :define_method, matcher_method do |*args|
241
+ eval("be_#{method_on_object.to_s.gsub('?','')}(*args)")
242
+ end
243
+ end
244
+ end
245
+
246
+ def plugin_mock_framework
247
+ case mock_framework
248
+ when Module
249
+ Spec::Example::ExampleMethods.__send__ :include, mock_framework
250
+ else
251
+ require mock_framework
252
+ Spec::Example::ExampleMethods.__send__ :include, Spec::Adapters::MockFramework
253
+ end
254
+ end
255
+
251
256
  def examples_should_be_run?
252
257
  return @examples_should_be_run unless @examples_should_be_run.nil?
253
258
  @examples_should_be_run = true
@@ -304,7 +309,7 @@ module Spec
304
309
 
305
310
  def default_differ
306
311
  require 'spec/expectations/differs/default'
307
- self.differ_class = Spec::Expectations::Differs::Default
312
+ self.differ_class = ::Spec::Expectations::Differs::Default
308
313
  end
309
314
 
310
315
  def set_spec_from_line_number