bourne 1.1.1 → 1.1.2
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +1 -1
- data/bourne.gemspec +1 -1
- data/lib/bourne/api.rb +15 -1
- data/lib/bourne/version.rb +1 -1
- data/test/acceptance/acceptance_test_helper.rb +9 -9
- data/test/acceptance/mocha_example_test.rb +26 -26
- data/test/acceptance/spy_test.rb +10 -4
- data/test/acceptance/stubba_example_test.rb +24 -24
- data/test/execution_point.rb +7 -7
- data/test/method_definer.rb +2 -2
- data/test/mini_test_result.rb +16 -16
- data/test/simple_counter.rb +5 -5
- data/test/test_runner.rb +3 -3
- data/test/unit/expectation_test.rb +65 -65
- data/test/unit/mock_test.rb +44 -44
- data/test/unit/mockery_test.rb +24 -24
- metadata +18 -19
- data/Gemfile.lock +0 -20
data/test/simple_counter.rb
CHANGED
data/test/test_runner.rb
CHANGED
@@ -13,7 +13,7 @@ module TestRunner
|
|
13
13
|
define_method(:test_me, &block)
|
14
14
|
end
|
15
15
|
test = test_class.new(:test_me)
|
16
|
-
|
16
|
+
|
17
17
|
if defined?(Test::Unit::TestResult)
|
18
18
|
test_result ||= Test::Unit::TestResult.new
|
19
19
|
test.run(test_result) {}
|
@@ -34,10 +34,10 @@ module TestRunner
|
|
34
34
|
test.run(runner)
|
35
35
|
test_result = MiniTestResult.new(runner, test)
|
36
36
|
end
|
37
|
-
|
37
|
+
|
38
38
|
test_result
|
39
39
|
end
|
40
|
-
|
40
|
+
|
41
41
|
def assert_passed(test_result)
|
42
42
|
flunk "Test failed unexpectedly with message: #{test_result.failures}" if test_result.failure_count > 0
|
43
43
|
flunk "Test failed unexpectedly with message: #{test_result.errors}" if test_result.error_count > 0
|
@@ -7,7 +7,7 @@ require 'execution_point'
|
|
7
7
|
require 'simple_counter'
|
8
8
|
|
9
9
|
class ExpectationTest < Test::Unit::TestCase
|
10
|
-
|
10
|
+
|
11
11
|
include Mocha
|
12
12
|
|
13
13
|
class FakeMockery
|
@@ -36,67 +36,67 @@ class ExpectationTest < Test::Unit::TestCase
|
|
36
36
|
def new_expectation
|
37
37
|
Expectation.new(nil, :expected_method)
|
38
38
|
end
|
39
|
-
|
39
|
+
|
40
40
|
def test_should_match_calls_to_same_method_with_any_parameters
|
41
41
|
assert new_expectation.match?(:expected_method, 1, 2, 3)
|
42
42
|
end
|
43
|
-
|
43
|
+
|
44
44
|
def test_should_match_calls_to_same_method_with_exactly_zero_parameters
|
45
45
|
expectation = new_expectation.with()
|
46
46
|
assert expectation.match?(:expected_method)
|
47
47
|
end
|
48
|
-
|
48
|
+
|
49
49
|
def test_should_not_match_calls_to_same_method_with_more_than_zero_parameters
|
50
50
|
expectation = new_expectation.with()
|
51
51
|
assert !expectation.match?(:expected_method, 1, 2, 3)
|
52
52
|
end
|
53
|
-
|
53
|
+
|
54
54
|
def test_should_match_calls_to_same_method_with_expected_parameter_values
|
55
55
|
expectation = new_expectation.with(1, 2, 3)
|
56
56
|
assert expectation.match?(:expected_method, 1, 2, 3)
|
57
57
|
end
|
58
|
-
|
58
|
+
|
59
59
|
def test_should_match_calls_to_same_method_with_parameters_constrained_as_expected
|
60
60
|
expectation = new_expectation.with() {|x, y, z| x + y == z}
|
61
61
|
assert expectation.match?(:expected_method, 1, 2, 3)
|
62
62
|
end
|
63
|
-
|
63
|
+
|
64
64
|
def test_should_not_match_calls_to_different_method_with_parameters_constrained_as_expected
|
65
65
|
expectation = new_expectation.with() {|x, y, z| x + y == z}
|
66
66
|
assert !expectation.match?(:different_method, 1, 2, 3)
|
67
67
|
end
|
68
|
-
|
68
|
+
|
69
69
|
def test_should_not_match_calls_to_different_methods_with_no_parameters
|
70
70
|
assert !new_expectation.match?(:unexpected_method)
|
71
71
|
end
|
72
|
-
|
72
|
+
|
73
73
|
def test_should_not_match_calls_to_same_method_with_too_few_parameters
|
74
74
|
expectation = new_expectation.with(1, 2, 3)
|
75
75
|
assert !expectation.match?(:unexpected_method, 1, 2)
|
76
76
|
end
|
77
|
-
|
77
|
+
|
78
78
|
def test_should_not_match_calls_to_same_method_with_too_many_parameters
|
79
79
|
expectation = new_expectation.with(1, 2)
|
80
80
|
assert !expectation.match?(:unexpected_method, 1, 2, 3)
|
81
81
|
end
|
82
|
-
|
82
|
+
|
83
83
|
def test_should_not_match_calls_to_same_method_with_unexpected_parameter_values
|
84
84
|
expectation = new_expectation.with(1, 2, 3)
|
85
85
|
assert !expectation.match?(:unexpected_method, 1, 0, 3)
|
86
86
|
end
|
87
|
-
|
87
|
+
|
88
88
|
def test_should_not_match_calls_to_same_method_with_parameters_not_constrained_as_expected
|
89
89
|
expectation = new_expectation.with() {|x, y, z| x + y == z}
|
90
90
|
assert !expectation.match?(:expected_method, 1, 0, 3)
|
91
91
|
end
|
92
|
-
|
92
|
+
|
93
93
|
def test_should_allow_invocations_until_expected_invocation_count_is_one_and_actual_invocation_count_would_be_two
|
94
94
|
expectation = new_expectation.times(1)
|
95
95
|
assert expectation.invocations_allowed?
|
96
96
|
expectation.invoke([])
|
97
97
|
assert !expectation.invocations_allowed?
|
98
98
|
end
|
99
|
-
|
99
|
+
|
100
100
|
def test_should_allow_invocations_until_expected_invocation_count_is_two_and_actual_invocation_count_would_be_three
|
101
101
|
expectation = new_expectation.times(2)
|
102
102
|
assert expectation.invocations_allowed?
|
@@ -116,18 +116,18 @@ class ExpectationTest < Test::Unit::TestCase
|
|
116
116
|
expectation.invoke([])
|
117
117
|
assert !expectation.invocations_allowed?
|
118
118
|
end
|
119
|
-
|
119
|
+
|
120
120
|
def test_should_store_provided_backtrace
|
121
121
|
backtrace = Object.new
|
122
122
|
expectation = Expectation.new(nil, :expected_method, backtrace)
|
123
123
|
assert_equal backtrace, expectation.backtrace
|
124
124
|
end
|
125
|
-
|
125
|
+
|
126
126
|
def test_should_default_backtrace_to_caller
|
127
127
|
execution_point = ExecutionPoint.current; expectation = Expectation.new(nil, :expected_method)
|
128
128
|
assert_equal execution_point, ExecutionPoint.new(expectation.backtrace)
|
129
129
|
end
|
130
|
-
|
130
|
+
|
131
131
|
def test_should_not_yield
|
132
132
|
yielded = false
|
133
133
|
new_expectation.invoke([]) { yielded = true }
|
@@ -155,7 +155,7 @@ class ExpectationTest < Test::Unit::TestCase
|
|
155
155
|
expectation.invoke([]) { |*parameters| yielded_parameters << parameters }
|
156
156
|
assert_equal [[1, 2, 3], [4, 5]], yielded_parameters
|
157
157
|
end
|
158
|
-
|
158
|
+
|
159
159
|
def test_should_yield_multiple_times_for_single_invocation
|
160
160
|
expectation = new_expectation().multiple_yields([1, 2, 3], [4, 5])
|
161
161
|
yielded_parameters = []
|
@@ -175,20 +175,20 @@ class ExpectationTest < Test::Unit::TestCase
|
|
175
175
|
expectation = new_expectation.returns(99)
|
176
176
|
assert_equal 99, expectation.invoke([])
|
177
177
|
end
|
178
|
-
|
178
|
+
|
179
179
|
def test_should_return_same_specified_value_multiple_times
|
180
180
|
expectation = new_expectation.returns(99)
|
181
181
|
assert_equal 99, expectation.invoke([])
|
182
182
|
assert_equal 99, expectation.invoke([])
|
183
183
|
end
|
184
|
-
|
184
|
+
|
185
185
|
def test_should_return_specified_values_on_consecutive_calls
|
186
186
|
expectation = new_expectation.returns(99, 100, 101)
|
187
187
|
assert_equal 99, expectation.invoke([])
|
188
188
|
assert_equal 100, expectation.invoke([])
|
189
189
|
assert_equal 101, expectation.invoke([])
|
190
190
|
end
|
191
|
-
|
191
|
+
|
192
192
|
def test_should_return_specified_values_on_consecutive_calls_even_if_values_are_modified
|
193
193
|
values = [99, 100, 101]
|
194
194
|
expectation = new_expectation.returns(*values)
|
@@ -197,27 +197,27 @@ class ExpectationTest < Test::Unit::TestCase
|
|
197
197
|
assert_equal 100, expectation.invoke([])
|
198
198
|
assert_equal 101, expectation.invoke([])
|
199
199
|
end
|
200
|
-
|
200
|
+
|
201
201
|
def test_should_return_nil_by_default
|
202
202
|
assert_nil new_expectation.invoke([])
|
203
203
|
end
|
204
|
-
|
204
|
+
|
205
205
|
def test_should_return_nil_if_no_value_specified
|
206
206
|
expectation = new_expectation.returns()
|
207
207
|
assert_nil expectation.invoke([])
|
208
208
|
end
|
209
|
-
|
209
|
+
|
210
210
|
def test_should_raise_runtime_exception
|
211
211
|
expectation = new_expectation.raises
|
212
212
|
assert_raise(RuntimeError) { expectation.invoke([]) }
|
213
213
|
end
|
214
|
-
|
214
|
+
|
215
215
|
def test_should_raise_custom_exception
|
216
216
|
exception = Class.new(Exception)
|
217
217
|
expectation = new_expectation.raises(exception)
|
218
218
|
assert_raise(exception) { expectation.invoke([]) }
|
219
219
|
end
|
220
|
-
|
220
|
+
|
221
221
|
def test_should_raise_same_instance_of_custom_exception
|
222
222
|
exception_klass = Class.new(StandardError)
|
223
223
|
expected_exception = exception_klass.new
|
@@ -225,40 +225,40 @@ class ExpectationTest < Test::Unit::TestCase
|
|
225
225
|
actual_exception = assert_raise(exception_klass) { expectation.invoke([]) }
|
226
226
|
assert_same expected_exception, actual_exception
|
227
227
|
end
|
228
|
-
|
228
|
+
|
229
229
|
def test_should_use_the_default_exception_message
|
230
230
|
expectation = new_expectation.raises(Exception)
|
231
231
|
exception = assert_raise(Exception) { expectation.invoke([]) }
|
232
232
|
assert_equal Exception.new.message, exception.message
|
233
233
|
end
|
234
|
-
|
234
|
+
|
235
235
|
def test_should_raise_custom_exception_with_message
|
236
236
|
exception_msg = "exception message"
|
237
237
|
expectation = new_expectation.raises(Exception, exception_msg)
|
238
238
|
exception = assert_raise(Exception) { expectation.invoke([]) }
|
239
239
|
assert_equal exception_msg, exception.message
|
240
240
|
end
|
241
|
-
|
241
|
+
|
242
242
|
def test_should_return_values_then_raise_exception
|
243
243
|
expectation = new_expectation.returns(1, 2).then.raises()
|
244
244
|
assert_equal 1, expectation.invoke([])
|
245
245
|
assert_equal 2, expectation.invoke([])
|
246
246
|
assert_raise(RuntimeError) { expectation.invoke([]) }
|
247
247
|
end
|
248
|
-
|
248
|
+
|
249
249
|
def test_should_raise_exception_then_return_values
|
250
250
|
expectation = new_expectation.raises().then.returns(1, 2)
|
251
251
|
assert_raise(RuntimeError) { expectation.invoke([]) }
|
252
252
|
assert_equal 1, expectation.invoke([])
|
253
253
|
assert_equal 2, expectation.invoke([])
|
254
254
|
end
|
255
|
-
|
255
|
+
|
256
256
|
def test_should_verify_successfully_if_expected_call_was_made
|
257
257
|
expectation = new_expectation
|
258
258
|
expectation.invoke([])
|
259
259
|
assert expectation.verified?
|
260
260
|
end
|
261
|
-
|
261
|
+
|
262
262
|
def test_should_not_verify_successfully_if_call_expected_once_but_invoked_twice
|
263
263
|
expectation = new_expectation.once
|
264
264
|
expectation.invoke([])
|
@@ -303,19 +303,19 @@ class ExpectationTest < Test::Unit::TestCase
|
|
303
303
|
3.times {expectation.invoke([])}
|
304
304
|
assert expectation.verified?
|
305
305
|
end
|
306
|
-
|
306
|
+
|
307
307
|
def test_should_not_verify_successfully_if_expected_call_was_not_made_at_least_once
|
308
308
|
expectation = new_expectation.with(1, 2, 3).at_least_once
|
309
309
|
assert !expectation.verified?
|
310
310
|
assert_match(/expected at least once, not yet invoked/i, expectation.mocha_inspect)
|
311
311
|
end
|
312
|
-
|
312
|
+
|
313
313
|
def test_should_verify_successfully_if_expected_call_was_made_expected_number_of_times
|
314
314
|
expectation = new_expectation.times(2)
|
315
315
|
2.times {expectation.invoke([])}
|
316
316
|
assert expectation.verified?
|
317
317
|
end
|
318
|
-
|
318
|
+
|
319
319
|
def test_should_not_verify_successfully_if_expected_call_was_made_too_few_times
|
320
320
|
expectation = new_expectation.times(2)
|
321
321
|
1.times {expectation.invoke([])}
|
@@ -323,13 +323,13 @@ class ExpectationTest < Test::Unit::TestCase
|
|
323
323
|
assert_match(/expected exactly twice/i, expectation.mocha_inspect)
|
324
324
|
assert_match(/invoked once/i, expectation.mocha_inspect)
|
325
325
|
end
|
326
|
-
|
326
|
+
|
327
327
|
def test_should_not_verify_successfully_if_expected_call_was_made_too_many_times
|
328
328
|
expectation = new_expectation.times(2)
|
329
329
|
3.times {expectation.invoke([])}
|
330
330
|
assert !expectation.verified?
|
331
331
|
end
|
332
|
-
|
332
|
+
|
333
333
|
def test_should_increment_assertion_counter_for_expectation_because_it_does_need_verifyng
|
334
334
|
expectation = new_expectation
|
335
335
|
expectation.invoke([])
|
@@ -337,21 +337,21 @@ class ExpectationTest < Test::Unit::TestCase
|
|
337
337
|
expectation.verified?(assertion_counter)
|
338
338
|
assert_equal 1, assertion_counter.count
|
339
339
|
end
|
340
|
-
|
340
|
+
|
341
341
|
def test_should_not_increment_assertion_counter_for_stub_because_it_does_not_need_verifying
|
342
342
|
stub = Expectation.new(nil, :expected_method).at_least(0)
|
343
343
|
assertion_counter = SimpleCounter.new
|
344
344
|
stub.verified?(assertion_counter)
|
345
345
|
assert_equal 0, assertion_counter.count
|
346
346
|
end
|
347
|
-
|
347
|
+
|
348
348
|
def test_should_store_backtrace_from_point_where_expectation_was_created
|
349
349
|
execution_point = ExecutionPoint.current; expectation = Expectation.new(nil, :expected_method)
|
350
350
|
assert_equal execution_point, ExecutionPoint.new(expectation.backtrace)
|
351
351
|
end
|
352
|
-
|
352
|
+
|
353
353
|
class FakeMock
|
354
|
-
|
354
|
+
|
355
355
|
def initialize(name)
|
356
356
|
@name = name
|
357
357
|
end
|
@@ -359,9 +359,9 @@ class ExpectationTest < Test::Unit::TestCase
|
|
359
359
|
def mocha_inspect
|
360
360
|
@name
|
361
361
|
end
|
362
|
-
|
362
|
+
|
363
363
|
end
|
364
|
-
|
364
|
+
|
365
365
|
def test_should_raise_error_with_message_indicating_which_method_was_expected_to_be_called_on_which_mock_object_with_which_parameters_and_in_what_sequences
|
366
366
|
mock = FakeMock.new('mock')
|
367
367
|
sequence_one = Sequence.new('one')
|
@@ -370,19 +370,19 @@ class ExpectationTest < Test::Unit::TestCase
|
|
370
370
|
assert !expectation.verified?
|
371
371
|
assert_match "mock.expected_method(1, 2, {'a' => true}, {:b => false}, [1, 2, 3]); in sequence 'one'; in sequence 'two'", expectation.mocha_inspect
|
372
372
|
end
|
373
|
-
|
373
|
+
|
374
374
|
class FakeConstraint
|
375
|
-
|
375
|
+
|
376
376
|
def initialize(allows_invocation_now)
|
377
377
|
@allows_invocation_now = allows_invocation_now
|
378
378
|
end
|
379
|
-
|
379
|
+
|
380
380
|
def allows_invocation_now?
|
381
381
|
@allows_invocation_now
|
382
382
|
end
|
383
|
-
|
383
|
+
|
384
384
|
end
|
385
|
-
|
385
|
+
|
386
386
|
def test_should_be_in_correct_order_if_all_ordering_constraints_allow_invocation_now
|
387
387
|
constraint_one = FakeConstraint.new(allows_invocation_now = true)
|
388
388
|
constraint_two = FakeConstraint.new(allows_invocation_now = true)
|
@@ -391,7 +391,7 @@ class ExpectationTest < Test::Unit::TestCase
|
|
391
391
|
expectation.add_ordering_constraint(constraint_two)
|
392
392
|
assert expectation.in_correct_order?
|
393
393
|
end
|
394
|
-
|
394
|
+
|
395
395
|
def test_should_not_be_in_correct_order_if_one_ordering_constraint_does_not_allow_invocation_now
|
396
396
|
constraint_one = FakeConstraint.new(allows_invocation_now = true)
|
397
397
|
constraint_two = FakeConstraint.new(allows_invocation_now = false)
|
@@ -400,7 +400,7 @@ class ExpectationTest < Test::Unit::TestCase
|
|
400
400
|
expectation.add_ordering_constraint(constraint_two)
|
401
401
|
assert !expectation.in_correct_order?
|
402
402
|
end
|
403
|
-
|
403
|
+
|
404
404
|
def test_should_match_if_all_ordering_constraints_allow_invocation_now
|
405
405
|
constraint_one = FakeConstraint.new(allows_invocation_now = true)
|
406
406
|
constraint_two = FakeConstraint.new(allows_invocation_now = true)
|
@@ -441,21 +441,21 @@ class ExpectationTest < Test::Unit::TestCase
|
|
441
441
|
2.times { expectation.invoke([]) }
|
442
442
|
assert expectation.satisfied?
|
443
443
|
end
|
444
|
-
|
444
|
+
|
445
445
|
class FakeSequence
|
446
|
-
|
446
|
+
|
447
447
|
attr_reader :expectations
|
448
|
-
|
448
|
+
|
449
449
|
def initialize
|
450
450
|
@expectations = []
|
451
451
|
end
|
452
|
-
|
452
|
+
|
453
453
|
def constrain_as_next_in_sequence(expectation)
|
454
454
|
@expectations << expectation
|
455
455
|
end
|
456
|
-
|
456
|
+
|
457
457
|
end
|
458
|
-
|
458
|
+
|
459
459
|
def test_should_tell_sequences_to_constrain_expectation_as_next_in_sequence
|
460
460
|
sequence_one = FakeSequence.new
|
461
461
|
sequence_two = FakeSequence.new
|
@@ -464,23 +464,23 @@ class ExpectationTest < Test::Unit::TestCase
|
|
464
464
|
assert_equal [expectation], sequence_one.expectations
|
465
465
|
assert_equal [expectation], sequence_two.expectations
|
466
466
|
end
|
467
|
-
|
467
|
+
|
468
468
|
class FakeState
|
469
|
-
|
469
|
+
|
470
470
|
def initialize
|
471
471
|
@active = false
|
472
472
|
end
|
473
|
-
|
473
|
+
|
474
474
|
def activate
|
475
475
|
@active = true
|
476
476
|
end
|
477
|
-
|
477
|
+
|
478
478
|
def active?
|
479
479
|
@active
|
480
480
|
end
|
481
|
-
|
481
|
+
|
482
482
|
end
|
483
|
-
|
483
|
+
|
484
484
|
def test_should_change_state_when_expectation_is_invoked
|
485
485
|
state = FakeState.new
|
486
486
|
expectation = Expectation.new(nil, :method_one)
|
@@ -490,14 +490,14 @@ class ExpectationTest < Test::Unit::TestCase
|
|
490
490
|
expectation.invoke([])
|
491
491
|
assert state.active?
|
492
492
|
end
|
493
|
-
|
493
|
+
|
494
494
|
def test_should_match_when_state_is_active
|
495
495
|
state = FakeState.new
|
496
496
|
expectation = Expectation.new(nil, :method_one)
|
497
497
|
|
498
498
|
expectation.when(state)
|
499
499
|
assert !expectation.match?(:method_one)
|
500
|
-
|
500
|
+
|
501
501
|
state.activate
|
502
502
|
assert expectation.match?(:method_one)
|
503
503
|
end
|
@@ -526,5 +526,5 @@ class ExpectationTest < Test::Unit::TestCase
|
|
526
526
|
expectation.invocation_count = 3
|
527
527
|
assert_equal 3, expectation.invocation_count
|
528
528
|
end
|
529
|
-
|
529
|
+
|
530
530
|
end
|