mocha 1.8.0 → 1.13.0
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/.rubocop.yml +3 -0
- data/.rubocop_todo.yml +7 -30
- data/.yardopts +1 -0
- data/CONTRIBUTING.md +1 -1
- data/README.md +56 -31
- data/RELEASE.md +166 -0
- data/Rakefile +15 -7
- data/init.rb +1 -3
- data/lib/mocha/any_instance_method.rb +11 -53
- data/lib/mocha/api.rb +119 -56
- data/lib/mocha/block_matcher.rb +31 -0
- data/lib/mocha/cardinality.rb +52 -34
- data/lib/mocha/class_methods.rb +17 -15
- data/lib/mocha/configuration.rb +351 -67
- data/lib/mocha/deprecation.rb +2 -1
- data/lib/mocha/detection/test_unit.rb +1 -3
- data/lib/mocha/exception_raiser.rb +2 -1
- data/lib/mocha/expectation.rb +120 -81
- data/lib/mocha/expectation_error.rb +1 -3
- data/lib/mocha/expectation_list.rb +6 -6
- data/lib/mocha/inspect.rb +30 -26
- data/lib/mocha/instance_method.rb +19 -2
- data/lib/mocha/integration/mini_test.rb +7 -0
- data/lib/mocha/integration/test_unit.rb +7 -0
- data/lib/mocha/integration.rb +1 -3
- data/lib/mocha/invocation.rb +77 -0
- data/lib/mocha/macos_version.rb +5 -0
- data/lib/mocha/minitest.rb +6 -1
- data/lib/mocha/mock.rb +80 -39
- data/lib/mocha/mockery.rb +34 -80
- data/lib/mocha/names.rb +1 -1
- data/lib/mocha/object_methods.rb +13 -19
- data/lib/mocha/parameter_matchers/all_of.rb +1 -1
- data/lib/mocha/parameter_matchers/any_of.rb +1 -1
- data/lib/mocha/parameter_matchers/equivalent_uri.rb +0 -9
- data/lib/mocha/parameter_matchers/has_entries.rb +2 -3
- data/lib/mocha/parameter_matchers/has_entry.rb +24 -16
- data/lib/mocha/parameter_matchers/has_key.rb +2 -3
- data/lib/mocha/parameter_matchers/has_keys.rb +53 -0
- data/lib/mocha/parameter_matchers/has_value.rb +2 -3
- data/lib/mocha/parameter_matchers/includes.rb +2 -0
- data/lib/mocha/parameter_matchers/instance_methods.rb +18 -0
- data/lib/mocha/parameter_matchers/is_a.rb +2 -3
- data/lib/mocha/parameter_matchers/not.rb +2 -3
- data/lib/mocha/parameter_matchers.rb +2 -1
- data/lib/mocha/raised_exception.rb +11 -0
- data/lib/mocha/return_values.rb +3 -3
- data/lib/mocha/setup.rb +5 -0
- data/lib/mocha/single_return_value.rb +2 -1
- data/lib/mocha/singleton_class.rb +9 -0
- data/lib/mocha/state_machine.rb +31 -40
- data/lib/mocha/stubbed_method.rb +125 -0
- data/lib/mocha/test_unit.rb +6 -1
- data/lib/mocha/thrower.rb +2 -1
- data/lib/mocha/thrown_object.rb +12 -0
- data/lib/mocha/version.rb +1 -1
- data/lib/mocha/yield_parameters.rb +5 -11
- data/lib/mocha.rb +8 -0
- data/mocha.gemspec +14 -10
- metadata +16 -233
- data/bin/build-matrix +0 -83
- data/docs/CNAME +0 -1
- data/docs/Mocha/API.html +0 -1056
- data/docs/Mocha/ClassMethods.html +0 -267
- data/docs/Mocha/Configuration.html +0 -626
- data/docs/Mocha/Expectation.html +0 -2709
- data/docs/Mocha/ExpectationError.html +0 -157
- data/docs/Mocha/ExpectationErrorFactory.html +0 -269
- data/docs/Mocha/Hooks.html +0 -385
- data/docs/Mocha/Integration/MiniTest/Adapter.html +0 -165
- data/docs/Mocha/Integration/MiniTest.html +0 -123
- data/docs/Mocha/Integration/TestUnit/Adapter.html +0 -165
- data/docs/Mocha/Integration/TestUnit.html +0 -123
- data/docs/Mocha/Integration.html +0 -125
- data/docs/Mocha/Mock.html +0 -1197
- data/docs/Mocha/ObjectMethods.html +0 -712
- data/docs/Mocha/ParameterMatchers/AllOf.html +0 -154
- data/docs/Mocha/ParameterMatchers/AnyOf.html +0 -154
- data/docs/Mocha/ParameterMatchers/AnyParameters.html +0 -153
- data/docs/Mocha/ParameterMatchers/Anything.html +0 -153
- data/docs/Mocha/ParameterMatchers/Base.html +0 -448
- data/docs/Mocha/ParameterMatchers/Equals.html +0 -154
- data/docs/Mocha/ParameterMatchers/EquivalentUri.html +0 -153
- data/docs/Mocha/ParameterMatchers/HasEntries.html +0 -154
- data/docs/Mocha/ParameterMatchers/HasEntry.html +0 -154
- data/docs/Mocha/ParameterMatchers/HasKey.html +0 -154
- data/docs/Mocha/ParameterMatchers/HasValue.html +0 -154
- data/docs/Mocha/ParameterMatchers/Includes.html +0 -154
- data/docs/Mocha/ParameterMatchers/InstanceOf.html +0 -154
- data/docs/Mocha/ParameterMatchers/IsA.html +0 -153
- data/docs/Mocha/ParameterMatchers/KindOf.html +0 -154
- data/docs/Mocha/ParameterMatchers/Not.html +0 -154
- data/docs/Mocha/ParameterMatchers/Optionally.html +0 -153
- data/docs/Mocha/ParameterMatchers/RegexpMatches.html +0 -154
- data/docs/Mocha/ParameterMatchers/RespondsWith.html +0 -154
- data/docs/Mocha/ParameterMatchers/YamlEquivalent.html +0 -154
- data/docs/Mocha/ParameterMatchers.html +0 -3049
- data/docs/Mocha/Sequence.html +0 -149
- data/docs/Mocha/StateMachine/State.html +0 -141
- data/docs/Mocha/StateMachine/StatePredicate.html +0 -141
- data/docs/Mocha/StateMachine.html +0 -539
- data/docs/Mocha/StubbingError.html +0 -150
- data/docs/Mocha/UnexpectedInvocation.html +0 -140
- data/docs/Mocha.html +0 -127
- data/docs/_index.html +0 -537
- data/docs/class_list.html +0 -51
- data/docs/css/common.css +0 -1
- data/docs/css/full_list.css +0 -58
- data/docs/css/style.css +0 -496
- data/docs/file.COPYING.html +0 -81
- data/docs/file.MIT-LICENSE.html +0 -85
- data/docs/file.README.html +0 -418
- data/docs/file.RELEASE.html +0 -875
- data/docs/file_list.html +0 -71
- data/docs/frames.html +0 -17
- data/docs/index.html +0 -418
- data/docs/js/app.js +0 -292
- data/docs/js/full_list.js +0 -216
- data/docs/js/jquery.js +0 -4
- data/docs/method_list.html +0 -571
- data/docs/top-level-namespace.html +0 -118
- data/gemfiles/Gemfile.minitest.1.3.0 +0 -7
- data/gemfiles/Gemfile.minitest.1.4.0 +0 -7
- data/gemfiles/Gemfile.minitest.1.4.1 +0 -7
- data/gemfiles/Gemfile.minitest.1.4.2 +0 -7
- data/gemfiles/Gemfile.minitest.2.0.0 +0 -7
- data/gemfiles/Gemfile.minitest.2.0.1 +0 -7
- data/gemfiles/Gemfile.minitest.2.11.0 +0 -7
- data/gemfiles/Gemfile.minitest.2.11.2 +0 -7
- data/gemfiles/Gemfile.minitest.2.3.0 +0 -7
- data/gemfiles/Gemfile.test-unit.2.0.0 +0 -7
- data/gemfiles/Gemfile.test-unit.2.0.1 +0 -7
- data/gemfiles/Gemfile.test-unit.2.0.3 +0 -7
- data/lib/mocha/class_method.rb +0 -113
- data/lib/mocha/mini_test.rb +0 -5
- data/lib/mocha/module_method.rb +0 -6
- data/lib/mocha/module_methods.rb +0 -10
- data/lib/mocha/multiple_yields.rb +0 -15
- data/lib/mocha/no_yields.rb +0 -5
- data/lib/mocha/parameter_matchers/object.rb +0 -15
- data/lib/mocha/pretty_parameters.rb +0 -24
- data/lib/mocha/single_yield.rb +0 -13
- data/lib/mocha/standalone.rb +0 -4
- data/lib/mocha/unexpected_invocation.rb +0 -24
- data/lib/mocha_standalone.rb +0 -4
- data/test/acceptance/acceptance_test_helper.rb +0 -35
- data/test/acceptance/bug_18914_test.rb +0 -38
- data/test/acceptance/bug_21465_test.rb +0 -32
- data/test/acceptance/bug_21563_test.rb +0 -23
- data/test/acceptance/exception_rescue_test.rb +0 -54
- data/test/acceptance/expectations_on_multiple_methods_test.rb +0 -56
- data/test/acceptance/expected_invocation_count_test.rb +0 -230
- data/test/acceptance/failure_messages_test.rb +0 -62
- data/test/acceptance/issue_272_test.rb +0 -51
- data/test/acceptance/issue_65_test.rb +0 -65
- data/test/acceptance/issue_70_test.rb +0 -54
- data/test/acceptance/mocha_example_test.rb +0 -97
- data/test/acceptance/mocha_test_result_test.rb +0 -84
- data/test/acceptance/mock_test.rb +0 -98
- data/test/acceptance/mock_with_initializer_block_test.rb +0 -56
- data/test/acceptance/mocked_methods_dispatch_test.rb +0 -76
- data/test/acceptance/multiple_expectations_failure_message_test.rb +0 -67
- data/test/acceptance/optional_parameters_test.rb +0 -68
- data/test/acceptance/parameter_matcher_test.rb +0 -300
- data/test/acceptance/partial_mocks_test.rb +0 -45
- data/test/acceptance/prepend_test.rb +0 -87
- data/test/acceptance/prevent_use_of_mocha_outside_test_test.rb +0 -77
- data/test/acceptance/raise_exception_test.rb +0 -37
- data/test/acceptance/return_value_test.rb +0 -50
- data/test/acceptance/sequence_test.rb +0 -190
- data/test/acceptance/states_test.rb +0 -72
- data/test/acceptance/stub_any_instance_method_defined_on_superclass_test.rb +0 -65
- data/test/acceptance/stub_any_instance_method_test.rb +0 -282
- data/test/acceptance/stub_class_method_defined_on_active_record_association_proxy_test.rb +0 -106
- data/test/acceptance/stub_class_method_defined_on_class_test.rb +0 -79
- data/test/acceptance/stub_class_method_defined_on_module_test.rb +0 -74
- data/test/acceptance/stub_class_method_defined_on_superclass_test.rb +0 -145
- data/test/acceptance/stub_everything_test.rb +0 -54
- data/test/acceptance/stub_instance_method_defined_on_active_record_association_proxy_test.rb +0 -92
- data/test/acceptance/stub_instance_method_defined_on_class_and_aliased_test.rb +0 -68
- data/test/acceptance/stub_instance_method_defined_on_class_test.rb +0 -68
- data/test/acceptance/stub_instance_method_defined_on_kernel_module_test.rb +0 -137
- data/test/acceptance/stub_instance_method_defined_on_module_test.rb +0 -77
- data/test/acceptance/stub_instance_method_defined_on_object_class_test.rb +0 -76
- data/test/acceptance/stub_instance_method_defined_on_singleton_class_test.rb +0 -68
- data/test/acceptance/stub_instance_method_defined_on_superclass_test.rb +0 -71
- data/test/acceptance/stub_method_defined_on_module_and_aliased_test.rb +0 -39
- data/test/acceptance/stub_module_method_test.rb +0 -201
- data/test/acceptance/stub_test.rb +0 -50
- data/test/acceptance/stubba_example_test.rb +0 -94
- data/test/acceptance/stubba_test_result_test.rb +0 -72
- data/test/acceptance/stubbing_error_backtrace_test.rb +0 -64
- data/test/acceptance/stubbing_frozen_object_test.rb +0 -89
- data/test/acceptance/stubbing_method_accepting_block_parameter_test.rb +0 -53
- data/test/acceptance/stubbing_method_unnecessarily_test.rb +0 -63
- data/test/acceptance/stubbing_nil_test.rb +0 -60
- data/test/acceptance/stubbing_non_existent_any_instance_method_test.rb +0 -141
- data/test/acceptance/stubbing_non_existent_class_method_test.rb +0 -157
- data/test/acceptance/stubbing_non_existent_instance_method_test.rb +0 -145
- data/test/acceptance/stubbing_non_public_any_instance_method_test.rb +0 -128
- data/test/acceptance/stubbing_non_public_class_method_test.rb +0 -163
- data/test/acceptance/stubbing_non_public_instance_method_test.rb +0 -141
- data/test/acceptance/stubbing_on_non_mock_object_test.rb +0 -70
- data/test/acceptance/stubbing_same_class_method_on_parent_and_child_classes_test.rb +0 -34
- data/test/acceptance/throw_test.rb +0 -43
- data/test/acceptance/unexpected_invocation_test.rb +0 -24
- data/test/acceptance/unstubbing_test.rb +0 -195
- data/test/assertions.rb +0 -8
- data/test/deprecation_disabler.rb +0 -15
- data/test/execution_point.rb +0 -36
- data/test/integration/mini_test_test.rb +0 -8
- data/test/integration/shared_tests.rb +0 -176
- data/test/integration/test_unit_test.rb +0 -8
- data/test/method_definer.rb +0 -22
- data/test/mini_test_result.rb +0 -96
- data/test/minitest_result.rb +0 -48
- data/test/simple_counter.rb +0 -11
- data/test/test_helper.rb +0 -58
- data/test/test_runner.rb +0 -56
- data/test/test_unit_result.rb +0 -22
- data/test/unit/any_instance_method_test.rb +0 -150
- data/test/unit/array_inspect_test.rb +0 -14
- data/test/unit/backtrace_filter_test.rb +0 -17
- data/test/unit/cardinality_test.rb +0 -54
- data/test/unit/central_test.rb +0 -99
- data/test/unit/change_state_side_effect_test.rb +0 -37
- data/test/unit/class_method_test.rb +0 -254
- data/test/unit/class_methods_test.rb +0 -69
- data/test/unit/configuration_test.rb +0 -37
- data/test/unit/date_time_inspect_test.rb +0 -19
- data/test/unit/exception_raiser_test.rb +0 -40
- data/test/unit/expectation_list_test.rb +0 -80
- data/test/unit/expectation_test.rb +0 -492
- data/test/unit/hash_inspect_test.rb +0 -14
- data/test/unit/hooks_test.rb +0 -35
- data/test/unit/in_state_ordering_constraint_test.rb +0 -39
- data/test/unit/method_matcher_test.rb +0 -26
- data/test/unit/mock_test.rb +0 -363
- data/test/unit/mockery_test.rb +0 -174
- data/test/unit/module_methods_test.rb +0 -17
- data/test/unit/multiple_yields_test.rb +0 -16
- data/test/unit/no_yields_test.rb +0 -16
- data/test/unit/object_inspect_test.rb +0 -58
- data/test/unit/object_methods_test.rb +0 -62
- data/test/unit/parameter_matchers/all_of_test.rb +0 -24
- data/test/unit/parameter_matchers/any_of_test.rb +0 -24
- data/test/unit/parameter_matchers/anything_test.rb +0 -19
- data/test/unit/parameter_matchers/equals_test.rb +0 -23
- data/test/unit/parameter_matchers/equivalent_uri_test.rb +0 -50
- data/test/unit/parameter_matchers/has_entries_test.rb +0 -51
- data/test/unit/parameter_matchers/has_entry_test.rb +0 -128
- data/test/unit/parameter_matchers/has_key_test.rb +0 -54
- data/test/unit/parameter_matchers/has_value_test.rb +0 -55
- data/test/unit/parameter_matchers/includes_test.rb +0 -106
- data/test/unit/parameter_matchers/instance_of_test.rb +0 -23
- data/test/unit/parameter_matchers/is_a_test.rb +0 -23
- data/test/unit/parameter_matchers/kind_of_test.rb +0 -23
- data/test/unit/parameter_matchers/not_test.rb +0 -24
- data/test/unit/parameter_matchers/regexp_matches_test.rb +0 -45
- data/test/unit/parameter_matchers/responds_with_test.rb +0 -38
- data/test/unit/parameter_matchers/stub_matcher.rb +0 -23
- data/test/unit/parameter_matchers/yaml_equivalent_test.rb +0 -23
- data/test/unit/parameters_matcher_test.rb +0 -119
- data/test/unit/receivers_test.rb +0 -96
- data/test/unit/return_values_test.rb +0 -61
- data/test/unit/sequence_test.rb +0 -100
- data/test/unit/single_return_value_test.rb +0 -12
- data/test/unit/single_yield_test.rb +0 -16
- data/test/unit/state_machine_test.rb +0 -96
- data/test/unit/string_inspect_test.rb +0 -9
- data/test/unit/thrower_test.rb +0 -18
- data/test/unit/yield_parameters_test.rb +0 -91
data/lib/mocha/api.rb
CHANGED
@@ -3,11 +3,33 @@ require 'mocha/hooks'
|
|
3
3
|
require 'mocha/mockery'
|
4
4
|
require 'mocha/sequence'
|
5
5
|
require 'mocha/object_methods'
|
6
|
-
require 'mocha/module_methods'
|
7
6
|
require 'mocha/class_methods'
|
8
7
|
|
9
8
|
module Mocha
|
10
9
|
# Methods added to +Test::Unit::TestCase+, +MiniTest::Unit::TestCase+ or equivalent.
|
10
|
+
# The mock creation methods are {#mock}, {#stub} and {#stub_everything}, all of which return a #{Mock}
|
11
|
+
# which can be further modified by {Mock#responds_like} and {Mock#responds_like_instance_of} methods,
|
12
|
+
# both of which return a {Mock}, too, and can therefore, be chained to the original creation methods.
|
13
|
+
#
|
14
|
+
# {Mock#responds_like} and {Mock#responds_like_instance_of} force the mock to indicate what it is
|
15
|
+
# supposed to be mocking, thus making it a safer verifying mock. They check that the underlying +responder+
|
16
|
+
# will actually respond to the methods being stubbed, throwing a +NoMethodError+ upon invocation otherwise.
|
17
|
+
#
|
18
|
+
# @example Verifying mock using {Mock#responds_like_instance_of}
|
19
|
+
# class Sheep
|
20
|
+
# def initialize
|
21
|
+
# raise "some awkward code we don't want to call"
|
22
|
+
# end
|
23
|
+
# def chew(grass); end
|
24
|
+
# end
|
25
|
+
#
|
26
|
+
# sheep = mock('sheep').responds_like_instance_of(Sheep)
|
27
|
+
# sheep.expects(:chew)
|
28
|
+
# sheep.expects(:foo)
|
29
|
+
# sheep.respond_to?(:chew) # => true
|
30
|
+
# sheep.respond_to?(:foo) # => false
|
31
|
+
# sheep.chew
|
32
|
+
# sheep.foo # => raises NoMethodError exception
|
11
33
|
module API
|
12
34
|
include ParameterMatchers
|
13
35
|
include Hooks
|
@@ -15,22 +37,26 @@ module Mocha
|
|
15
37
|
# @private
|
16
38
|
def self.included(_mod)
|
17
39
|
Object.send(:include, Mocha::ObjectMethods)
|
18
|
-
Module.send(:include, Mocha::ModuleMethods)
|
19
40
|
Class.send(:include, Mocha::ClassMethods)
|
20
41
|
end
|
21
42
|
|
43
|
+
# @private
|
44
|
+
def self.extended(mod)
|
45
|
+
included(mod)
|
46
|
+
end
|
47
|
+
|
22
48
|
# Builds a new mock object
|
23
49
|
#
|
24
|
-
# @param [String] name identifies mock object in error messages.
|
25
|
-
# @param [Hash] expected_methods_vs_return_values expected method name symbols as keys and corresponding return values as values - these expectations are setup as if {Mock#expects} were called multiple times.
|
26
|
-
# @yield optional block to be evaluated in the context of the mock object instance, giving an alternative way to setup stubbed methods.
|
27
|
-
# @yield note that the block is evaulated by calling Mock#instance_eval and so things like instance variables declared in the test will not be available within the block.
|
28
|
-
# @yield deprecated: use Object#tap or define stubs/expectations with an explicit receiver instead.
|
29
50
|
# @return [Mock] a new mock object
|
30
51
|
#
|
31
|
-
# @overload def mock(name
|
32
|
-
#
|
33
|
-
#
|
52
|
+
# @overload def mock(name)
|
53
|
+
# @param [String, Symbol] name identifies mock object in error messages.
|
54
|
+
# @note Prior to v1.10.0 when +name+ was a +Symbol+, this method returned an unnamed +Mock+ that expected the method identified by +name+. This was undocumented behaviour and it will be removed in the future, but for the moment it can be reinstated using {Configuration#reinstate_undocumented_behaviour_from_v1_9=}.
|
55
|
+
# @overload def mock(expected_methods_vs_return_values = {})
|
56
|
+
# @param [Hash] expected_methods_vs_return_values expected method name symbols as keys and corresponding return values as values - these expectations are setup as if {Mock#expects} were called multiple times.
|
57
|
+
# @overload def mock(name, expected_methods_vs_return_values = {})
|
58
|
+
# @param [String, Symbol] name identifies mock object in error messages.
|
59
|
+
# @param [Hash] expected_methods_vs_return_values expected method name symbols as keys and corresponding return values as values - these expectations are setup as if {Mock#expects} were called multiple times.
|
34
60
|
#
|
35
61
|
# @example Using expected_methods_vs_return_values Hash to setup expectations.
|
36
62
|
# def test_motor_starts_and_stops
|
@@ -39,36 +65,44 @@ module Mocha
|
|
39
65
|
# assert motor.stop
|
40
66
|
# # an error will be raised unless both Motor#start and Motor#stop have been called
|
41
67
|
# end
|
42
|
-
#
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
68
|
+
#
|
69
|
+
def mock(*arguments) # rubocop:disable Metrics/CyclomaticComplexity,Metrics/PerceivedComplexity
|
70
|
+
if Mocha.configuration.reinstate_undocumented_behaviour_from_v1_9?
|
71
|
+
if arguments.first.is_a?(Symbol)
|
72
|
+
method_name = arguments[0]
|
73
|
+
Deprecation.warning(
|
74
|
+
"Explicitly include `#{method_name}` in Hash of expected methods vs return values,",
|
75
|
+
" e.g. `mock(:#{method_name} => nil)`."
|
76
|
+
)
|
77
|
+
if arguments[1]
|
78
|
+
Deprecation.warning(
|
79
|
+
"In this case the 2nd argument for `mock(:##{method_name}, ...)` is ignored,",
|
80
|
+
' but in the future a Hash of expected methods vs return values will be respected.'
|
81
|
+
)
|
82
|
+
end
|
83
|
+
elsif arguments.first.is_a?(String)
|
84
|
+
name = arguments.shift
|
85
|
+
end
|
86
|
+
elsif arguments.first.is_a?(String) || arguments.first.is_a?(Symbol)
|
87
|
+
name = arguments.shift
|
88
|
+
end
|
54
89
|
expectations = arguments.shift || {}
|
55
|
-
mock = name ? Mockery.instance.named_mock(name
|
90
|
+
mock = name ? Mockery.instance.named_mock(name) : Mockery.instance.unnamed_mock
|
56
91
|
mock.expects(expectations)
|
57
92
|
mock
|
58
93
|
end
|
59
94
|
|
60
95
|
# Builds a new mock object
|
61
96
|
#
|
62
|
-
# @param [String] name identifies mock object in error messages.
|
63
|
-
# @param [Hash] stubbed_methods_vs_return_values stubbed method name symbols as keys and corresponding return values as values - these stubbed methods are setup as if {Mock#stubs} were called multiple times.
|
64
|
-
# @yield optional block to be evaluated in the context of the mock object instance, giving an alternative way to setup stubbed methods.
|
65
|
-
# @yield note that the block is evaulated by calling Mock#instance_eval and so things like instance variables declared in the test will not be available within the block.
|
66
|
-
# @yield deprecated: use Object#tap or define stubs/expectations with an explicit receiver instead.
|
67
97
|
# @return [Mock] a new mock object
|
68
98
|
#
|
69
|
-
# @overload def stub(name
|
70
|
-
#
|
71
|
-
#
|
99
|
+
# @overload def stub(name)
|
100
|
+
# @param [String, Symbol] name identifies mock object in error messages.
|
101
|
+
# @note Prior to v1.10.0 when +name+ was a +Symbol+, this method returned an unnamed +Mock+ that stubbed the method identified by +name+. This was undocumented behaviour and it will be removed in the future, but for the moment it can be reinstated using {Configuration#reinstate_undocumented_behaviour_from_v1_9=}.
|
102
|
+
# @overload def stub(stubbed_methods_vs_return_values = {})
|
103
|
+
# @param [Hash] stubbed_methods_vs_return_values stubbed method name symbols as keys and corresponding return values as values - these stubbed methods are setup as if {Mock#stubs} were called multiple times.
|
104
|
+
# @overload def stub(name, stubbed_methods_vs_return_values = {})
|
105
|
+
# @param [String, Symbol] name identifies mock object in error messages.
|
72
106
|
#
|
73
107
|
# @example Using stubbed_methods_vs_return_values Hash to setup stubbed methods.
|
74
108
|
# def test_motor_starts_and_stops
|
@@ -77,37 +111,46 @@ module Mocha
|
|
77
111
|
# assert motor.stop
|
78
112
|
# # an error will not be raised even if either Motor#start or Motor#stop has not been called
|
79
113
|
# end
|
80
|
-
#
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
114
|
+
# rubocop:disable Metrics/CyclomaticComplexity,Metrics/PerceivedComplexity
|
115
|
+
def stub(*arguments)
|
116
|
+
if Mocha.configuration.reinstate_undocumented_behaviour_from_v1_9?
|
117
|
+
if arguments.first.is_a?(Symbol)
|
118
|
+
method_name = arguments[0]
|
119
|
+
Deprecation.warning(
|
120
|
+
"Explicitly include `#{method_name}` in Hash of stubbed methods vs return values,",
|
121
|
+
" e.g. `stub(:#{method_name} => nil)`."
|
122
|
+
)
|
123
|
+
if arguments[1]
|
124
|
+
Deprecation.warning(
|
125
|
+
"In this case the 2nd argument for `stub(:##{method_name}, ...)` is ignored,",
|
126
|
+
' but in the future a Hash of stubbed methods vs return values will be respected.'
|
127
|
+
)
|
128
|
+
end
|
129
|
+
elsif arguments.first.is_a?(String)
|
130
|
+
name = arguments.shift
|
131
|
+
end
|
132
|
+
elsif arguments.first.is_a?(String) || arguments.first.is_a?(Symbol)
|
133
|
+
name = arguments.shift
|
134
|
+
end
|
93
135
|
expectations = arguments.shift || {}
|
94
|
-
stub = name ? Mockery.instance.named_mock(name
|
136
|
+
stub = name ? Mockery.instance.named_mock(name) : Mockery.instance.unnamed_mock
|
95
137
|
stub.stubs(expectations)
|
96
138
|
stub
|
97
139
|
end
|
140
|
+
# rubocop:enable Metrics/CyclomaticComplexity,Metrics/PerceivedComplexity
|
98
141
|
|
99
142
|
# Builds a mock object that accepts calls to any method. By default it will return +nil+ for any method call.
|
100
143
|
#
|
101
|
-
# @param [String] name identifies mock object in error messages.
|
102
|
-
# @param [Hash] stubbed_methods_vs_return_values stubbed method name symbols as keys and corresponding return values as values - these stubbed methods are setup as if {Mock#stubs} were called multiple times.
|
103
|
-
# @yield optional block to be evaluated in the context of the mock object instance, giving an alternative way to setup stubbed methods.
|
104
|
-
# @yield note that the block is evaulated by calling Mock#instance_eval and so things like instance variables declared in the test will not be available within the block.
|
105
|
-
# @yield deprecated: use Object#tap or define stubs/expectations with an explicit receiver instead.
|
106
144
|
# @return [Mock] a new mock object
|
107
145
|
#
|
108
|
-
# @overload def stub_everything(name
|
109
|
-
#
|
110
|
-
#
|
146
|
+
# @overload def stub_everything(name)
|
147
|
+
# @param [String, Symbol] name identifies mock object in error messages.
|
148
|
+
# @note Prior to v1.10.0 when +name+ was a +Symbol+, this method returned an unnamed +Mock+ that stubbed the method identified by +name+. This was undocumented behaviour and it will be removed in the future, but for the moment it can be reinstated using {Configuration#reinstate_undocumented_behaviour_from_v1_9=}.
|
149
|
+
# @overload def stub_everything(stubbed_methods_vs_return_values = {})
|
150
|
+
# @param [Hash] stubbed_methods_vs_return_values stubbed method name symbols as keys and corresponding return values as values - these stubbed methods are setup as if {Mock#stubs} were called multiple times.
|
151
|
+
# @overload def stub_everything(name, stubbed_methods_vs_return_values = {})
|
152
|
+
# @param [String, Symbol] name identifies mock object in error messages.
|
153
|
+
# @param [Hash] stubbed_methods_vs_return_values stubbed method name symbols as keys and corresponding return values as values - these stubbed methods are setup as if {Mock#stubs} were called multiple times.
|
111
154
|
#
|
112
155
|
# @example Ignore invocations of irrelevant methods.
|
113
156
|
# def test_motor_stops
|
@@ -116,14 +159,34 @@ module Mocha
|
|
116
159
|
# assert_nil motor.irrelevant_method_2 # => no error raised
|
117
160
|
# assert motor.stop
|
118
161
|
# end
|
119
|
-
|
120
|
-
|
162
|
+
# rubocop:disable Metrics/CyclomaticComplexity,Metrics/PerceivedComplexity
|
163
|
+
def stub_everything(*arguments)
|
164
|
+
if Mocha.configuration.reinstate_undocumented_behaviour_from_v1_9?
|
165
|
+
if arguments.first.is_a?(Symbol)
|
166
|
+
method_name = arguments[0]
|
167
|
+
Deprecation.warning(
|
168
|
+
"Explicitly include `#{method_name}` in Hash of stubbed methods vs return values,",
|
169
|
+
" e.g. `stub_everything(:#{method_name} => nil)`."
|
170
|
+
)
|
171
|
+
if arguments[1]
|
172
|
+
Deprecation.warning(
|
173
|
+
"In this case the 2nd argument for `stub_everything(:##{method_name}, ...)` is ignored,",
|
174
|
+
' but in the future a Hash of stubbed methods vs return values will be respected.'
|
175
|
+
)
|
176
|
+
end
|
177
|
+
elsif arguments.first.is_a?(String)
|
178
|
+
name = arguments.shift
|
179
|
+
end
|
180
|
+
elsif arguments.first.is_a?(String) || arguments.first.is_a?(Symbol)
|
181
|
+
name = arguments.shift
|
182
|
+
end
|
121
183
|
expectations = arguments.shift || {}
|
122
|
-
stub = name ? Mockery.instance.named_mock(name
|
184
|
+
stub = name ? Mockery.instance.named_mock(name) : Mockery.instance.unnamed_mock
|
123
185
|
stub.stub_everything
|
124
186
|
stub.stubs(expectations)
|
125
187
|
stub
|
126
188
|
end
|
189
|
+
# rubocop:enable Metrics/CyclomaticComplexity,Metrics/PerceivedComplexity
|
127
190
|
|
128
191
|
# Builds a new sequence which can be used to constrain the order in which expectations can occur.
|
129
192
|
#
|
@@ -0,0 +1,31 @@
|
|
1
|
+
module Mocha
|
2
|
+
module BlockMatchers
|
3
|
+
class OptionalBlock
|
4
|
+
def match?(_actual_block)
|
5
|
+
true
|
6
|
+
end
|
7
|
+
|
8
|
+
def mocha_inspect; end
|
9
|
+
end
|
10
|
+
|
11
|
+
class BlockGiven
|
12
|
+
def match?(actual_block)
|
13
|
+
!actual_block.nil?
|
14
|
+
end
|
15
|
+
|
16
|
+
def mocha_inspect
|
17
|
+
'with block given'
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
class NoBlockGiven
|
22
|
+
def match?(actual_block)
|
23
|
+
actual_block.nil?
|
24
|
+
end
|
25
|
+
|
26
|
+
def mocha_inspect
|
27
|
+
'with no block given'
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
data/lib/mocha/cardinality.rb
CHANGED
@@ -2,85 +2,103 @@ module Mocha
|
|
2
2
|
class Cardinality
|
3
3
|
INFINITY = 1 / 0.0
|
4
4
|
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
5
|
+
def initialize(required = 0, maximum = INFINITY)
|
6
|
+
update(required, maximum)
|
7
|
+
@invocations = []
|
8
|
+
end
|
9
9
|
|
10
|
-
|
11
|
-
|
12
|
-
|
10
|
+
def exactly(count)
|
11
|
+
update(count, count)
|
12
|
+
end
|
13
13
|
|
14
|
-
|
15
|
-
|
16
|
-
|
14
|
+
def at_least(count)
|
15
|
+
update(count, INFINITY)
|
16
|
+
end
|
17
|
+
|
18
|
+
def at_most(count)
|
19
|
+
update(0, count)
|
20
|
+
end
|
17
21
|
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
end
|
22
|
+
def times(range_or_count)
|
23
|
+
case range_or_count
|
24
|
+
when Range then update(range_or_count.first, range_or_count.last)
|
25
|
+
else update(range_or_count, range_or_count)
|
23
26
|
end
|
24
27
|
end
|
25
28
|
|
26
|
-
def
|
27
|
-
@
|
28
|
-
@maximum = maximum
|
29
|
+
def <<(invocation)
|
30
|
+
@invocations << invocation
|
29
31
|
end
|
30
32
|
|
31
|
-
def invocations_allowed?
|
32
|
-
|
33
|
+
def invocations_allowed?
|
34
|
+
@invocations.size < maximum
|
33
35
|
end
|
34
36
|
|
35
|
-
def satisfied?
|
36
|
-
|
37
|
+
def satisfied?
|
38
|
+
@invocations.size >= required
|
37
39
|
end
|
38
40
|
|
39
41
|
def needs_verifying?
|
40
42
|
!allowed_any_number_of_times?
|
41
43
|
end
|
42
44
|
|
43
|
-
def verified?
|
44
|
-
(
|
45
|
+
def verified?
|
46
|
+
(@invocations.size >= required) && (@invocations.size <= maximum)
|
45
47
|
end
|
46
48
|
|
47
49
|
def allowed_any_number_of_times?
|
48
50
|
required.zero? && infinite?(maximum)
|
49
51
|
end
|
50
52
|
|
51
|
-
def used?
|
52
|
-
|
53
|
+
def used?
|
54
|
+
@invocations.any? || maximum.zero?
|
53
55
|
end
|
54
56
|
|
55
|
-
|
57
|
+
# rubocop:disable Metrics/CyclomaticComplexity,Metrics/PerceivedComplexity
|
58
|
+
def anticipated_times
|
56
59
|
if allowed_any_number_of_times?
|
57
60
|
'allowed any number of times'
|
58
61
|
elsif required.zero? && maximum.zero?
|
59
|
-
|
62
|
+
"expected #{count(maximum)}"
|
60
63
|
elsif required == maximum
|
61
|
-
"expected exactly #{
|
64
|
+
"expected exactly #{count(required)}"
|
62
65
|
elsif infinite?(maximum)
|
63
|
-
"expected at least #{
|
66
|
+
"expected at least #{count(required)}"
|
64
67
|
elsif required.zero?
|
65
|
-
"expected at most #{
|
68
|
+
"expected at most #{count(maximum)}"
|
66
69
|
else
|
67
|
-
"expected between #{required} and #{
|
70
|
+
"expected between #{required} and #{count(maximum)}"
|
68
71
|
end
|
69
72
|
end
|
73
|
+
# rubocop:enable Metrics/CyclomaticComplexity,Metrics/PerceivedComplexity
|
74
|
+
|
75
|
+
def invoked_times
|
76
|
+
"invoked #{count(@invocations.size)}"
|
77
|
+
end
|
78
|
+
|
79
|
+
def actual_invocations
|
80
|
+
@invocations.map(&:full_description).join
|
81
|
+
end
|
70
82
|
|
71
83
|
protected
|
72
84
|
|
73
85
|
attr_reader :required, :maximum
|
74
86
|
|
75
|
-
def
|
87
|
+
def count(number)
|
76
88
|
case number
|
77
|
-
when 0 then '
|
89
|
+
when 0 then 'never'
|
78
90
|
when 1 then 'once'
|
79
91
|
when 2 then 'twice'
|
80
92
|
else "#{number} times"
|
81
93
|
end
|
82
94
|
end
|
83
95
|
|
96
|
+
def update(required, maximum)
|
97
|
+
@required = required
|
98
|
+
@maximum = maximum
|
99
|
+
self
|
100
|
+
end
|
101
|
+
|
84
102
|
def infinite?(number)
|
85
103
|
number.respond_to?(:infinite?) && number.infinite?
|
86
104
|
end
|
data/lib/mocha/class_methods.rb
CHANGED
@@ -1,15 +1,9 @@
|
|
1
1
|
require 'mocha/mockery'
|
2
|
-
require 'mocha/class_method'
|
3
2
|
require 'mocha/any_instance_method'
|
4
3
|
|
5
4
|
module Mocha
|
6
5
|
# Methods added to all classes to allow mocking and stubbing on real (i.e. non-mock) objects.
|
7
6
|
module ClassMethods
|
8
|
-
# @private
|
9
|
-
def stubba_method
|
10
|
-
Mocha::ClassMethod
|
11
|
-
end
|
12
|
-
|
13
7
|
# @private
|
14
8
|
class AnyInstance
|
15
9
|
def initialize(klass)
|
@@ -28,17 +22,15 @@ module Mocha
|
|
28
22
|
Mocha::AnyInstanceMethod
|
29
23
|
end
|
30
24
|
|
31
|
-
|
25
|
+
def stubba_class
|
26
|
+
@stubba_object
|
27
|
+
end
|
32
28
|
|
33
|
-
def
|
34
|
-
|
35
|
-
return true if @stubba_object.public_instance_methods(true).include?(method)
|
36
|
-
return true if @stubba_object.allocate.respond_to?(method.to_sym)
|
37
|
-
end
|
38
|
-
return true if @stubba_object.protected_instance_methods(true).include?(method)
|
39
|
-
return true if @stubba_object.private_instance_methods(true).include?(method)
|
40
|
-
false
|
29
|
+
def respond_to?(method)
|
30
|
+
@stubba_object.allocate.respond_to?(method.to_sym)
|
41
31
|
end
|
32
|
+
|
33
|
+
attr_reader :stubba_object
|
42
34
|
end
|
43
35
|
|
44
36
|
# @return [Mock] a mock object which will detect calls to any instance of this class.
|
@@ -56,5 +48,15 @@ module Mocha
|
|
56
48
|
end
|
57
49
|
@any_instance ||= AnyInstance.new(self)
|
58
50
|
end
|
51
|
+
|
52
|
+
# @private
|
53
|
+
# rubocop:disable Metrics/CyclomaticComplexity
|
54
|
+
def __method_visibility__(method, include_public_methods = true)
|
55
|
+
(include_public_methods && public_method_defined?(method) && :public) ||
|
56
|
+
(protected_method_defined?(method) && :protected) ||
|
57
|
+
(private_method_defined?(method) && :private)
|
58
|
+
end
|
59
|
+
# rubocop:enable Metrics/CyclomaticComplexity
|
60
|
+
alias_method :__method_exists__?, :__method_visibility__
|
59
61
|
end
|
60
62
|
end
|