mocha 1.10.0 → 1.11.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/FUNDING.yml +1 -0
- data/.yardopts +1 -0
- data/RELEASE.md +49 -0
- data/Rakefile +1 -4
- data/docs/Mocha.html +2 -2
- data/docs/Mocha/API.html +167 -35
- data/docs/Mocha/ClassMethods.html +2 -2
- data/docs/Mocha/Configuration.html +197 -55
- data/docs/Mocha/Expectation.html +284 -76
- data/docs/Mocha/ExpectationError.html +2 -2
- data/docs/Mocha/ExpectationErrorFactory.html +2 -2
- data/docs/Mocha/Hooks.html +2 -2
- data/docs/Mocha/Integration.html +2 -2
- data/docs/Mocha/Integration/MiniTest.html +2 -2
- data/docs/Mocha/Integration/MiniTest/Adapter.html +2 -2
- data/docs/Mocha/Integration/TestUnit.html +2 -2
- data/docs/Mocha/Integration/TestUnit/Adapter.html +2 -2
- data/docs/Mocha/Mock.html +14 -41
- data/docs/Mocha/ObjectMethods.html +2 -2
- data/docs/Mocha/ParameterMatchers.html +14 -26
- data/docs/Mocha/ParameterMatchers/AllOf.html +2 -2
- data/docs/Mocha/ParameterMatchers/AnyOf.html +2 -2
- data/docs/Mocha/ParameterMatchers/AnyParameters.html +2 -2
- data/docs/Mocha/ParameterMatchers/Anything.html +2 -2
- data/docs/Mocha/ParameterMatchers/Base.html +2 -2
- data/docs/Mocha/ParameterMatchers/Equals.html +2 -2
- data/docs/Mocha/ParameterMatchers/EquivalentUri.html +2 -2
- data/docs/Mocha/ParameterMatchers/HasEntries.html +2 -2
- data/docs/Mocha/ParameterMatchers/HasEntry.html +2 -2
- data/docs/Mocha/ParameterMatchers/HasKey.html +2 -2
- data/docs/Mocha/ParameterMatchers/HasValue.html +2 -2
- data/docs/Mocha/ParameterMatchers/Includes.html +2 -2
- data/docs/Mocha/ParameterMatchers/InstanceOf.html +2 -2
- data/docs/Mocha/ParameterMatchers/IsA.html +2 -2
- data/docs/Mocha/ParameterMatchers/KindOf.html +2 -2
- data/docs/Mocha/ParameterMatchers/Not.html +2 -2
- data/docs/Mocha/ParameterMatchers/Optionally.html +2 -2
- data/docs/Mocha/ParameterMatchers/RegexpMatches.html +2 -2
- data/docs/Mocha/ParameterMatchers/RespondsWith.html +2 -2
- data/docs/Mocha/ParameterMatchers/YamlEquivalent.html +2 -2
- data/docs/Mocha/Sequence.html +2 -2
- data/docs/Mocha/StateMachine.html +5 -5
- data/docs/Mocha/StateMachine/State.html +2 -2
- data/docs/Mocha/StateMachine/StatePredicate.html +2 -2
- data/docs/Mocha/StubbingError.html +2 -2
- data/docs/_index.html +3 -3
- data/docs/file.COPYING.html +2 -2
- data/docs/file.MIT-LICENSE.html +2 -2
- data/docs/file.README.html +2 -2
- data/docs/file.RELEASE.html +74 -2
- data/docs/frames.html +1 -1
- data/docs/index.html +2 -2
- data/docs/method_list.html +51 -27
- data/docs/top-level-namespace.html +2 -2
- data/lib/mocha/api.rb +83 -19
- data/lib/mocha/block_matcher.rb +31 -0
- data/lib/mocha/configuration.rb +57 -1
- data/lib/mocha/deprecation.rb +2 -1
- data/lib/mocha/expectation.rb +48 -7
- data/lib/mocha/invocation.rb +20 -4
- data/lib/mocha/mock.rb +42 -16
- data/lib/mocha/mockery.rb +14 -14
- data/lib/mocha/parameter_matchers/has_entries.rb +2 -3
- data/lib/mocha/parameter_matchers/has_entry.rb +2 -3
- data/lib/mocha/parameter_matchers/has_key.rb +2 -3
- data/lib/mocha/parameter_matchers/has_value.rb +2 -3
- data/lib/mocha/parameter_matchers/is_a.rb +2 -3
- data/lib/mocha/parameter_matchers/not.rb +2 -3
- data/lib/mocha/state_machine.rb +2 -3
- data/lib/mocha/stubbed_method.rb +4 -6
- data/lib/mocha/version.rb +1 -1
- data/lib/mocha/yield_parameters.rb +5 -11
- data/test/acceptance/acceptance_test_helper.rb +1 -0
- data/test/acceptance/display_matching_invocations_alongside_expectations_test.rb +5 -5
- data/test/acceptance/failure_messages_test.rb +16 -0
- data/test/acceptance/issue_457_test.rb +31 -0
- data/test/acceptance/mocha_example_test.rb +11 -1
- data/test/acceptance/mock_built_with_first_argument_type_being_string_test.rb +98 -0
- data/test/acceptance/mock_test.rb +64 -12
- data/test/acceptance/multiple_yielding_test.rb +59 -0
- data/test/acceptance/stubba_example_test.rb +11 -1
- data/test/acceptance/stubbing_non_existent_any_instance_method_test.rb +16 -0
- data/test/acceptance/yielding_test.rb +80 -0
- data/test/unit/expectation_test.rb +30 -3
- data/test/unit/yield_parameters_test.rb +35 -53
- metadata +8 -9
- data/lib/mocha/multiple_yields.rb +0 -15
- data/lib/mocha/no_yields.rb +0 -5
- data/lib/mocha/pretty_parameters.rb +0 -24
- data/lib/mocha/single_yield.rb +0 -13
- data/test/unit/multiple_yields_test.rb +0 -16
- data/test/unit/no_yields_test.rb +0 -16
- data/test/unit/single_yield_test.rb +0 -16
@@ -20,11 +20,10 @@ module Mocha
|
|
20
20
|
# object.expects(:method_1).with(has_key('key_1'))
|
21
21
|
# object.method_1('key_2' => 2)
|
22
22
|
# # error raised, because method_1 was not called with Hash containing key: 'key_1'
|
23
|
-
#
|
24
|
-
def has_key(key)
|
23
|
+
#
|
24
|
+
def has_key(key) # rubocop:disable Naming/PredicateName
|
25
25
|
HasKey.new(key)
|
26
26
|
end
|
27
|
-
# rubocop:enable Naming/PredicateName
|
28
27
|
|
29
28
|
# Parameter matcher which matches when actual parameter contains +Hash+ entry with expected key.
|
30
29
|
class HasKey < Base
|
@@ -20,11 +20,10 @@ module Mocha
|
|
20
20
|
# object.expects(:method_1).with(has_value(1))
|
21
21
|
# object.method_1('key_2' => 2)
|
22
22
|
# # error raised, because method_1 was not called with Hash containing value: 1
|
23
|
-
#
|
24
|
-
def has_value(value)
|
23
|
+
#
|
24
|
+
def has_value(value) # rubocop:disable Naming/PredicateName
|
25
25
|
HasValue.new(value)
|
26
26
|
end
|
27
|
-
# rubocop:enable Naming/PredicateName
|
28
27
|
|
29
28
|
# Parameter matcher which matches when actual parameter contains +Hash+ entry with expected value.
|
30
29
|
class HasValue < Base
|
@@ -21,11 +21,10 @@ module Mocha
|
|
21
21
|
# object.expects(:method_1).with(is_a(Integer))
|
22
22
|
# object.method_1('string')
|
23
23
|
# # error raised, because method_1 was not called with an Integer
|
24
|
-
#
|
25
|
-
def is_a(klass)
|
24
|
+
#
|
25
|
+
def is_a(klass) # rubocop:disable Naming/PredicateName
|
26
26
|
IsA.new(klass)
|
27
27
|
end
|
28
|
-
# rubocop:enable Naming/PredicateName
|
29
28
|
|
30
29
|
# Parameter matcher which matches when actual parameter is a specific class.
|
31
30
|
class IsA < Base
|
@@ -20,11 +20,10 @@ module Mocha
|
|
20
20
|
# object.expects(:method_1).with(Not(includes(1)))
|
21
21
|
# object.method_1([0, 1, 2, 3])
|
22
22
|
# # error raised, because method_1 was not called with object not including 1
|
23
|
-
#
|
24
|
-
def Not(matcher)
|
23
|
+
#
|
24
|
+
def Not(matcher) # rubocop:disable Naming/MethodName
|
25
25
|
Not.new(matcher)
|
26
26
|
end
|
27
|
-
# rubocop:enable Naming/MethodName
|
28
27
|
|
29
28
|
# Parameter matcher which inverts the logic of the specified matcher using a logical NOT operation.
|
30
29
|
class Not < Base
|
data/lib/mocha/state_machine.rb
CHANGED
@@ -84,11 +84,10 @@ module Mocha
|
|
84
84
|
end
|
85
85
|
|
86
86
|
# Provides a mechanism to determine whether the {StateMachine} is not in the state specified by +state_name+ at some point in the future.
|
87
|
-
#
|
88
|
-
def is_not(state_name)
|
87
|
+
#
|
88
|
+
def is_not(state_name) # rubocop:disable Naming/PredicateName
|
89
89
|
StatePredicate.new(self, state_name)
|
90
90
|
end
|
91
|
-
# rubocop:enable Naming/PredicateName
|
92
91
|
|
93
92
|
# @private
|
94
93
|
def mocha_inspect
|
data/lib/mocha/stubbed_method.rb
CHANGED
@@ -74,7 +74,7 @@ module Mocha
|
|
74
74
|
def restore_original_method
|
75
75
|
return if use_prepended_module_for_stub_method?
|
76
76
|
if stub_method_overwrites_original_method?
|
77
|
-
original_method_owner.send(:define_method, method_name, method_body(original_method))
|
77
|
+
original_method_owner.send(:define_method, method_name, method_body(@original_method))
|
78
78
|
end
|
79
79
|
retain_original_visibility(original_method_owner)
|
80
80
|
end
|
@@ -93,18 +93,16 @@ module Mocha
|
|
93
93
|
private
|
94
94
|
|
95
95
|
def retain_original_visibility(method_owner)
|
96
|
-
return unless original_visibility
|
97
|
-
Module.instance_method(original_visibility).bind(method_owner).call(method_name)
|
96
|
+
return unless @original_visibility
|
97
|
+
Module.instance_method(@original_visibility).bind(method_owner).call(method_name)
|
98
98
|
end
|
99
99
|
|
100
|
-
attr_reader :original_method, :original_visibility
|
101
|
-
|
102
100
|
def store_original_method_visibility
|
103
101
|
@original_visibility = original_method_owner.__method_visibility__(method_name)
|
104
102
|
end
|
105
103
|
|
106
104
|
def stub_method_overwrites_original_method?
|
107
|
-
original_method && original_method.owner == original_method_owner
|
105
|
+
@original_method && @original_method.owner == original_method_owner
|
108
106
|
end
|
109
107
|
|
110
108
|
def remove_original_method_from_stubbee
|
data/lib/mocha/version.rb
CHANGED
@@ -1,7 +1,3 @@
|
|
1
|
-
require 'mocha/no_yields'
|
2
|
-
require 'mocha/single_yield'
|
3
|
-
require 'mocha/multiple_yields'
|
4
|
-
|
5
1
|
module Mocha
|
6
2
|
class YieldParameters
|
7
3
|
def initialize
|
@@ -10,18 +6,16 @@ module Mocha
|
|
10
6
|
|
11
7
|
def next_invocation
|
12
8
|
case @parameter_groups.length
|
13
|
-
when 0 then
|
9
|
+
when 0 then []
|
14
10
|
when 1 then @parameter_groups.first
|
15
11
|
else @parameter_groups.shift
|
16
12
|
end
|
17
13
|
end
|
18
14
|
|
19
|
-
def add(*
|
20
|
-
@parameter_groups <<
|
21
|
-
|
22
|
-
|
23
|
-
def multiple_add(*parameter_groups)
|
24
|
-
@parameter_groups << MultipleYields.new(*parameter_groups)
|
15
|
+
def add(*parameter_groups)
|
16
|
+
@parameter_groups << parameter_groups.map do |pg|
|
17
|
+
pg.is_a?(Array) ? pg : [pg]
|
18
|
+
end
|
25
19
|
end
|
26
20
|
end
|
27
21
|
end
|
@@ -31,7 +31,7 @@ class DisplayMatchingInvocationsAlongsideExpectationsTest < Mocha::TestCase
|
|
31
31
|
test_result = run_as_test do
|
32
32
|
foo = mock('foo')
|
33
33
|
foo.expects(:bar).with(1).returns('a')
|
34
|
-
foo.stubs(:bar).with(any_parameters).multiple_yields(
|
34
|
+
foo.stubs(:bar).with(any_parameters).multiple_yields('bc', %w[d e]).returns('f').raises(StandardError).throws(:tag, 'value')
|
35
35
|
|
36
36
|
foo.bar(1, 2) { |_ignored| }
|
37
37
|
assert_raises(StandardError) { foo.bar(3, 4) { |_ignored| } }
|
@@ -40,9 +40,9 @@ class DisplayMatchingInvocationsAlongsideExpectationsTest < Mocha::TestCase
|
|
40
40
|
assert_invocations(
|
41
41
|
test_result,
|
42
42
|
'- allowed any number of times, invoked 3 times: #<Mock:foo>.bar(any_parameters)',
|
43
|
-
' - #<Mock:foo>.bar(1, 2) # => "f" after yielding ("
|
44
|
-
' - #<Mock:foo>.bar(3, 4) # => raised StandardError after yielding ("
|
45
|
-
' - #<Mock:foo>.bar(5, 6) # => threw (:tag, "value") after yielding ("
|
43
|
+
' - #<Mock:foo>.bar(1, 2) { ... } # => "f" after yielding ("bc"), then ("d", "e")',
|
44
|
+
' - #<Mock:foo>.bar(3, 4) { ... } # => raised StandardError after yielding ("bc"), then ("d", "e")',
|
45
|
+
' - #<Mock:foo>.bar(5, 6) { ... } # => threw (:tag, "value") after yielding ("bc"), then ("d", "e")'
|
46
46
|
)
|
47
47
|
end
|
48
48
|
|
@@ -57,7 +57,7 @@ class DisplayMatchingInvocationsAlongsideExpectationsTest < Mocha::TestCase
|
|
57
57
|
assert_invocations(
|
58
58
|
test_result,
|
59
59
|
'- allowed any number of times, invoked once: #<Mock:foo>.bar(any_parameters)',
|
60
|
-
' - #<Mock:foo>.bar(1, 2) # => nil after yielding ()'
|
60
|
+
' - #<Mock:foo>.bar(1, 2) { ... } # => nil after yielding ()'
|
61
61
|
)
|
62
62
|
end
|
63
63
|
|
@@ -58,4 +58,20 @@ class FailureMessagesTest < Mocha::TestCase
|
|
58
58
|
end
|
59
59
|
assert_match Regexp.new(%("Foo")), test_result.failures[0].message
|
60
60
|
end
|
61
|
+
|
62
|
+
def test_should_display_that_block_was_expected
|
63
|
+
test_result = run_as_test do
|
64
|
+
foo = mock
|
65
|
+
foo.expects(:bar).with_block_given
|
66
|
+
end
|
67
|
+
assert_match Regexp.new(' with block given$'), test_result.failures[0].message
|
68
|
+
end
|
69
|
+
|
70
|
+
def test_should_display_that_block_was_not_expected
|
71
|
+
test_result = run_as_test do
|
72
|
+
foo = mock
|
73
|
+
foo.expects(:bar).with_no_block_given
|
74
|
+
end
|
75
|
+
assert_match Regexp.new(' with no block given$'), test_result.failures[0].message
|
76
|
+
end
|
61
77
|
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
require File.expand_path('../acceptance_test_helper', __FILE__)
|
2
|
+
|
3
|
+
class Issue457Test < Mocha::TestCase
|
4
|
+
include AcceptanceTest
|
5
|
+
|
6
|
+
def setup
|
7
|
+
setup_acceptance_test
|
8
|
+
end
|
9
|
+
|
10
|
+
def teardown
|
11
|
+
teardown_acceptance_test
|
12
|
+
end
|
13
|
+
|
14
|
+
def test_only_inspect_objects_when_necessary
|
15
|
+
test_result = run_as_test do
|
16
|
+
klass = Class.new do
|
17
|
+
def message
|
18
|
+
raise 'Not inspectable in this state!'
|
19
|
+
end
|
20
|
+
|
21
|
+
def inspect
|
22
|
+
message
|
23
|
+
end
|
24
|
+
end
|
25
|
+
instance = klass.new
|
26
|
+
instance.stubs(:message).returns('message')
|
27
|
+
assert_equal 'message', instance.inspect
|
28
|
+
end
|
29
|
+
assert_passed(test_result)
|
30
|
+
end
|
31
|
+
end
|
@@ -1,6 +1,16 @@
|
|
1
|
-
require File.expand_path('
|
1
|
+
require File.expand_path('../acceptance_test_helper', __FILE__)
|
2
2
|
|
3
3
|
class MochaExampleTest < Mocha::TestCase
|
4
|
+
include AcceptanceTest
|
5
|
+
|
6
|
+
def setup
|
7
|
+
setup_acceptance_test
|
8
|
+
end
|
9
|
+
|
10
|
+
def teardown
|
11
|
+
teardown_acceptance_test
|
12
|
+
end
|
13
|
+
|
4
14
|
class Rover
|
5
15
|
def initialize(left_track, right_track, steps_per_metre, steps_per_degree)
|
6
16
|
@left_track = left_track
|
@@ -0,0 +1,98 @@
|
|
1
|
+
require File.expand_path('../acceptance_test_helper', __FILE__)
|
2
|
+
require 'deprecation_disabler'
|
3
|
+
|
4
|
+
class MockBuiltWithFirstArgumentTypeBeingStringTest < Mocha::TestCase
|
5
|
+
include AcceptanceTest
|
6
|
+
|
7
|
+
def setup
|
8
|
+
setup_acceptance_test
|
9
|
+
end
|
10
|
+
|
11
|
+
def teardown
|
12
|
+
teardown_acceptance_test
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_mock_built_with_single_symbol_argument_with_satisfied_expectation
|
16
|
+
test_result = run_as_test do
|
17
|
+
DeprecationDisabler.disable_deprecations do
|
18
|
+
m = mock(:my_method)
|
19
|
+
assert_nil m.my_method
|
20
|
+
end
|
21
|
+
expected_warning = 'Explicitly include `my_method` in Hash of expected methods vs return values, e.g. `mock(:my_method => nil)`.'
|
22
|
+
assert_equal expected_warning, Mocha::Deprecation.messages.last
|
23
|
+
end
|
24
|
+
assert_passed(test_result)
|
25
|
+
end
|
26
|
+
|
27
|
+
def test_mock_built_with_single_symbol_argument_with_unsatisfied_expectation
|
28
|
+
test_result = run_as_test do
|
29
|
+
DeprecationDisabler.disable_deprecations do
|
30
|
+
mock(:my_method)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
assert_failed(test_result)
|
34
|
+
assert(test_result.failure_message_lines.any? do |line|
|
35
|
+
line[/expected exactly once, invoked never\: #<Mock\:0x[0-9a-f]+>\.my_method\(any_parameters\)/]
|
36
|
+
end)
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_stub_built_with_single_symbol_argument
|
40
|
+
test_result = run_as_test do
|
41
|
+
DeprecationDisabler.disable_deprecations do
|
42
|
+
s = stub(:my_method)
|
43
|
+
assert_nil s.my_method
|
44
|
+
end
|
45
|
+
expected_warning = 'Explicitly include `my_method` in Hash of stubbed methods vs return values, e.g. `stub(:my_method => nil)`.'
|
46
|
+
assert_equal expected_warning, Mocha::Deprecation.messages.last
|
47
|
+
end
|
48
|
+
assert_passed(test_result)
|
49
|
+
end
|
50
|
+
|
51
|
+
def test_mock_built_with_first_argument_a_symbol_and_second_argument_a_hash
|
52
|
+
test_result = run_as_test do
|
53
|
+
DeprecationDisabler.disable_deprecations do
|
54
|
+
s = mock(:my_method, :another_method => 123)
|
55
|
+
assert_nil s.my_method
|
56
|
+
end
|
57
|
+
expected_warning = 'In this case the 2nd argument for `mock(:#my_method, ...)` is ignored, but in the future a Hash of expected methods vs return values will be respected.'
|
58
|
+
assert Mocha::Deprecation.messages.last(2).include?(expected_warning)
|
59
|
+
end
|
60
|
+
assert_passed(test_result)
|
61
|
+
end
|
62
|
+
|
63
|
+
def test_stub_built_with_first_argument_a_symbol_and_second_argument_a_hash
|
64
|
+
test_result = run_as_test do
|
65
|
+
DeprecationDisabler.disable_deprecations do
|
66
|
+
s = stub(:my_method, :another_method => 123)
|
67
|
+
assert_nil s.my_method
|
68
|
+
end
|
69
|
+
expected_warning = 'In this case the 2nd argument for `stub(:#my_method, ...)` is ignored, but in the future a Hash of stubbed methods vs return values will be respected.'
|
70
|
+
assert Mocha::Deprecation.messages.last(2).include?(expected_warning)
|
71
|
+
end
|
72
|
+
assert_passed(test_result)
|
73
|
+
end
|
74
|
+
|
75
|
+
def test_stub_everything_built_with_single_symbol_argument
|
76
|
+
test_result = run_as_test do
|
77
|
+
DeprecationDisabler.disable_deprecations do
|
78
|
+
s = stub_everything(:my_method)
|
79
|
+
assert_nil s.my_method
|
80
|
+
end
|
81
|
+
expected_warning = 'Explicitly include `my_method` in Hash of stubbed methods vs return values, e.g. `stub_everything(:my_method => nil)`.'
|
82
|
+
assert_equal expected_warning, Mocha::Deprecation.messages.last
|
83
|
+
end
|
84
|
+
assert_passed(test_result)
|
85
|
+
end
|
86
|
+
|
87
|
+
def test_stub_everything_built_with_first_argument_a_symbol_and_second_argument_a_hash
|
88
|
+
test_result = run_as_test do
|
89
|
+
DeprecationDisabler.disable_deprecations do
|
90
|
+
s = stub_everything(:my_method, :another_method => 123)
|
91
|
+
assert_nil s.my_method
|
92
|
+
end
|
93
|
+
expected_warning = 'In this case the 2nd argument for `stub_everything(:#my_method, ...)` is ignored, but in the future a Hash of stubbed methods vs return values will be respected.' # rubocop:disable Metrics/LineLength
|
94
|
+
assert Mocha::Deprecation.messages.last(2).include?(expected_warning)
|
95
|
+
end
|
96
|
+
assert_passed(test_result)
|
97
|
+
end
|
98
|
+
end
|
@@ -1,7 +1,11 @@
|
|
1
1
|
require File.expand_path('../acceptance_test_helper', __FILE__)
|
2
|
+
require 'mocha/configuration'
|
3
|
+
require 'mocha/deprecation'
|
4
|
+
require 'deprecation_disabler'
|
2
5
|
|
3
6
|
class MockTest < Mocha::TestCase
|
4
7
|
include AcceptanceTest
|
8
|
+
include Mocha
|
5
9
|
|
6
10
|
def setup
|
7
11
|
setup_acceptance_test
|
@@ -39,9 +43,13 @@ class MockTest < Mocha::TestCase
|
|
39
43
|
|
40
44
|
def test_should_build_symbol_named_mock_and_explicitly_add_an_expectation_which_is_satisfied
|
41
45
|
test_result = run_as_test do
|
42
|
-
|
43
|
-
|
44
|
-
|
46
|
+
Mocha::Configuration.override(:reinstate_undocumented_behaviour_from_v1_9 => false) do
|
47
|
+
DeprecationDisabler.disable_deprecations do
|
48
|
+
foo = mock(:foo)
|
49
|
+
foo.expects(:bar)
|
50
|
+
foo.bar
|
51
|
+
end
|
52
|
+
end
|
45
53
|
end
|
46
54
|
assert_passed(test_result)
|
47
55
|
end
|
@@ -56,8 +64,10 @@ class MockTest < Mocha::TestCase
|
|
56
64
|
|
57
65
|
def test_should_build_symbol_named_mock_and_explicitly_add_an_expectation_which_is_not_satisfied
|
58
66
|
test_result = run_as_test do
|
59
|
-
|
60
|
-
|
67
|
+
DeprecationDisabler.disable_deprecations do
|
68
|
+
foo = mock(:foo)
|
69
|
+
foo.expects(:bar)
|
70
|
+
end
|
61
71
|
end
|
62
72
|
assert_failed(test_result)
|
63
73
|
end
|
@@ -98,9 +108,13 @@ class MockTest < Mocha::TestCase
|
|
98
108
|
|
99
109
|
def test_should_build_symbol_named_mock_incorporating_two_expectations_which_are_satisifed
|
100
110
|
test_result = run_as_test do
|
101
|
-
|
102
|
-
|
103
|
-
|
111
|
+
Mocha::Configuration.override(:reinstate_undocumented_behaviour_from_v1_9 => false) do
|
112
|
+
DeprecationDisabler.disable_deprecations do
|
113
|
+
foo = mock(:foo, :bar => 'bar', :baz => 'baz')
|
114
|
+
foo.bar
|
115
|
+
foo.baz
|
116
|
+
end
|
117
|
+
end
|
104
118
|
end
|
105
119
|
assert_passed(test_result)
|
106
120
|
end
|
@@ -115,8 +129,10 @@ class MockTest < Mocha::TestCase
|
|
115
129
|
|
116
130
|
def test_should_build_symbol_named_mock_incorporating_two_expectations_the_first_of_which_is_not_satisifed
|
117
131
|
test_result = run_as_test do
|
118
|
-
|
119
|
-
|
132
|
+
DeprecationDisabler.disable_deprecations do
|
133
|
+
foo = mock(:foo, :bar => 'bar', :baz => 'baz')
|
134
|
+
foo.baz
|
135
|
+
end
|
120
136
|
end
|
121
137
|
assert_failed(test_result)
|
122
138
|
end
|
@@ -131,9 +147,45 @@ class MockTest < Mocha::TestCase
|
|
131
147
|
|
132
148
|
def test_should_build_symbol_named_mock_incorporating_two_expectations_the_second_of_which_is_not_satisifed
|
133
149
|
test_result = run_as_test do
|
134
|
-
|
135
|
-
|
150
|
+
DeprecationDisabler.disable_deprecations do
|
151
|
+
foo = mock(:foo, :bar => 'bar', :baz => 'baz')
|
152
|
+
foo.bar
|
153
|
+
end
|
136
154
|
end
|
137
155
|
assert_failed(test_result)
|
138
156
|
end
|
157
|
+
|
158
|
+
class Foo
|
159
|
+
class << self
|
160
|
+
attr_accessor :logger
|
161
|
+
end
|
162
|
+
|
163
|
+
def use_the_mock
|
164
|
+
self.class.logger.log('Foo was here')
|
165
|
+
end
|
166
|
+
end
|
167
|
+
|
168
|
+
# rubocop:disable Metrics/AbcSize
|
169
|
+
def test_should_display_deprecation_warning_if_mock_receives_invocations_in_another_test
|
170
|
+
use_mock_test_result = run_as_test do
|
171
|
+
Foo.logger = mock('Logger')
|
172
|
+
Foo.logger.expects(:log).with('Foo was here')
|
173
|
+
Foo.new.use_the_mock
|
174
|
+
end
|
175
|
+
assert_passed(use_mock_test_result)
|
176
|
+
|
177
|
+
reuse_mock_test_result = run_as_test do
|
178
|
+
DeprecationDisabler.disable_deprecations do
|
179
|
+
Foo.logger.expects(:log).with('Foo was here')
|
180
|
+
Foo.new.use_the_mock
|
181
|
+
end
|
182
|
+
end
|
183
|
+
assert_passed(reuse_mock_test_result)
|
184
|
+
assert message = Deprecation.messages.last
|
185
|
+
assert message.include?('#<Mock:Logger> was instantiated in one test but it is receiving invocations within another test.')
|
186
|
+
assert message.include?('This can lead to unintended interactions between tests and hence unexpected test failures.')
|
187
|
+
assert message.include?('Ensure that every test correctly cleans up any state that it introduces.')
|
188
|
+
assert message.include?('A Mocha::StubbingError will be raised in this scenario in the future.')
|
189
|
+
end
|
190
|
+
# rubocop:enable Metrics/AbcSize
|
139
191
|
end
|