rspec 1.1.3 → 1.1.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (122) hide show
  1. data/CHANGES +35 -0
  2. data/MIT-LICENSE +1 -1
  3. data/README +9 -44
  4. data/Rakefile +34 -51
  5. data/TODO +0 -1
  6. data/UPGRADE +0 -24
  7. data/bin/spec +0 -0
  8. data/bin/spec_translator +0 -0
  9. data/examples/pure/behave_as_example.rb +0 -0
  10. data/examples/pure/partial_mock_example.rb +1 -0
  11. data/examples/stories/calculator.rb +1 -1
  12. data/lib/autotest/rspec.rb +7 -9
  13. data/lib/spec/example.rb +1 -1
  14. data/lib/spec/example/configuration.rb +30 -16
  15. data/lib/spec/example/example_group.rb +2 -1
  16. data/lib/spec/example/example_group_factory.rb +23 -21
  17. data/lib/spec/example/example_group_methods.rb +18 -5
  18. data/lib/spec/example/example_matcher.rb +0 -0
  19. data/lib/spec/example/example_methods.rb +6 -0
  20. data/lib/spec/example/module_inclusion_warnings.rb +37 -0
  21. data/lib/spec/expectations/differs/default.rb +1 -1
  22. data/lib/spec/expectations/extensions/object.rb +4 -12
  23. data/lib/spec/expectations/handler.rb +8 -0
  24. data/lib/spec/extensions.rb +1 -0
  25. data/lib/spec/extensions/metaclass.rb +7 -0
  26. data/lib/spec/extensions/object.rb +0 -4
  27. data/lib/spec/matchers/change.rb +1 -1
  28. data/lib/spec/matchers/has.rb +1 -11
  29. data/lib/spec/matchers/operator_matcher.rb +0 -0
  30. data/lib/spec/matchers/raise_error.rb +53 -30
  31. data/lib/spec/mocks.rb +1 -1
  32. data/lib/spec/mocks/argument_constraint_matchers.rb +5 -1
  33. data/lib/spec/mocks/argument_expectation.rb +26 -0
  34. data/lib/spec/mocks/extensions.rb +1 -0
  35. data/lib/spec/mocks/framework.rb +15 -0
  36. data/lib/spec/mocks/message_expectation.rb +29 -5
  37. data/lib/spec/mocks/mock.rb +9 -7
  38. data/lib/spec/mocks/proxy.rb +26 -12
  39. data/lib/spec/rake/spectask.rb +5 -5
  40. data/lib/spec/runner/backtrace_tweaker.rb +1 -1
  41. data/lib/spec/runner/formatter/base_formatter.rb +2 -3
  42. data/lib/spec/runner/formatter/base_text_formatter.rb +2 -2
  43. data/lib/spec/runner/formatter/failing_example_groups_formatter.rb +4 -8
  44. data/lib/spec/runner/formatter/html_formatter.rb +18 -14
  45. data/lib/spec/runner/formatter/nested_text_formatter.rb +65 -0
  46. data/lib/spec/runner/formatter/profile_formatter.rb +4 -0
  47. data/lib/spec/runner/formatter/progress_bar_formatter.rb +5 -1
  48. data/lib/spec/runner/formatter/specdoc_formatter.rb +1 -1
  49. data/lib/spec/runner/formatter/story/plain_text_formatter.rb +18 -7
  50. data/lib/spec/runner/option_parser.rb +17 -15
  51. data/lib/spec/runner/options.rb +37 -14
  52. data/lib/spec/runner/reporter.rb +15 -11
  53. data/lib/spec/story/extensions/regexp.rb +2 -2
  54. data/lib/spec/story/extensions/string.rb +2 -2
  55. data/lib/spec/story/runner.rb +9 -5
  56. data/lib/spec/story/runner/plain_text_story_runner.rb +2 -2
  57. data/lib/spec/story/runner/scenario_runner.rb +8 -0
  58. data/lib/spec/story/runner/story_mediator.rb +1 -1
  59. data/lib/spec/story/runner/story_runner.rb +3 -1
  60. data/lib/spec/story/step.rb +4 -4
  61. data/lib/spec/story/story.rb +8 -11
  62. data/lib/spec/story/world.rb +0 -1
  63. data/lib/spec/version.rb +2 -2
  64. data/plugins/mock_frameworks/rspec.rb +2 -0
  65. data/spec/autotest/rspec_spec.rb +12 -10
  66. data/spec/spec/example/configuration_spec.rb +0 -0
  67. data/spec/spec/example/example_group/described_module_spec.rb +20 -0
  68. data/spec/spec/example/example_group/warning_messages_spec.rb +76 -0
  69. data/spec/spec/example/example_group_factory_spec.rb +117 -102
  70. data/spec/spec/example/example_group_methods_spec.rb +51 -17
  71. data/spec/spec/example/example_group_spec.rb +13 -1
  72. data/spec/spec/example/example_methods_spec.rb +28 -6
  73. data/spec/spec/example/nested_example_group_spec.rb +12 -0
  74. data/spec/spec/example/predicate_matcher_spec.rb +0 -0
  75. data/spec/spec/expectations/differs/default_spec.rb +27 -9
  76. data/spec/spec/matchers/be_spec.rb +24 -0
  77. data/spec/spec/matchers/has_spec.rb +16 -0
  78. data/spec/spec/matchers/raise_error_spec.rb +124 -0
  79. data/spec/spec/mocks/{bug_report_10263.rb → bug_report_10263_spec.rb} +0 -0
  80. data/spec/spec/mocks/bug_report_11545_spec.rb +2 -0
  81. data/spec/spec/mocks/failing_mock_argument_constraints_spec.rb +8 -0
  82. data/spec/spec/mocks/hash_including_matcher_spec.rb +32 -0
  83. data/spec/spec/mocks/mock_spec.rb +56 -37
  84. data/spec/spec/mocks/partial_mock_spec.rb +41 -5
  85. data/spec/spec/mocks/passing_mock_argument_constraints_spec.rb +6 -0
  86. data/spec/spec/runner/execution_context_spec.rb +7 -1
  87. data/spec/spec/runner/formatter/failing_example_groups_formatter_spec.rb +3 -2
  88. data/spec/spec/runner/formatter/html_formatted-1.8.6.html +30 -25
  89. data/spec/spec/runner/formatter/html_formatter_spec.rb +0 -3
  90. data/spec/spec/runner/formatter/nested_text_formatter_spec.rb +333 -0
  91. data/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +12 -2
  92. data/spec/spec/runner/formatter/spec_mate_formatter_spec.rb +2 -2
  93. data/spec/spec/runner/formatter/specdoc_formatter_spec.rb +110 -78
  94. data/spec/spec/runner/formatter/story/plain_text_formatter_spec.rb +105 -1
  95. data/spec/spec/runner/formatter/text_mate_formatted-1.8.6.html +33 -28
  96. data/spec/spec/runner/option_parser_spec.rb +65 -49
  97. data/spec/spec/runner/options_spec.rb +103 -17
  98. data/spec/spec/runner/reporter_spec.rb +10 -7
  99. data/spec/spec/runner/spec_drb.opts +1 -0
  100. data/spec/spec/runner/spec_parser_spec.rb +10 -4
  101. data/spec/spec/story/runner/plain_text_story_runner_spec.rb +14 -13
  102. data/spec/spec/story/runner/scenario_runner_spec.rb +124 -52
  103. data/spec/spec/story/runner/story_mediator_spec.rb +2 -2
  104. data/spec/spec/story/runner/story_runner_spec.rb +40 -2
  105. data/spec/spec/story/runner_spec.rb +59 -72
  106. data/spec/spec/story/step_spec.rb +20 -1
  107. data/spec/spec/story/story_spec.rb +2 -2
  108. data/stories/all.rb +1 -1
  109. data/stories/example_groups/stories.rb +4 -3
  110. data/stories/mock_framework_integration/stories.rb +7 -0
  111. data/stories/mock_framework_integration/use_flexmock.story +9 -0
  112. data/stories/resources/spec/spec_with_flexmock.rb +18 -0
  113. metadata +21 -18
  114. data/pre_commit/lib/pre_commit.rb +0 -4
  115. data/pre_commit/lib/pre_commit/core.rb +0 -50
  116. data/pre_commit/lib/pre_commit/pre_commit.rb +0 -54
  117. data/pre_commit/lib/pre_commit/rspec.rb +0 -111
  118. data/pre_commit/lib/pre_commit/rspec_on_rails.rb +0 -313
  119. data/pre_commit/spec/pre_commit/pre_commit_spec.rb +0 -15
  120. data/pre_commit/spec/pre_commit/rspec_on_rails_spec.rb +0 -36
  121. data/pre_commit/spec/spec_helper.rb +0 -3
  122. data/pre_commit/spec/spec_suite.rb +0 -11
