dchelimsky-rspec 1.1.11.7 → 1.1.12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (79) hide show
  1. data/History.txt +1 -1
  2. data/features/support/helpers/story_helper.rb +0 -3
  3. data/lib/spec/example/example_group_methods.rb +1 -1
  4. data/lib/spec/matchers.rb +1 -1
  5. data/lib/spec/mocks.rb +3 -3
  6. data/lib/spec/mocks/argument_expectation.rb +14 -14
  7. data/lib/spec/mocks/framework.rb +1 -1
  8. data/lib/spec/mocks/message_expectation.rb +1 -1
  9. data/lib/spec/mocks/mock.rb +3 -4
  10. data/lib/spec/mocks/spec_methods.rb +10 -1
  11. data/lib/spec/version.rb +2 -2
  12. data/rspec.gemspec +3 -3
  13. data/spec/spec/mocks/hash_including_matcher_spec.rb +4 -4
  14. data/spec/spec/mocks/hash_not_including_matcher_spec.rb +3 -3
  15. data/spec/spec/mocks/mock_spec.rb +25 -0
  16. data/spec/spec/runner/reporter_spec.rb +1 -1
  17. data/spec/spec_helper.rb +0 -1
  18. metadata +3 -3
  19. data/lib/spec/mocks/argument_constraints.rb +0 -237
  20. data/lib/spec/runner/formatter/story/html_formatter.rb +0 -174
  21. data/lib/spec/runner/formatter/story/plain_text_formatter.rb +0 -194
  22. data/lib/spec/runner/formatter/story/progress_bar_formatter.rb +0 -42
  23. data/lib/spec/story.rb +0 -10
  24. data/lib/spec/story/extensions.rb +0 -3
  25. data/lib/spec/story/extensions/main.rb +0 -86
  26. data/lib/spec/story/extensions/regexp.rb +0 -9
  27. data/lib/spec/story/extensions/string.rb +0 -9
  28. data/lib/spec/story/given_scenario.rb +0 -14
  29. data/lib/spec/story/runner.rb +0 -57
  30. data/lib/spec/story/runner/plain_text_story_runner.rb +0 -48
  31. data/lib/spec/story/runner/scenario_collector.rb +0 -18
  32. data/lib/spec/story/runner/scenario_runner.rb +0 -54
  33. data/lib/spec/story/runner/story_mediator.rb +0 -137
  34. data/lib/spec/story/runner/story_parser.rb +0 -247
  35. data/lib/spec/story/runner/story_runner.rb +0 -74
  36. data/lib/spec/story/scenario.rb +0 -14
  37. data/lib/spec/story/step.rb +0 -70
  38. data/lib/spec/story/step_group.rb +0 -89
  39. data/lib/spec/story/step_mother.rb +0 -38
  40. data/lib/spec/story/story.rb +0 -39
  41. data/lib/spec/story/world.rb +0 -124
  42. data/spec/spec/matchers/mock_constraint_matchers_spec.rb +0 -24
  43. data/spec/spec/mocks/failing_mock_argument_constraints_spec.rb +0 -95
  44. data/spec/spec/mocks/passing_mock_argument_constraints_spec.rb +0 -145
  45. data/spec/spec/runner/formatter/story/html_formatter_spec.rb +0 -135
  46. data/spec/spec/runner/formatter/story/plain_text_formatter_spec.rb +0 -600
  47. data/spec/spec/runner/formatter/story/progress_bar_formatter_spec.rb +0 -82
  48. data/spec/spec/story/builders.rb +0 -46
  49. data/spec/spec/story/extensions/main_spec.rb +0 -161
  50. data/spec/spec/story/extensions_spec.rb +0 -14
  51. data/spec/spec/story/given_scenario_spec.rb +0 -27
  52. data/spec/spec/story/runner/plain_text_story_runner_spec.rb +0 -90
  53. data/spec/spec/story/runner/scenario_collector_spec.rb +0 -27
  54. data/spec/spec/story/runner/scenario_runner_spec.rb +0 -214
  55. data/spec/spec/story/runner/story_mediator_spec.rb +0 -143
  56. data/spec/spec/story/runner/story_parser_spec.rb +0 -401
  57. data/spec/spec/story/runner/story_runner_spec.rb +0 -294
  58. data/spec/spec/story/runner_spec.rb +0 -93
  59. data/spec/spec/story/scenario_spec.rb +0 -18
  60. data/spec/spec/story/step_group_spec.rb +0 -157
  61. data/spec/spec/story/step_mother_spec.rb +0 -84
  62. data/spec/spec/story/step_spec.rb +0 -272
  63. data/spec/spec/story/story_helper.rb +0 -2
  64. data/spec/spec/story/story_spec.rb +0 -84
  65. data/spec/spec/story/world_spec.rb +0 -423
  66. data/story_server/prototype/javascripts/builder.js +0 -136
  67. data/story_server/prototype/javascripts/controls.js +0 -972
  68. data/story_server/prototype/javascripts/dragdrop.js +0 -976
  69. data/story_server/prototype/javascripts/effects.js +0 -1117
  70. data/story_server/prototype/javascripts/prototype.js +0 -4140
  71. data/story_server/prototype/javascripts/rspec.js +0 -149
  72. data/story_server/prototype/javascripts/scriptaculous.js +0 -58
  73. data/story_server/prototype/javascripts/slider.js +0 -276
  74. data/story_server/prototype/javascripts/sound.js +0 -55
  75. data/story_server/prototype/javascripts/unittest.js +0 -568
  76. data/story_server/prototype/lib/server.rb +0 -24
  77. data/story_server/prototype/stories.html +0 -176
  78. data/story_server/prototype/stylesheets/rspec.css +0 -136
  79. data/story_server/prototype/stylesheets/test.css +0 -90