@@ -17,9 +17,6 @@ module Spec
17
17
  expected_file = File.dirname(__FILE__) + "/html_formatted-#{::VERSION}#{suffix}.html"
18
18
  raise "There is no HTML file with expected content for this platform: #{expected_file}" unless File.file?(expected_file)
19
19
  expected_html = File.read(expected_file)
20
- unless jruby?
21
- raise "There should be no absolute paths in html_formatted.html!!" if (expected_html =~ /\/Users/n || expected_html =~ /\/home/n)
22
- end
23
20
 
24
21
  Dir.chdir(root) do
25
22
  args = ['failing_examples/mocking_example.rb', 'failing_examples/diffing_spec.rb', 'examples/pure/stubbing_example.rb', 'examples/pure/pending_example.rb', '--format', 'html', opt]
@@ -0,0 +1,333 @@
1
+ require File.dirname(__FILE__) + '/../../../spec_helper.rb'
2
+ require 'spec/runner/formatter/nested_text_formatter'
3
+
4
+ module Spec
5
+ module Runner
6
+ module Formatter
7
+ describe NestedTextFormatter do
8
+ it_should_behave_like "sandboxed rspec_options"
9
+ attr_reader :io, :options, :formatter, :example_group
10
+ before(:each) do
11
+ @io = StringIO.new
12
+ options.stub!(:dry_run).and_return(false)
13
+ options.stub!(:colour).and_return(false)
14
+ @formatter = NestedTextFormatter.new(options, io)
15
+ @example_group = ::Spec::Example::ExampleGroup.describe("ExampleGroup") do
16
+ specify "example" do
17
+ end
18
+ end
19
+ end
20
+
21
+ describe "where ExampleGroup has no superclasss with a description" do
22
+ before do
23
+ add_example_group
24
+ end
25
+
26
+ def add_example_group
27
+ formatter.add_example_group(example_group)
28
+ end
29
+
30
+ describe "#dump_summary" do
31
+ it "should produce standard summary without pending when pending has a 0 count" do
32
+ formatter.dump_summary(3, 2, 1, 0)
33
+ expected_output = <<-OUT
34
+ ExampleGroup
35
+
36
+ Finished in 3 seconds
37
+
38
+ 2 examples, 1 failure
39
+ OUT
40
+
41
+ io.string.should == expected_output.gsub(/^ /, '')
42
+ end
43
+
44
+ it "should produce standard summary" do
45
+ formatter.dump_summary(3, 2, 1, 4)
46
+ expected_output = <<-OUT
47
+ ExampleGroup
48
+
49
+ Finished in 3 seconds
50
+
51
+ 2 examples, 1 failure, 4 pending
52
+ OUT
53
+ io.string.should == expected_output.gsub(/^ /, '')
54
+ end
55
+ end
56
+
57
+ describe "#add_example_group" do
58
+ describe "when ExampleGroup has description_args" do
59
+ before do
60
+ example_group.description_args.should_not be_nil
61
+ end
62
+
63
+ describe "when ExampleGroup has no parents with description args" do
64
+ before do
65
+ example_group.superclass.description_args.should be_nil
66
+ end
67
+
68
+ it "should push ExampleGroup name" do
69
+ io.string.should eql("ExampleGroup\n")
70
+ end
71
+ end
72
+
73
+ describe "when ExampleGroup has one parent with description args" do
74
+ attr_reader :child_example_group
75
+ def add_example_group
76
+ example_group.description_args.should_not be_nil
77
+ @child_example_group = Class.new(example_group).describe("Child ExampleGroup")
78
+ end
79
+
80
+ describe "and parent ExampleGroups have not been printed" do
81
+ before do
82
+ formatter.add_example_group(child_example_group)
83
+ end
84
+
85
+ it "should push ExampleGroup name with two spaces of indentation" do
86
+ expected_output = <<-OUT
87
+ ExampleGroup
88
+ Child ExampleGroup
89
+ OUT
90
+ io.string.should == expected_output.gsub(/^ /, '')
91
+ end
92
+ end
93
+
94
+ describe "and parent ExampleGroups have been printed" do
95
+ before do
96
+ formatter.add_example_group(example_group)
97
+ io.string = ""
98
+ formatter.add_example_group(child_example_group)
99
+ end
100
+
101
+ it "should print only the indented ExampleGroup" do
102
+ expected_output = <<-OUT
103
+ Child ExampleGroup
104
+ OUT
105
+ io.string.should == expected_output.gsub(/^ /, '')
106
+ end
107
+ end
108
+ end
109
+
110
+ describe "when ExampleGroup has two parents with description args" do
111
+ attr_reader :child_example_group, :grand_child_example_group
112
+ def add_example_group
113
+ example_group.description_args.should_not be_nil
114
+ @child_example_group = Class.new(example_group).describe("Child ExampleGroup")
115
+ @grand_child_example_group = Class.new(child_example_group).describe("GrandChild ExampleGroup")
116
+ end
117
+
118
+ describe "and parent ExampleGroups have not been printed" do
119
+ before do
120
+ formatter.add_example_group(grand_child_example_group)
121
+ end
122
+
123
+ it "should print the entire nested ExampleGroup heirarchy" do
124
+ expected_output = <<-OUT
125
+ ExampleGroup
126
+ Child ExampleGroup
127
+ GrandChild ExampleGroup
128
+ OUT
129
+ io.string.should == expected_output.gsub(/^ /, '')
130
+ end
131
+ end
132
+
133
+ describe "and parent ExampleGroups have been printed" do
134
+ before do
135
+ formatter.add_example_group(child_example_group)
136
+ io.string = ""
137
+ formatter.add_example_group(grand_child_example_group)
138
+ end
139
+
140
+ it "should print only the indented ExampleGroup" do
141
+ expected_output = <<-OUT
142
+ GrandChild ExampleGroup
143
+ OUT
144
+ io.string.should == expected_output.gsub(/^ /, '')
145
+ end
146
+ end
147
+ end
148
+ end
149
+
150
+ describe "when ExampleGroup description_args is nil" do
151
+ attr_reader :child_example_group
152
+
153
+ describe "and parent ExampleGroups have not been printed" do
154
+ def add_example_group
155
+ @child_example_group = Class.new(example_group)
156
+ child_example_group.description_args.should be_nil
157
+ formatter.add_example_group(child_example_group)
158
+ end
159
+
160
+ it "should render only the parent ExampleGroup" do
161
+ expected_output = <<-OUT
162
+ ExampleGroup
163
+ OUT
164
+ io.string.should == expected_output.gsub(/^ /, '')
165
+ end
166
+ end
167
+
168
+ describe "and parent ExampleGroups have been printed" do
169
+ def add_example_group
170
+ @child_example_group = Class.new(example_group)
171
+ child_example_group.description_args.should be_nil
172
+ formatter.add_example_group(example_group)
173
+ io.string = ""
174
+ formatter.add_example_group(child_example_group)
175
+ end
176
+
177
+ it "should not render anything" do
178
+ io.string.should == ""
179
+ end
180
+ end
181
+ end
182
+
183
+ describe "when ExampleGroup description_args is empty" do
184
+ def add_example_group
185
+ example_group.set_description
186
+ example_group.description_args.should be_empty
187
+ super
188
+ end
189
+
190
+ it "should not render anything" do
191
+ io.string.should == ""
192
+ end
193
+ end
194
+ end
195
+
196
+ describe "#example_failed" do
197
+ describe "where ExampleGroup has no superclasss with a description" do
198
+ describe "when having an error" do
199
+ it "should push failing spec name and failure number" do
200
+ formatter.example_failed(
201
+ example_group.it("spec"),
202
+ 98,
203
+ Reporter::Failure.new("c s", RuntimeError.new)
204
+ )
205
+ expected_output = <<-OUT
206
+ ExampleGroup
207
+ spec (ERROR - 98)
208
+ OUT
209
+ io.string.should == expected_output.gsub(/^ /, '')
210
+ end
211
+ end
212
+
213
+ describe "when having an expectation failure" do
214
+ it "should push failing spec name and failure number" do
215
+ formatter.example_failed(
216
+ example_group.it("spec"),
217
+ 98,
218
+ Reporter::Failure.new("c s", Spec::Expectations::ExpectationNotMetError.new)
219
+ )
220
+ expected_output = <<-OUT
221
+ ExampleGroup
222
+ spec (FAILED - 98)
223
+ OUT
224
+ io.string.should == expected_output.gsub(/^ /, '')
225
+ end
226
+ end
227
+ end
228
+
229
+ describe "where ExampleGroup has two superclasses with a description" do
230
+ attr_reader :child_example_group, :grand_child_example_group
231
+
232
+ def add_example_group
233
+ @child_example_group = Class.new(example_group).describe("Child ExampleGroup")
234
+ @grand_child_example_group = Class.new(child_example_group).describe("GrandChild ExampleGroup")
235
+ formatter.add_example_group(grand_child_example_group)
236
+ end
237
+
238
+ describe "when having an error" do
239
+ it "should push failing spec name and failure number" do
240
+ formatter.example_failed(
241
+ grand_child_example_group.it("spec"),
242
+ 98,
243
+ Reporter::Failure.new("c s", RuntimeError.new)
244
+ )
245
+ expected_output = <<-OUT
246
+ ExampleGroup
247
+ Child ExampleGroup
248
+ GrandChild ExampleGroup
249
+ spec (ERROR - 98)
250
+ OUT
251
+ io.string.should == expected_output.gsub(/^ /, '')
252
+ end
253
+ end
254
+
255
+ describe "when having an expectation" do
256
+ it "should push failing spec name and failure number" do
257
+ formatter.example_failed(
258
+ grand_child_example_group.it("spec"),
259
+ 98,
260
+ Reporter::Failure.new("c s", Spec::Expectations::ExpectationNotMetError.new)
261
+ )
262
+ expected_output = <<-OUT
263
+ ExampleGroup
264
+ Child ExampleGroup
265
+ GrandChild ExampleGroup
266
+ spec (FAILED - 98)
267
+ OUT
268
+ io.string.should == expected_output.gsub(/^ /, '')
269
+ end
270
+ end
271
+ end
272
+ end
273
+
274
+ describe "#start" do
275
+ it "should push nothing on start" do
276
+ formatter.start(5)
277
+ expected_output = <<-OUT
278
+ ExampleGroup
279
+ OUT
280
+ io.string.should == expected_output.gsub(/^ /, '')
281
+ end
282
+ end
283
+
284
+ describe "#start_dump" do
285
+ it "should push nothing on start dump" do
286
+ formatter.start_dump
287
+ expected_output = <<-OUT
288
+ ExampleGroup
289
+ OUT
290
+ io.string.should == expected_output.gsub(/^ /, '')
291
+ end
292
+ end
293
+
294
+ describe "#example_passed" do
295
+ it "should push passing spec name" do
296
+ formatter.example_passed(example_group.it("spec"))
297
+ expected_output = <<-OUT
298
+ ExampleGroup
299
+ spec
300
+ OUT
301
+ io.string.should == expected_output.gsub(/^ /, '')
302
+ end
303
+ end
304
+
305
+ describe "#example_pending" do
306
+ it "should push pending example name and message" do
307
+ formatter.example_pending(example_group.examples.first, 'reason')
308
+ expected_output = <<-OUT
309
+ ExampleGroup
310
+ example (PENDING: reason)
311
+ OUT
312
+ io.string.should == expected_output.gsub(/^ /, '')
313
+ end
314
+
315
+ it "should dump pending" do
316
+ formatter.example_pending(example_group.examples.first, 'reason')
317
+ io.rewind
318
+ formatter.dump_pending
319
+ io.string.should =~ /Pending\:\nExampleGroup example \(reason\)\n/
320
+ end
321
+ end
322
+
323
+ def have_single_level_example_group_output(expected_output)
324
+ expected = "ExampleGroup\n #{expected_output}"
325
+ ::Spec::Matchers::SimpleMatcher.new(expected) do |actual|
326
+ actual == expected
327
+ end
328
+ end
329
+ end
330
+ end
331
+ end
332
+ end
333
+ end
@@ -24,7 +24,12 @@ module Spec
24
24
  end