@@ -1,84 +0,0 @@
1
- require File.dirname(__FILE__) + '/story_helper'
2
-
3
- module Spec
4
- module Story
5
- describe StepMother do
6
- it 'should store a step by name and type' do
7
- # given
8
- step_mother = StepMother.new
9
- step = Step.new("a given", &lambda {})
10
- step_mother.store(:given, step)
11
-
12
- # when
13
- found = step_mother.find(:given, "a given")
14
-
15
- # then
16
- found.should == step
17
- end
18
-
19
- it 'should NOT raise an error if a step is missing' do
20
- # given
21
- step_mother = StepMother.new
22
-
23
- # then
24
- lambda do
25
- # when
26
- step_mother.find(:given, "doesn't exist")
27
- end.should_not raise_error
28
- end
29
-
30
- it "should create a default step which raises a pending error" do
31
- # given
32
- step_mother = StepMother.new
33
-
34
- # when
35
- step = step_mother.find(:given, "doesn't exist")
36
-
37
- # then
38
- step.should be_an_instance_of(Step)
39
-
40
- lambda do
41
- step.perform(Object.new, "doesn't exist")
42
- end.should raise_error(Spec::Example::ExamplePendingError, /Unimplemented/)
43
- end
44
-
45
- it "should create a default step with it's name stripped" do
46
- # given
47
- step_mother = StepMother.new
48
-
49
- # when
50
- step = step_mother.find(:given, "doesn't exist\n\n")
51
-
52
- # then
53
- step.should be_an_instance_of(Step)
54
- step.name.should == "doesn't exist"
55
- end
56
-
57
- it 'should clear itself' do
58
- # given
59
- step_mother = StepMother.new
60
- step = Step.new("a given") do end
61
- step_mother.store(:given, step)
62
-
63
- # when
64
- step_mother.clear
65
-
66
- # then
67
- step_mother.should be_empty
68
- end
69
-
70
- it "should use assigned steps" do
71
- step_mother = StepMother.new
72
-
73
- step = Step.new('step') {}
74
- step_group = StepGroup.new
75
- step_group.add(:given, step)
76
-
77
- step_mother.use(step_group)
78
-
79
- step_mother.find(:given, "step").should equal(step)
80
- end
81
-
82
- end
83
- end
84
- end
@@ -1,272 +0,0 @@
1
- require File.dirname(__FILE__) + '/story_helper'
2
-
3
- module Spec
4
- module Story
5
- describe Step, "#matching" do
6
- it "should match a text string" do
7
- step = Step.new("this text") {}
8
- step.matches?("this text").should be_true
9
- end
10
-
11
- it "should match a text string that has additional line returns" do
12
- step = Step.new("this text") {}
13
- step.matches?("this text\n\n").should be_true
14
- end
15
-
16
- it "should not match a text string that does not start the same" do
17
- step = Step.new("this text") {}
18
- step.matches?("Xthis text").should be_false
19
- end
20
-
21
- it "should not match a text string that does not end the same" do
22
- step = Step.new("this text") {}
23
- step.matches?("this textX").should be_false
24
- end
25
-
26
- it "should match a text string with a param" do
27
- step = Step.new("this $param text") {}
28
- step.matches?("this anything text").should be_true
29
- end
30
-
31
- it "should not be greedy" do
32
- step = Step.new("enter $value for $key") {}
33
- step.parse_args("enter 3 for keys for a piano").should == ['3','keys for a piano']
34
- end
35
-
36
- it "should match a text string with 3 params" do
37
- step = Step.new("1 $one 2 $two 3 $three 4") {}
38
- step.matches?("1 a 2 b 3 c 4").should be_true
39
- end
40
-
41
- it "should match a text string with two params sharing a prefix" do
42
- step = Step.new("I am cool $n times out of $n_total")
43
- step.matches?("I am cool 3 times out of 7").should be_true
44
- end
45
-
46
- it "should match a text string with a param at the beginning" do
47
- step = Step.new("$one 2 3") {}
48
- step.matches?("a 2 3").should be_true
49
- end
50
-
51
- it "should match a text string with a param at the end" do
52
- step = Step.new("1 2 $three") {}
53
- step.matches?("1 2 c").should be_true
54
- end
55
-
56
- it "should match a text string with a dollar sign ($)" do
57
- step = Step.new("show me the $$money") {}
58
- step.matches?("show me the $kwan").should be_true
59
- end
60
-
61
- it "should match a string with an escaped dollar sign" do
62
- step = Step.new("show me the \$money") {}
63
- step.matches?("show me the $kwan").should be_true
64
- end
65
-
66
- it "should not match a different string" do
67
- step = Step.new("this text") {}
68
- step.matches?("other text").should be_false
69
- end
70
-
71
- it "should match a regexp" do
72
- step = Step.new(/this text/) {}
73
- step.matches?("this text").should be_true
74
- end
75
-
76
- it "should match a regexp with a match group" do
77
- step = Step.new(/this (.*) text/) {}
78
- step.matches?("this anything text").should be_true
79
- end
80
-
81
- it "should match a regexp with a named variable" do
82
- step = Step.new(/this $variable text/) {}
83
- step.matches?("this anything text").should be_true
84
- end
85
-
86
- it "should not match a non matching regexp" do
87
- step = Step.new(/this (.*) text/) {}
88
- step.matches?("other anything text").should be_false
89
- end
90
-
91
- it "should not match a non matching regexp with a named variable" do
92
- step = Step.new(/this $variable text/) {}
93
- step.matches?("other anything text").should be_false
94
- end
95
-
96
- it "should not get bogged down by parens in strings" do
97
- step = Step.new("before () after") {}
98
- step.matches?("before () after").should be_true
99
- end
100
-
101
- it "should not get bogged down by regular expression special characters in strings" do
102
- step = Step.new("These characters should work ? ( ) [ ] { } ^ !") {}
103
- step.matches?("These characters should work ? ( ) [ ] { } ^ !").should be_true
104
- end
105
-
106
- it "should match any option of an alteration" do
107
- step = Step.new(/(he|she) is cool/) {}
108
- step.matches?("he is cool").should be_true
109
- step.matches?("she is cool").should be_true
110
- end
111
-
112
- it "should match alteration as well as a variable" do
113
- step = Step.new(/(he|she) is (.*)/) {}
114
- step.matches?("he is cool").should be_true
115
- step.parse_args("he is cool").should == ['he', 'cool']
116
- end
117
-
118
- it "should match alteration as well as a named variable" do
119
- step = Step.new(/(he|she) is $adjective/) {}
120
- step.matches?("he is cool").should be_true
121
- step.parse_args("he is cool").should == ['he', 'cool']
122
- end
123
-
124
- it "should match alteration as well as a anonymous and named variable" do
125
- step = Step.new(/(he|she) is (.*?) $adjective/) {}
126
- step.matches?("he is very cool").should be_true
127
- step.parse_args("he is very cool").should == ['he', 'very', 'cool']
128
- end
129
-
130
- it "should match a regex with a dollar sign ($)" do
131
- step = Step.new(/show me the \$\d+/) {}
132
- step.matches?("show me the $123").should be_true
133
- end
134
-
135
- it "should match a regex with a dollar sign and named variable" do
136
- step = Step.new(/show me the \$$money/) {}
137
- step.matches?("show me the $123").should be_true
138
- end
139
-
140
- it "should match a multiline regex" do
141
- step = Step.new(/.*should have text.$text/) {}
142
- step.matches?(<<TEXT).should be_true
143
- should have text
144
- this is the text
145
- and so is this
146
- TEXT
147
- end
148
-
149
- it "should match the beginning of the string, not the line" do
150
- step = Step.new(/should have text/) {}
151
- step.matches?(<<TEXT).should be_false
152
- whatever
153
- should have text
154
- TEXT
155
- end
156
-
157
- it "should match the end of the string, not the line" do
158
- step = Step.new(/should have text/) {}
159
- step.matches?(<<TEXT).should be_false
160
- should have text
161
- whatever
162
- TEXT
163
- end
164
- end
165
-
166
- describe Step, "#parse_args" do
167
- it "should return an empty array for a text string with no parameters" do
168
- step = Step.new("this text") {}
169
- step.parse_args("this text").should == []
170
- end
171
-
172
- it "should return an empty array for a text string with additional line returns and no parameters" do
173
- step = Step.new("this text") {}
174
- step.parse_args("this text\n\n").should == []
175
- end
176
- end
177
-
178
- describe Step do
179
- it "should be pending with no block" do
180
- step = Step.new("foo")
181
- lambda {
182
- step.perform(Object.new)
183
- }.should raise_error(Spec::Example::ExamplePendingError, "Not Yet Implemented")
184
- end
185
-
186
- it "should perform itself on an object" do
187
- # given
188
- $instance = nil
189
- step = Step.new 'step' do
190
- $instance = self
191
- end
192
- instance = Object.new
193
-
194
- # when
195
- step.perform(instance, "step")
196
-
197
- # then
198
- $instance.should == instance
199
- end
200
-
201
- it "should perform itself with one parameter with match expression" do
202
- # given
203
- $result = nil
204
- step = Step.new 'an account with $count dollars' do |count|
205
- $result = count
206
- end
207
- instance = Object.new
208
-
209
- # when
210
- args = step.parse_args("an account with 3 dollars")
211
- step.perform(instance, *args)
212
-
213
- # then
214
- $result.should == "3"
215
- end
216
-
217
- it "should perform itself with one parameter without a match expression" do
218
- # given
219
- $result = nil
220
- step = Step.new 'an account with a balance of' do |amount|
221
- $result = amount
222
- end
223
- instance = Object.new
224
-
225
- # when
226
- step.perform(instance, 20)
227
-
228
- # then
229
- $result.should == 20
230
- end
231
-
232
- it "should perform itself with 2 parameters" do
233
- # given
234
- $account_type = nil
235
- $amount = nil
236
- step = Step.new 'a $account_type account with $amount dollars' do |account_type, amount|
237
- $account_type = account_type
238
- $amount = amount
239
- end
240
- instance = Object.new
241
-
242
- # when
243
- args = step.parse_args("a savings account with 3 dollars")
244
- step.perform(instance, *args)
245
-
246
- # then
247
- $account_type.should == "savings"
248
- $amount.should == "3"
249
- end
250
-
251
- it "should perform itself when defined with a regexp with 2 parameters" do
252
- # given
253
- $pronoun = nil
254
- $adjective = nil
255
- step = Step.new /(he|she) is (.*)/ do |pronoun, adjective|
256
- $pronoun = pronoun
257
- $adjective = adjective
258
- end
259
- instance = Object.new
260
-
261
- # when
262
- args = step.parse_args("he is cool")
263
- step.perform(instance, *args)
264
-
265
- # then
266
- $pronoun.should == "he"
267
- $adjective.should == "cool"
268
- end
269
-
270
- end
271
- end
272
- end
@@ -1,2 +0,0 @@
1
- require File.dirname(__FILE__) + '/../../spec_helper'
2
- require File.dirname(__FILE__) + '/builders'
@@ -1,84 +0,0 @@
1
- require File.dirname(__FILE__) + '/story_helper'
2
-
3
- module Spec
4
- module Story
5
- describe Story do
6
- it 'should run itself in a given object' do
7
- # given
8
- $instance = nil
9
- story = Story.new 'title', 'narrative' do
10
- $instance = self
11
- end
12
- object = Object.new
13
-
14
- # when
15
- story.run_in(object)
16
-
17
- # then
18
- $instance.should be(object)
19
- end
20
-
21
- it 'should not raise an error if no block is supplied' do
22
- # when
23
- error = exception_from { Story.new 'title', 'narrative' }
24
-
25
- # then
26
- error.should be_nil
27
- end
28
-
29
- it "should raise an error when an error is raised running in another object" do
30
- #given
31
- story = Story.new 'title', 'narrative' do
32
- raise "this is raised in the story"
33
- end
34
- object = Object.new
35
-
36
- # when/then
37
- lambda do
38
- story.run_in(object)
39
- end.should raise_error
40
- end
41
-
42
- it "should use the steps it is told to using a StepGroup" do
43
- story = Story.new("title", "narrative", :steps_for => steps = StepGroup.new) do end
44
- assignee = mock("assignee")
45
- assignee.should_receive(:use).with(steps)
46
- story.assign_steps_to(assignee)
47
- end
48
-
49
- it "should use the steps it is told to using a key" do
50
- begin
51
- orig_rspec_story_steps = $rspec_story_steps
52
- $rspec_story_steps = StepGroupHash.new
53
- $rspec_story_steps[:foo] = steps = Object.new
54
-
55
- story = Story.new("title", "narrative", :steps_for => :foo) do end
56
- assignee = mock("assignee")
57
-
58
- assignee.should_receive(:use).with(steps)
59
- story.assign_steps_to(assignee)
60
- ensure
61
- $rspec_story_steps = orig_rspec_story_steps
62
- end
63
- end
64
-
65
- it "should use the steps it is told to using multiple keys" do
66
- begin
67
- orig_rspec_story_steps = $rspec_story_steps
68
- $rspec_story_steps = StepGroupHash.new
69
- $rspec_story_steps[:foo] = foo_steps = Object.new
70
- $rspec_story_steps[:bar] = bar_steps = Object.new
71
-
72
- story = Story.new("title", "narrative", :steps_for => [:foo, :bar]) do end
73
- assignee = mock("assignee")
74
-
75
- assignee.should_receive(:use).with(foo_steps)
76
- assignee.should_receive(:use).with(bar_steps)
77
- story.assign_steps_to(assignee)
78
- ensure
79
- $rspec_story_steps = orig_rspec_story_steps
80
- end
81
- end
82
- end
83
- end
84
- end
@@ -1,423 +0,0 @@
1
- require File.dirname(__FILE__) + '/story_helper'
2
-
3
- require 'spec/story'
4
-
5
- module Spec
6
- module Story
7
- describe World do
8
- before :each do
9
- World.listeners.clear
10
- end
11
-
12
- after :each do
13
- World.listeners.clear
14
- World.step_mother.clear
15
- end
16
-
17
- it 'should create an object that mixes in a World' do
18
- # when
19
- obj = World::create
20
-
21
- # then
22
- obj.should be_kind_of(World)
23
- end
24
-
25
- it 'should create a World from any object type' do
26
- # when
27
- obj = World::create String
28
-
29
- # then
30
- obj.should be_kind_of(String)
31
- obj.should be_kind_of(World)
32
- end
33
-
34
- it 'should pass arguments to #new when creating an object of a specified type that mixes in a world' do
35
- # given
36
- Thing = Struct.new(:name, :age)
37
-
38
- # when
39
- obj = World::create Thing, "David", "I'm not telling"
40
-
41
- # then
42
- obj.should be_an_instance_of(Thing)
43
- obj.name.should == "David"
44
- obj.age.should == "I'm not telling"
45
- obj.should be_kind_of(World)
46
- end
47
-
48
- def ensure_world_executes_step(&block)
49
- # given
50
- obj = World::create
51
- $step_ran = false
52
-
53
- # when
54
- obj.instance_eval(&block)
55
-
56
- # then
57
- $step_ran.should be_true
58
- end
59
-
60
- it 'should execute a Given, When or Then step' do
61
- ensure_world_executes_step do
62
- Given 'a given' do
63
- $step_ran = true
64
- end
65
- end
66
-
67
- ensure_world_executes_step do
68
- When 'an event' do
69
- $step_ran = true
70
- end
71
- end
72
-
73
- ensure_world_executes_step do
74
- Then 'an outcome' do
75
- $step_ran = true
76
- end
77
- end
78
- end
79
-
80
- it 'should interpret Given... And... as multiple givens' do
81
- # given
82
- world = World.create
83
- $steps = []
84
-
85
- # when
86
- world.instance_eval do
87
- Given 'step 1' do
88
- $steps << 1
89
- end
90
- And 'step 2' do
91
- $steps << 2
92
- end
93
- end
94
-
95
- # then
96
- $steps.should == [1,2]
97
- World.step_mother.find(:given, 'step 1').should_not be_nil
98
- World.step_mother.find(:given, 'step 2').should_not be_nil
99
- end
100
-
101
- it 'should interpret When... And... as multiple events' do
102
- # given
103
- world = World.create
104
- $steps = []
105
-
106
- # when
107
- world.instance_eval do
108
- When 'step 1' do
109
- $steps << 1
110
- end
111
- And 'step 2' do
112
- $steps << 2
113
- end
114
- end
115
-
116
- # then
117
- $steps.should == [1,2]
118
- World.step_mother.find(:when, 'step 1').should_not be_nil
119
- World.step_mother.find(:when, 'step 2').should_not be_nil
120
- end
121
-
122
- it 'should interpret Then... And... as multiple outcomes' do
123
- # given
124
- world = World.create
125
- $steps = []
126
-
127
- # when
128
- world.instance_eval do
129
- Then 'step 1' do
130
- $steps << 1
131
- end
132
- And 'step 2' do
133
- $steps << 2
134
- end
135
- end
136
-
137
- # then
138
- $steps.should == [1,2]
139
- World.step_mother.find(:then, 'step 1').should_not be_nil
140
- World.step_mother.find(:then, 'step 2').should_not be_nil
141
- end
142
-
143
- it 'should reuse a given across scenarios' do
144
- # given
145
- $num_invoked = 0
146
- a_world = World::create
147
- a_world.instance_eval do
148
- Given 'a given' do
149
- $num_invoked += 1
150
- end
151
- end
152
- another_world = World::create
153
-
154
- # when
155
- another_world.instance_eval do
156
- Given 'a given' # without a body
157
- end
158
-
159
- # then
160
- $num_invoked.should == 2
161
- end
162
-
163
- it 'should reuse an event across scenarios' do
164
- # given
165
- $num_invoked = 0
166
- a_world = World::create
167
- a_world.instance_eval do
168
- When 'an event' do
169
- $num_invoked += 1
170
- end
171
- end
172
-
173
- another_world = World::create
174
-
175
- # when
176
- another_world.instance_eval do
177
- When 'an event' # without a body
178
- end
179
-
180
- # then
181
- $num_invoked.should == 2
182
- end
183
-
184
- it 'should reuse an outcome across scenarios' do
185
- # given
186
- $num_invoked = 0
187
- a_world = World::create
188
- a_world.instance_eval do
189
- Then 'an outcome' do
190
- $num_invoked += 1
191
- end
192
- end
193
-
194
- another_world = World::create
195
-
196
- # when
197
- another_world.instance_eval do
198
- Then 'an outcome' # without a body
199
- end
200
-
201
- # then
202
- $num_invoked.should == 2
203
- end
204
-
205
- it 'should preserve instance variables between steps within a scenario' do
206
- # given
207
- world = World::create
208
- $first = nil
209
- $second = nil
210
-
211
- # when
212
- world.instance_eval do
213
- Given 'given' do
214
- @first = 'first'
215
- end
216
- When 'event' do
217
- @second = @first # from given
218
- end
219
- Then 'outcome' do
220
- $first = @first # from given
221
- $second = @second # from event
222
- end
223
- end
224
-
225
- # then
226
- $first.should == 'first'
227
- $second.should == 'first'
228
- end
229
-
230
- it 'should invoke a reused step in the new object instance' do
231
- # given
232
- $instances = []
233
- $debug = true
234
- world1 = World.create
235
- world1.instance_eval do
236
- Given 'a given' do
237
- $instances << self.__id__
238
- end
239
- end
240
- world2 = World.create
241
-
242
- # when
243
- world2.instance_eval do
244
- Given 'a given' # reused
245
- Then 'an outcome' do
246
- $instances << __id__
247
- end
248
- end
249
- $debug = false
250
- # then
251
- $instances.should == [ world1.__id__, world2.__id__, world2.__id__ ]
252
- end
253
-
254
- def ensure_world_collects_error(expected_error, &block)
255
- # given
256
- world = World.create
257
- # $error = nil
258
-
259
- # when
260
- world.start_collecting_errors
261
- world.instance_eval(&block)
262
-
263
- # then
264
- world.should have(1).errors
265
- world.errors[0].should be_kind_of(expected_error)
266
- end
267
-
268
- it 'should collect a failure from a Given step' do
269
- ensure_world_collects_error RuntimeError do
270
- Given 'a given' do
271
- raise RuntimeError, "oops"
272
- end
273
- end
274
- end
275
-
276
- it 'should collect a failure from a When step' do
277
- ensure_world_collects_error RuntimeError do
278
- When 'an event' do
279
- raise RuntimeError, "oops"
280
- end
281
- end
282
- end
283
-
284
- it 'should collect a failure from a Then step' do
285
- ensure_world_collects_error RuntimeError do
286
- Then 'an outcome' do
287
- raise RuntimeError, "oops"
288
- end
289
- end
290
- end
291
-
292
- it 'should inform listeners when it runs a Given, When or Then step' do
293
- # given
294
- world = World.create
295
- mock_listener1 = mock('listener1')
296
- mock_listener2 = mock('listener2')
297
- World.add_listener(mock_listener1)
298
- World.add_listener(mock_listener2)
299
-
300
- # expect
301
- mock_listener1.should_receive(:step_upcoming).with(:given, 'a context')
302
- mock_listener1.should_receive(:step_succeeded).with(:given, 'a context')
303
- mock_listener1.should_receive(:step_upcoming).with(:when, 'an event')
304
- mock_listener1.should_receive(:step_succeeded).with(:when, 'an event')
305
- mock_listener1.should_receive(:step_upcoming).with(:then, 'an outcome')
306
- mock_listener1.should_receive(:step_succeeded).with(:then, 'an outcome')
307
-
308
- mock_listener2.should_receive(:step_upcoming).with(:given, 'a context')
309
- mock_listener2.should_receive(:step_succeeded).with(:given, 'a context')
310
- mock_listener2.should_receive(:step_upcoming).with(:when, 'an event')
311
- mock_listener2.should_receive(:step_succeeded).with(:when, 'an event')
312
- mock_listener2.should_receive(:step_upcoming).with(:then, 'an outcome')
313
- mock_listener2.should_receive(:step_succeeded).with(:then, 'an outcome')
314
-
315
- # when
316
- world.instance_eval do
317
- Given 'a context' do end
318
- When 'an event' do end
319
- Then 'an outcome' do end
320
- end
321
-
322
- # then
323
- end
324
-
325
- it 'should tell listeners but not execute the step in dry-run mode' do
326
- # given
327
- World.stub!(:dry_run).and_return(true)
328
- mock_listener = mock('listener')
329
- World.add_listener(mock_listener)
330
- $step_invoked = false
331
- world = World.create
332
-
333
- # expect
334
- mock_listener.should_receive(:step_upcoming).with(:given, 'a context')
335
- mock_listener.should_receive(:step_succeeded).with(:given, 'a context')
336
-
337
- # when
338
- world.instance_eval do
339
- Given 'a context' do
340
- $step_invoked = true
341
- end
342
- end
343
-
344
- # then
345
- $step_invoked.should be(false)
346
- end
347
-
348
- it 'should suppress listeners while it runs a GivenScenario' do
349
- # given
350
- scenario_ran = false
351
-
352
- scenario = ScenarioBuilder.new.name('a scenario').to_scenario do
353
- scenario_ran = true
354
- Given 'given' do end
355
- When 'event' do end
356
- Then 'outcome' do end
357
- end
358
-
359
- given_scenario = GivenScenario.new('a scenario')
360
- Runner::StoryRunner.should_receive(:scenario_from_current_story).
361
- with('a scenario').and_return(scenario)
362
-
363
- world = World.create
364
- listener = mock('listener')
365
- World.add_listener(listener)
366
-
367
- # expect
368
- listener.should_receive(:found_scenario).with(:'given scenario', 'a scenario')
369
- listener.should_receive(:step_succeeded).never.with(:given, 'given')
370
- listener.should_receive(:step_succeeded).never.with(:when, 'event')
371
- listener.should_receive(:step_succeeded).never.with(:then, 'outcome')
372
-
373
- # when
374
- world.GivenScenario 'a scenario'
375
-
376
- # then
377
- scenario_ran.should be_true
378
- end
379
-
380
- it 'should interpret GivenScenario... And... as multiple givens' do
381
- # given
382
- world = World.create
383
- steps = []
384
-
385
- scenario = ScenarioBuilder.new.name('a scenario').to_scenario do
386
- steps << 1
387
- end
388
- Runner::StoryRunner.should_receive(:scenario_from_current_story).
389
- with('a scenario').and_return(scenario)
390
-
391
- # when
392
- world.instance_eval do
393
- GivenScenario 'a scenario'
394
- And 'step 2' do
395
- steps << 2
396
- end
397
- end
398
-
399
- # then
400
- steps.should == [1,2]
401
- World.step_mother.find(:given, 'step 2').should_not be_nil
402
- end
403
-
404
- it 'should provide rspec matchers' do
405
- # given
406
- world = World.create
407
-
408
- # then
409
- world.instance_eval do
410
- 'hello'.should match(/^hello$/)
411
- end
412
- end
413
-
414
- it "should use assigned matchers" do
415
- world = World.create
416
-
417
- World.should_receive(:use).with(steps = Object.new)
418
-
419
- World.use(steps)
420
- end
421
- end
422
- end
423
- end