25
25
 
26
26
  it "should produce standard summary" do
27
- @formatter.example_pending("example_group", ExampleGroup.new("example"), "message")
27
+ example_group = ExampleGroup.describe("example_group") do
28
+ specify "example" do
29
+ end
30
+ end
31
+ example = example_group.examples.first
32
+ @formatter.example_pending(example, "message")
28
33
  @io.rewind
29
34
  @formatter.dump_summary(3, 2, 1, 1)
30
35
  @io.string.should eql(%Q|
@@ -84,7 +89,12 @@ EOE
84
89
  end
85
90
 
86
91
  it "should dump pending" do
87
- @formatter.example_pending("example_group", ExampleGroup.new("example"), "message")
92
+ example_group = ExampleGroup.describe("example_group") do
93
+ specify "example" do
94
+ end
95
+ end
96
+ example = example_group.examples.first
97
+ @formatter.example_pending(example, "message")
88
98
  @formatter.dump_pending
89
99
  @io.string.should =~ /Pending\:\nexample_group example \(message\)\n/
90
100
  end
@@ -50,10 +50,10 @@ module Spec
50
50
  # Spec::Runner::CommandLine.run(
51
51
  # ::Spec::Runner::OptionParser.parse(args, err, out)
52
52
  # )
53
- #
53
+ #
54
54
  # seconds = /\d+\.\d+ seconds/
55
55
  # html = out.string.gsub seconds, 'x seconds'
56
- #
56
+ #
57
57
  # File.open(expected_file, 'w') {|io| io.write(html)}
58
58
  # end
59
59
  # end
@@ -12,71 +12,137 @@ module Spec
12
12
  options.stub!(:dry_run).and_return(false)
13
13
  options.stub!(:colour).and_return(false)
14
14
  @formatter = SpecdocFormatter.new(options, io)
15
- @example_group = Class.new(::Spec::Example::ExampleGroup).describe("ExampleGroup")
15
+ @example_group = ::Spec::Example::ExampleGroup.describe("ExampleGroup") do
16
+ specify "example" do
17
+ end
18
+ end
16
19
  end
17
20
 
18
21
  describe "where ExampleGroup has no superclasss with a description" do
19
22
  before do
20
- formatter.add_example_group(example_group)
23
+ add_example_group
21
24
  end
22
25
 
23
- it "should produce standard summary without pending when pending has a 0 count" do
24
- formatter.dump_summary(3, 2, 1, 0)
25
- io.string.should have_example_group_output("\nFinished in 3 seconds\n\n2 examples, 1 failure\n")
26
+ def add_example_group
27
+ formatter.add_example_group(example_group)
26
28
  end
27
29
 
28
- it "should produce standard summary" do
29
- formatter.dump_summary(3, 2, 1, 4)
30
- io.string.should have_example_group_output("\nFinished in 3 seconds\n\n2 examples, 1 failure, 4 pending\n")
31
- end
30
+ describe "#dump_summary" do
31
+ it "should produce standard summary without pending when pending has a 0 count" do
32
+ formatter.dump_summary(3, 2, 1, 0)
33
+ io.string.should have_example_group_output("\nFinished in 3 seconds\n\n2 examples, 1 failure\n")
34
+ end
32
35
 
33
- it "should push ExampleGroup name" do
34
- io.string.should eql("\nExampleGroup\n")
36
+ it "should produce standard summary" do
37
+ formatter.dump_summary(3, 2, 1, 4)
38
+ io.string.should have_example_group_output("\nFinished in 3 seconds\n\n2 examples, 1 failure, 4 pending\n")
39
+ end
35
40
  end
36
41
 
37
- it "when having an error, should push failing spec name and failure number" do
38
- formatter.example_failed(
39
- example_group.it("spec"),
40
- 98,
41
- Reporter::Failure.new("c s", RuntimeError.new)
42
- )
43
- io.string.should have_example_group_output("- spec (ERROR - 98)\n")
42
+ describe "#add_example_group" do
43
+ it "should push ExampleGroup name" do
44
+ io.string.should eql("\nExampleGroup\n")
45
+ end
44
46
  end
45
47
 
46
- it "when having an expectation failure, should push failing spec name and failure number" do
47
- formatter.example_failed(
48
- example_group.it("spec"),
49
- 98,
50
- Reporter::Failure.new("c s", Spec::Expectations::ExpectationNotMetError.new)
51
- )
52
- io.string.should have_example_group_output("- spec (FAILED - 98)\n")
53
- end
48
+ describe "#example_failed" do
49
+ describe "where ExampleGroup has no superclasss with a description" do
50
+ describe "when having an error" do
51
+ it "should push failing spec name and failure number" do
52
+ formatter.example_failed(
53
+ example_group.it("spec"),
54
+ 98,
55
+ Reporter::Failure.new("c s", RuntimeError.new)
56
+ )
57
+ io.string.should have_example_group_output("- spec (ERROR - 98)\n")
58
+ end
59
+ end
60
+
61
+ describe "when having an expectation failure" do
62
+ it "should push failing spec name and failure number" do
63
+ formatter.example_failed(
64
+ example_group.it("spec"),
65
+ 98,
66
+ Reporter::Failure.new("c s", Spec::Expectations::ExpectationNotMetError.new)
67
+ )
68
+ io.string.should have_example_group_output("- spec (FAILED - 98)\n")
69
+ end
70
+ end
71
+ end
54
72
 
55
- it "should push nothing on start" do
56
- formatter.start(5)
57
- io.string.should have_example_group_output("")
73
+ describe "where ExampleGroup has two superclasses with a description" do
74
+ attr_reader :child_example_group, :grand_child_example_group
75
+
76
+ def add_example_group
77
+ @child_example_group = Class.new(example_group).describe("Child ExampleGroup")
78
+ @grand_child_example_group = Class.new(child_example_group).describe("GrandChild ExampleGroup")
79
+ formatter.add_example_group(grand_child_example_group)
80
+ end
81
+
82
+ describe "when having an error" do
83
+ it "should push failing spec name and failure number" do
84
+ formatter.example_failed(
85
+ example_group.it("spec"),
86
+ 98,
87
+ Reporter::Failure.new("c s", RuntimeError.new)
88
+ )
89
+ io.string.should have_nested_example_group_output("- spec (ERROR - 98)\n")
90
+ end
91
+ end
92
+
93
+ describe "when having an expectation" do
94
+ it "should push failing spec name and failure number" do
95
+ formatter.example_failed(
96
+ example_group.it("spec"),
97
+ 98,
98
+ Reporter::Failure.new("c s", Spec::Expectations::ExpectationNotMetError.new)
99
+ )
100
+ io.string.should have_nested_example_group_output("- spec (FAILED - 98)\n")
101
+ end
102
+ end
103
+
104
+ def have_nested_example_group_output(expected_output)
105
+ expected_full_output = "\nExampleGroup Child ExampleGroup GrandChild ExampleGroup\n#{expected_output}"
106
+ ::Spec::Matchers::SimpleMatcher.new(expected_full_output) do |actual|
107
+ actual == expected_full_output
108
+ end
109
+ end
110
+ end
58
111
  end
59
112
 
60
- it "should push nothing on start dump" do
61
- formatter.start_dump
62
- io.string.should have_example_group_output("")
113
+ describe "#start" do
114
+ it "should push nothing on start" do
115
+ formatter.start(5)
116
+ io.string.should have_example_group_output("")
117
+ end
63
118
  end
64
-
65
- it "should push passing spec name" do
66
- formatter.example_passed(example_group.it("spec"))
67
- io.string.should have_example_group_output("- spec\n")
119
+
120
+ describe "#start_dump" do
121
+ it "should push nothing on start dump" do
122
+ formatter.start_dump
123
+ io.string.should have_example_group_output("")
124
+ end
68
125
  end
69
126
 
70
- it "should push pending example name and message" do
71
- formatter.example_pending('example_group', ExampleGroup.new("example"), 'reason')
72
- io.string.should have_example_group_output("- example (PENDING: reason)\n")
127
+ describe "#example_passed" do
128
+ it "should push passing spec name" do
129
+ formatter.example_passed(example_group.it("spec"))
130
+ io.string.should have_example_group_output("- spec\n")
131
+ end
73
132
  end
74
133
 
75
- it "should dump pending" do
76
- formatter.example_pending('example_group', ExampleGroup.new("example"), 'reason')
77
- io.rewind
78
- formatter.dump_pending
79
- io.string.should =~ /Pending\:\nexample_group example \(reason\)\n/
134
+ describe "#example_pending" do
135
+ it "should push pending example name and message" do
136
+ formatter.example_pending(example_group.examples.first, 'reason')
137
+ io.string.should have_example_group_output("- example (PENDING: reason)\n")
138
+ end
139
+
140
+ it "should dump pending" do
141
+ formatter.example_pending(example_group.examples.first, 'reason')
142
+ io.rewind
143
+ formatter.dump_pending
144
+ io.string.should =~ /Pending\:\nExampleGroup example \(reason\)\n/
145
+ end
80
146
  end
81
147
 
82
148
  def have_example_group_output(expected_output)
@@ -86,40 +152,6 @@ module Spec
86
152
  end
87
153
  end
88
154
  end
89
-
90
- describe "where ExampleGroup has two superclasses with a description" do
91
- attr_reader :child_example_group, :grand_child_example_group
92
- before do
93
- @child_example_group = Class.new(example_group).describe("Child ExampleGroup")
94
- @grand_child_example_group = Class.new(child_example_group).describe("GrandChild ExampleGroup")
95
- formatter.add_example_group(grand_child_example_group)
96
- end
97
-
98
- specify "when having an error, should push failing spec name and failure number" do
99
- formatter.example_failed(
100
- example_group.it("spec"),
101
- 98,
102
- Reporter::Failure.new("c s", RuntimeError.new)
103
- )
104
- io.string.should have_nested_example_group_output("- spec (ERROR - 98)\n")
105
- end
106
-
107
- specify "when having an expectation failure, should push failing spec name and failure number" do
108
- formatter.example_failed(
109
- example_group.it("spec"),
110
- 98,
111
- Reporter::Failure.new("c s", Spec::Expectations::ExpectationNotMetError.new)
112
- )
113
- io.string.should have_nested_example_group_output("- spec (FAILED - 98)\n")
114
- end
115
-
116
- def have_nested_example_group_output(expected_output)
117
- expected_full_output = "\nExampleGroup Child ExampleGroup GrandChild ExampleGroup\n#{expected_output}"
118
- ::Spec::Matchers::SimpleMatcher.new(expected_full_output) do |actual|
119
- actual == expected_full_output
120
- end
121
- end
122
- end
123
155
  end
124
156
  end
125
157
  end