opal-rspec 0.4.0.beta3 → 0.4.0.beta4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (161) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +0 -1
  3. data/.gitmodules +15 -0
  4. data/.travis.yml +12 -0
  5. data/.yardopts +5 -0
  6. data/CHANGELOG.md +3 -1
  7. data/Gemfile +6 -7
  8. data/README.md +2 -0
  9. data/Rakefile +12 -50
  10. data/lib/opal/rspec/version.rb +1 -1
  11. data/lib/opal/rspec.rb +14 -0
  12. data/opal/opal/rspec/async.rb +146 -11
  13. data/opal/opal/rspec/fixes.rb +18 -8
  14. data/opal/opal/rspec/requires.rb +45 -0
  15. data/opal/opal/rspec.rb +1 -24
  16. data/opal-rspec.gemspec +1 -1
  17. data/spec/async_spec.rb +4 -5
  18. data/spec/matchers_spec.rb +20 -0
  19. data/spec/named_subject_spec.rb +11 -0
  20. data/spec/should_syntax_spec.rb +17 -0
  21. data/vendor_lib/rspec/autorun.rb +2 -0
  22. data/vendor_lib/rspec/core/backport_random.rb +302 -0
  23. data/vendor_lib/rspec/core/backtrace_formatter.rb +65 -0
  24. data/vendor_lib/rspec/core/command_line.rb +36 -0
  25. data/vendor_lib/rspec/core/configuration.rb +1129 -0
  26. data/vendor_lib/rspec/core/configuration_options.rb +143 -0
  27. data/vendor_lib/rspec/core/drb_command_line.rb +26 -0
  28. data/vendor_lib/rspec/core/drb_options.rb +87 -0
  29. data/vendor_lib/rspec/core/dsl.rb +26 -0
  30. data/vendor_lib/rspec/core/example.rb +312 -0
  31. data/vendor_lib/rspec/core/example_group.rb +540 -0
  32. data/vendor_lib/rspec/core/filter_manager.rb +224 -0
  33. data/vendor_lib/rspec/core/flat_map.rb +17 -0
  34. data/vendor_lib/rspec/core/formatters/base_formatter.rb +291 -0
  35. data/vendor_lib/rspec/core/formatters/base_text_formatter.rb +307 -0
  36. data/vendor_lib/rspec/core/formatters/deprecation_formatter.rb +193 -0
  37. data/vendor_lib/rspec/core/formatters/documentation_formatter.rb +67 -0
  38. data/vendor_lib/rspec/core/formatters/helpers.rb +82 -0
  39. data/vendor_lib/rspec/core/formatters/html_formatter.rb +155 -0
  40. data/vendor_lib/rspec/core/formatters/html_printer.rb +408 -0
  41. data/vendor_lib/rspec/core/formatters/json_formatter.rb +99 -0
  42. data/vendor_lib/rspec/core/formatters/progress_formatter.rb +32 -0
  43. data/vendor_lib/rspec/core/formatters/snippet_extractor.rb +101 -0
  44. data/vendor_lib/rspec/core/formatters.rb +54 -0
  45. data/vendor_lib/rspec/core/hooks.rb +535 -0
  46. data/vendor_lib/rspec/core/memoized_helpers.rb +431 -0
  47. data/vendor_lib/rspec/core/metadata.rb +313 -0
  48. data/vendor_lib/rspec/core/mocking/with_absolutely_nothing.rb +11 -0
  49. data/vendor_lib/rspec/core/mocking/with_flexmock.rb +27 -0
  50. data/vendor_lib/rspec/core/mocking/with_mocha.rb +52 -0
  51. data/vendor_lib/rspec/core/mocking/with_rr.rb +27 -0
  52. data/vendor_lib/rspec/core/mocking/with_rspec.rb +27 -0
  53. data/vendor_lib/rspec/core/option_parser.rb +234 -0
  54. data/vendor_lib/rspec/core/ordering.rb +154 -0
  55. data/vendor_lib/rspec/core/pending.rb +110 -0
  56. data/vendor_lib/rspec/core/project_initializer.rb +88 -0
  57. data/vendor_lib/rspec/core/rake_task.rb +128 -0
  58. data/vendor_lib/rspec/core/reporter.rb +132 -0
  59. data/vendor_lib/rspec/core/ruby_project.rb +44 -0
  60. data/vendor_lib/rspec/core/runner.rb +97 -0
  61. data/vendor_lib/rspec/core/shared_context.rb +53 -0
  62. data/vendor_lib/rspec/core/shared_example_group/collection.rb +27 -0
  63. data/vendor_lib/rspec/core/shared_example_group.rb +146 -0
  64. data/vendor_lib/rspec/core/version.rb +7 -0
  65. data/vendor_lib/rspec/core/warnings.rb +22 -0
  66. data/vendor_lib/rspec/core/world.rb +131 -0
  67. data/vendor_lib/rspec/core.rb +203 -0
  68. data/vendor_lib/rspec/expectations/differ.rb +154 -0
  69. data/vendor_lib/rspec/expectations/errors.rb +9 -0
  70. data/vendor_lib/rspec/expectations/expectation_target.rb +87 -0
  71. data/vendor_lib/rspec/expectations/extensions/object.rb +29 -0
  72. data/vendor_lib/rspec/expectations/extensions.rb +1 -0
  73. data/vendor_lib/rspec/expectations/fail_with.rb +79 -0
  74. data/vendor_lib/rspec/expectations/handler.rb +68 -0
  75. data/vendor_lib/rspec/expectations/syntax.rb +182 -0
  76. data/vendor_lib/rspec/expectations/version.rb +8 -0
  77. data/vendor_lib/rspec/expectations.rb +75 -0
  78. data/vendor_lib/rspec/matchers/built_in/base_matcher.rb +68 -0
  79. data/vendor_lib/rspec/matchers/built_in/be.rb +213 -0
  80. data/vendor_lib/rspec/matchers/built_in/be_instance_of.rb +15 -0
  81. data/vendor_lib/rspec/matchers/built_in/be_kind_of.rb +11 -0
  82. data/vendor_lib/rspec/matchers/built_in/be_within.rb +55 -0
  83. data/vendor_lib/rspec/matchers/built_in/change.rb +141 -0
  84. data/vendor_lib/rspec/matchers/built_in/cover.rb +21 -0
  85. data/vendor_lib/rspec/matchers/built_in/eq.rb +22 -0
  86. data/vendor_lib/rspec/matchers/built_in/eql.rb +23 -0
  87. data/vendor_lib/rspec/matchers/built_in/equal.rb +48 -0
  88. data/vendor_lib/rspec/matchers/built_in/exist.rb +26 -0
  89. data/vendor_lib/rspec/matchers/built_in/has.rb +48 -0
  90. data/vendor_lib/rspec/matchers/built_in/include.rb +61 -0
  91. data/vendor_lib/rspec/matchers/built_in/match.rb +17 -0
  92. data/vendor_lib/rspec/matchers/built_in/match_array.rb +51 -0
  93. data/vendor_lib/rspec/matchers/built_in/raise_error.rb +154 -0
  94. data/vendor_lib/rspec/matchers/built_in/respond_to.rb +74 -0
  95. data/vendor_lib/rspec/matchers/built_in/satisfy.rb +30 -0
  96. data/vendor_lib/rspec/matchers/built_in/start_and_end_with.rb +48 -0
  97. data/vendor_lib/rspec/matchers/built_in/throw_symbol.rb +94 -0
  98. data/vendor_lib/rspec/matchers/built_in/yield.rb +297 -0
  99. data/vendor_lib/rspec/matchers/built_in.rb +39 -0
  100. data/vendor_lib/rspec/matchers/compatibility.rb +14 -0
  101. data/vendor_lib/rspec/matchers/configuration.rb +113 -0
  102. data/vendor_lib/rspec/matchers/dsl.rb +23 -0
  103. data/vendor_lib/rspec/matchers/generated_descriptions.rb +35 -0
  104. data/vendor_lib/rspec/matchers/matcher.rb +301 -0
  105. data/vendor_lib/rspec/matchers/method_missing.rb +12 -0
  106. data/vendor_lib/rspec/matchers/operator_matcher.rb +99 -0
  107. data/vendor_lib/rspec/matchers/pretty.rb +70 -0
  108. data/vendor_lib/rspec/matchers/test_unit_integration.rb +11 -0
  109. data/vendor_lib/rspec/matchers.rb +633 -0
  110. data/vendor_lib/rspec/mocks/any_instance/chain.rb +92 -0
  111. data/vendor_lib/rspec/mocks/any_instance/expectation_chain.rb +47 -0
  112. data/vendor_lib/rspec/mocks/any_instance/message_chains.rb +75 -0
  113. data/vendor_lib/rspec/mocks/any_instance/recorder.rb +200 -0
  114. data/vendor_lib/rspec/mocks/any_instance/stub_chain.rb +45 -0
  115. data/vendor_lib/rspec/mocks/any_instance/stub_chain_chain.rb +23 -0
  116. data/vendor_lib/rspec/mocks/argument_list_matcher.rb +104 -0
  117. data/vendor_lib/rspec/mocks/argument_matchers.rb +264 -0
  118. data/vendor_lib/rspec/mocks/arity_calculator.rb +66 -0
  119. data/vendor_lib/rspec/mocks/configuration.rb +111 -0
  120. data/vendor_lib/rspec/mocks/error_generator.rb +203 -0
  121. data/vendor_lib/rspec/mocks/errors.rb +12 -0
  122. data/vendor_lib/rspec/mocks/example_methods.rb +201 -0
  123. data/vendor_lib/rspec/mocks/extensions/marshal.rb +17 -0
  124. data/vendor_lib/rspec/mocks/framework.rb +36 -0
  125. data/vendor_lib/rspec/mocks/instance_method_stasher.rb +112 -0
  126. data/vendor_lib/rspec/mocks/matchers/have_received.rb +99 -0
  127. data/vendor_lib/rspec/mocks/matchers/receive.rb +112 -0
  128. data/vendor_lib/rspec/mocks/matchers/receive_messages.rb +72 -0
  129. data/vendor_lib/rspec/mocks/message_expectation.rb +643 -0
  130. data/vendor_lib/rspec/mocks/method_double.rb +209 -0
  131. data/vendor_lib/rspec/mocks/method_reference.rb +95 -0
  132. data/vendor_lib/rspec/mocks/mock.rb +7 -0
  133. data/vendor_lib/rspec/mocks/mutate_const.rb +406 -0
  134. data/vendor_lib/rspec/mocks/object_reference.rb +90 -0
  135. data/vendor_lib/rspec/mocks/order_group.rb +82 -0
  136. data/vendor_lib/rspec/mocks/proxy.rb +269 -0
  137. data/vendor_lib/rspec/mocks/proxy_for_nil.rb +37 -0
  138. data/vendor_lib/rspec/mocks/space.rb +95 -0
  139. data/vendor_lib/rspec/mocks/standalone.rb +3 -0
  140. data/vendor_lib/rspec/mocks/stub_chain.rb +51 -0
  141. data/vendor_lib/rspec/mocks/syntax.rb +374 -0
  142. data/vendor_lib/rspec/mocks/targets.rb +90 -0
  143. data/vendor_lib/rspec/mocks/test_double.rb +109 -0
  144. data/vendor_lib/rspec/mocks/verifying_double.rb +77 -0
  145. data/vendor_lib/rspec/mocks/verifying_message_expecation.rb +60 -0
  146. data/vendor_lib/rspec/mocks/verifying_proxy.rb +151 -0
  147. data/vendor_lib/rspec/mocks/version.rb +7 -0
  148. data/vendor_lib/rspec/mocks.rb +100 -0
  149. data/vendor_lib/rspec/support/caller_filter.rb +56 -0
  150. data/vendor_lib/rspec/support/spec/deprecation_helpers.rb +29 -0
  151. data/vendor_lib/rspec/support/spec/in_sub_process.rb +40 -0
  152. data/vendor_lib/rspec/support/spec/stderr_splitter.rb +50 -0
  153. data/vendor_lib/rspec/support/spec.rb +14 -0
  154. data/vendor_lib/rspec/support/version.rb +7 -0
  155. data/vendor_lib/rspec/support/warnings.rb +41 -0
  156. data/vendor_lib/rspec/support.rb +6 -0
  157. data/vendor_lib/rspec/version.rb +5 -0
  158. data/vendor_lib/rspec-expectations.rb +1 -0
  159. data/vendor_lib/rspec.rb +3 -0
  160. metadata +163 -4
  161. data/opal/opal/rspec/rspec.js +0 -20384
@@ -0,0 +1,264 @@
1
+ module RSpec
2
+ module Mocks
3
+
4
+ # ArgumentMatchers are placeholders that you can include in message
5
+ # expectations to match arguments against a broader check than simple
6
+ # equality.
7
+ #
8
+ # With the exception of `any_args` and `no_args`, they all match against
9
+ # the arg in same position in the argument list.
10
+ #
11
+ # @see ArgumentListMatcher
12
+ module ArgumentMatchers
13
+
14
+ class AnyArgsMatcher
15
+ def description
16
+ "any args"
17
+ end
18
+ end
19
+
20
+ class AnyArgMatcher
21
+ def initialize(ignore)
22
+ end
23
+
24
+ def ==(other)
25
+ true
26
+ end
27
+ end
28
+
29
+ class NoArgsMatcher
30
+ def description
31
+ "no args"
32
+ end
33
+ end
34
+
35
+ class RegexpMatcher
36
+ def initialize(regexp)
37
+ @regexp = regexp
38
+ end
39
+
40
+ def ==(value)
41
+ Regexp === value ? value == @regexp : value =~ @regexp
42
+ end
43
+ end
44
+
45
+ class BooleanMatcher
46
+ def initialize(ignore)
47
+ end
48
+
49
+ def ==(value)
50
+ [true,false].include?(value)
51
+ end
52
+ end
53
+
54
+ class HashIncludingMatcher
55
+ def initialize(expected)
56
+ @expected = expected
57
+ end
58
+
59
+ def ==(actual)
60
+ @expected.all? {|k,v| actual.has_key?(k) && v == actual[k]}
61
+ rescue NoMethodError
62
+ false
63
+ end
64
+
65
+ def description
66
+ "hash_including(#{@expected.inspect.sub(/^\{/,"").sub(/\}$/,"")})"
67
+ end
68
+ end
69
+
70
+ class HashExcludingMatcher
71
+ def initialize(expected)
72
+ @expected = expected
73
+ end
74
+
75
+ def ==(actual)
76
+ @expected.none? {|k,v| actual.has_key?(k) && v == actual[k]}
77
+ rescue NoMethodError
78
+ false
79
+ end
80
+
81
+ def description
82
+ "hash_not_including(#{@expected.inspect.sub(/^\{/,"").sub(/\}$/,"")})"
83
+ end
84
+ end
85
+
86
+ class ArrayIncludingMatcher
87
+ def initialize(expected)
88
+ @expected = expected
89
+ end
90
+
91
+ def ==(actual)
92
+ Set.new(actual).superset?(Set.new(@expected))
93
+ end
94
+
95
+ def description
96
+ "array_including(#{@expected.join(",")})"
97
+ end
98
+ end
99
+
100
+ class DuckTypeMatcher
101
+ def initialize(*methods_to_respond_to)
102
+ @methods_to_respond_to = methods_to_respond_to
103
+ end
104
+
105
+ def ==(value)
106
+ @methods_to_respond_to.all? {|message| value.respond_to?(message)}
107
+ end
108
+ end
109
+
110
+ class MatcherMatcher
111
+ def initialize(matcher)
112
+ @matcher = matcher
113
+ end
114
+
115
+ def ==(value)
116
+ @matcher.matches?(value)
117
+ end
118
+ end
119
+
120
+ class EqualityProxy
121
+ def initialize(given)
122
+ @given = given
123
+ end
124
+
125
+ def ==(expected)
126
+ @given == expected
127
+ end
128
+ end
129
+
130
+ class InstanceOf
131
+ def initialize(klass)
132
+ @klass = klass
133
+ end
134
+
135
+ def ==(actual)
136
+ actual.instance_of?(@klass)
137
+ end
138
+ end
139
+
140
+ class KindOf
141
+ def initialize(klass)
142
+ @klass = klass
143
+ end
144
+
145
+ def ==(actual)
146
+ actual.kind_of?(@klass)
147
+ end
148
+ end
149
+
150
+ # Matches any args at all. Supports a more explicit variation of
151
+ # `object.should_receive(:message)`
152
+ #
153
+ # @example
154
+ #
155
+ # object.should_receive(:message).with(any_args)
156
+ def any_args
157
+ AnyArgsMatcher.new
158
+ end
159
+
160
+ # Matches any argument at all.
161
+ #
162
+ # @example
163
+ #
164
+ # object.should_receive(:message).with(anything)
165
+ def anything
166
+ AnyArgMatcher.new(nil)
167
+ end
168
+
169
+ # Matches no arguments.
170
+ #
171
+ # @example
172
+ #
173
+ # object.should_receive(:message).with(no_args)
174
+ def no_args
175
+ NoArgsMatcher.new
176
+ end
177
+
178
+ # Matches if the actual argument responds to the specified messages.
179
+ #
180
+ # @example
181
+ #
182
+ # object.should_receive(:message).with(duck_type(:hello))
183
+ # object.should_receive(:message).with(duck_type(:hello, :goodbye))
184
+ def duck_type(*args)
185
+ DuckTypeMatcher.new(*args)
186
+ end
187
+
188
+ # Matches a boolean value.
189
+ #
190
+ # @example
191
+ #
192
+ # object.should_receive(:message).with(boolean())
193
+ def boolean
194
+ BooleanMatcher.new(nil)
195
+ end
196
+
197
+ # Matches a hash that includes the specified key(s) or key/value pairs.
198
+ # Ignores any additional keys.
199
+ #
200
+ # @example
201
+ #
202
+ # object.should_receive(:message).with(hash_including(:key => val))
203
+ # object.should_receive(:message).with(hash_including(:key))
204
+ # object.should_receive(:message).with(hash_including(:key, :key2 => val2))
205
+ def hash_including(*args)
206
+ HashIncludingMatcher.new(anythingize_lonely_keys(*args))
207
+ end
208
+
209
+ # Matches an array that includes the specified items at least once.
210
+ # Ignores duplicates and additional values
211
+ #
212
+ # @example
213
+ #
214
+ # object.should_receive(:message).with(array_including(1,2,3))
215
+ # object.should_receive(:message).with(array_including([1,2,3]))
216
+ def array_including(*args)
217
+ actually_an_array = Array === args.first && args.count == 1 ? args.first : args
218
+ ArrayIncludingMatcher.new(actually_an_array)
219
+ end
220
+
221
+ # Matches a hash that doesn't include the specified key(s) or key/value.
222
+ #
223
+ # @example
224
+ #
225
+ # object.should_receive(:message).with(hash_excluding(:key => val))
226
+ # object.should_receive(:message).with(hash_excluding(:key))
227
+ # object.should_receive(:message).with(hash_excluding(:key, :key2 => :val2))
228
+ def hash_excluding(*args)
229
+ HashExcludingMatcher.new(anythingize_lonely_keys(*args))
230
+ end
231
+
232
+ alias_method :hash_not_including, :hash_excluding
233
+
234
+ # Matches if `arg.instance_of?(klass)`
235
+ #
236
+ # @example
237
+ #
238
+ # object.should_receive(:message).with(instance_of(Thing))
239
+ def instance_of(klass)
240
+ InstanceOf.new(klass)
241
+ end
242
+
243
+ alias_method :an_instance_of, :instance_of
244
+
245
+ # Matches if `arg.kind_of?(klass)`
246
+ # @example
247
+ #
248
+ # object.should_receive(:message).with(kind_of(Thing))
249
+ def kind_of(klass)
250
+ KindOf.new(klass)
251
+ end
252
+
253
+ alias_method :a_kind_of, :kind_of
254
+
255
+ private
256
+
257
+ def anythingize_lonely_keys(*args)
258
+ hash = args.last.class == Hash ? args.delete_at(-1) : {}
259
+ args.each { | arg | hash[arg] = anything }
260
+ hash
261
+ end
262
+ end
263
+ end
264
+ end
@@ -0,0 +1,66 @@
1
+ module RSpec
2
+ module Mocks
3
+
4
+ # Figures out the valid arity range for a method. Surprisingly non-trivial.
5
+ class ArityCalculator
6
+
7
+ def initialize(method)
8
+ @method = method
9
+ end
10
+
11
+ # @api private
12
+ def within_range?(actual)
13
+ min_arity <= actual && actual <= max_arity
14
+ end
15
+
16
+ # @api private
17
+ def range_description
18
+ return min_arity.to_s if min_arity == max_arity
19
+ return "#{min_arity} or more" if max_arity == INFINITY
20
+ "#{min_arity} to #{max_arity}"
21
+ end
22
+
23
+ private
24
+
25
+ def method
26
+ @method
27
+ end
28
+
29
+ # @api private
30
+ def self.supports_optional_and_splat_args?
31
+ Method.method_defined?(:parameters)
32
+ end
33
+
34
+ def min_arity
35
+ return method.arity if method.arity >= 0
36
+ # `~` inverts the one's complement and gives us the number of
37
+ # required arguments.
38
+ ~method.arity
39
+ end
40
+
41
+ if supports_optional_and_splat_args?
42
+ def max_arity
43
+ params = method.parameters
44
+ if params.any? {|(type, _)| type == :rest }
45
+ # Method takes a splat argument
46
+ return INFINITY
47
+ else
48
+ params.count {|(type, _)| type != :block }
49
+ end
50
+ end
51
+ else
52
+ def max_arity
53
+ # On 1.8, Method#parameters does not exist. There is no way to
54
+ # distinguish between default and splat args, so there is no way to
55
+ # have it work correctly for both default and splat args, as far as I
56
+ # can tell. The best we can do is consider it INFINITY (to be
57
+ # tolerant of splat args).
58
+ method.arity < 0 ? INFINITY : method.arity
59
+ end
60
+ end
61
+
62
+ INFINITY = 1/0.0
63
+ end
64
+ end
65
+ end
66
+
@@ -0,0 +1,111 @@
1
+ module RSpec
2
+ module Mocks
3
+ # Provides configuration options for rspec-mocks.
4
+ class Configuration
5
+
6
+ def initialize
7
+ @yield_receiver_to_any_instance_implementation_blocks = true
8
+ @verify_doubled_constant_names = false
9
+ @transfer_nested_constants = false
10
+ @verify_partial_doubles = false
11
+ end
12
+
13
+ def yield_receiver_to_any_instance_implementation_blocks?
14
+ @yield_receiver_to_any_instance_implementation_blocks
15
+ end
16
+
17
+ def yield_receiver_to_any_instance_implementation_blocks=(arg)
18
+ @yield_receiver_to_any_instance_implementation_blocks = arg
19
+ end
20
+
21
+ # Adds `stub` and `should_receive` to the given
22
+ # modules or classes. This is usually only necessary
23
+ # if you application uses some proxy classes that
24
+ # "strip themselves down" to a bare minimum set of
25
+ # methods and remove `stub` and `should_receive` in
26
+ # the process.
27
+ #
28
+ # @example
29
+ #
30
+ # RSpec.configure do |rspec|
31
+ # rspec.mock_with :rspec do |mocks|
32
+ # mocks.add_stub_and_should_receive_to Delegator
33
+ # end
34
+ # end
35
+ #
36
+ def add_stub_and_should_receive_to(*modules)
37
+ modules.each do |mod|
38
+ Syntax.enable_should(mod)
39
+ end
40
+ end
41
+
42
+ def syntax=(values)
43
+ if Array(values).include?(:expect)
44
+ Syntax.enable_expect
45
+ else
46
+ Syntax.disable_expect
47
+ end
48
+
49
+ if Array(values).include?(:should)
50
+ Syntax.enable_should
51
+ else
52
+ Syntax.disable_should
53
+ end
54
+ end
55
+
56
+ def syntax
57
+ syntaxes = []
58
+ syntaxes << :should if Syntax.should_enabled?
59
+ syntaxes << :expect if Syntax.expect_enabled?
60
+ syntaxes
61
+ end
62
+
63
+ def verify_doubled_constant_names?
64
+ !!@verify_doubled_constant_names
65
+ end
66
+
67
+ # When this is set to true, an error will be raised when
68
+ # `instance_double` or `class_double` is given the name of an undefined
69
+ # constant. You probably only want to set this when running your entire
70
+ # test suite, with all production code loaded. Setting this for an
71
+ # isolated unit test will prevent you from being able to isolate it!
72
+ def verify_doubled_constant_names=(val)
73
+ @verify_doubled_constant_names = val
74
+ end
75
+
76
+ def transfer_nested_constants?
77
+ !!@transfer_nested_constants
78
+ end
79
+
80
+ # Sets the default for the `transfer_nested_constants` option when
81
+ # stubbing constants.
82
+ def transfer_nested_constants=(val)
83
+ @transfer_nested_constants = val
84
+ end
85
+
86
+ # When set to true, partial mocks will be verified the same as object
87
+ # doubles. Any stubs will have their arity checked against the original
88
+ # method, and methods that do not exist cannot be stubbed.
89
+ def verify_partial_doubles=(val)
90
+ @verify_partial_doubles = !!val
91
+ end
92
+
93
+ def verify_partial_doubles?
94
+ @verify_partial_doubles
95
+ end
96
+
97
+ # @api private
98
+ # Resets the configured syntax to the default.
99
+ def reset_syntaxes_to_default
100
+ self.syntax = [:should, :expect]
101
+ RSpec::Mocks::Syntax.warn_about_should!
102
+ end
103
+ end
104
+
105
+ def self.configuration
106
+ @configuration ||= Configuration.new
107
+ end
108
+
109
+ configuration.reset_syntaxes_to_default
110
+ end
111
+ end
@@ -0,0 +1,203 @@
1
+ module RSpec
2
+ module Mocks
3
+ # @private
4
+ class ErrorGenerator
5
+ attr_writer :opts
6
+
7
+ def initialize(target, name)
8
+ @target = target
9
+ @name = name
10
+ end
11
+
12
+ # @private
13
+ def opts
14
+ @opts ||= {}
15
+ end
16
+
17
+ # @private
18
+ def raise_unexpected_message_error(message, *args)
19
+ __raise "#{intro} received unexpected message :#{message}#{arg_message(*args)}"
20
+ end
21
+
22
+ # @private
23
+ def raise_unexpected_message_args_error(expectation, *args)
24
+ expected_args = format_args(*expectation.expected_args)
25
+ actual_args = format_received_args(*args)
26
+ __raise "#{intro} received #{expectation.message.inspect} with unexpected arguments\n expected: #{expected_args}\n got: #{actual_args}"
27
+ end
28
+
29
+ # @private
30
+ def raise_missing_default_stub_error(expectation, *args)
31
+ expected_args = format_args(*expectation.expected_args)
32
+ actual_args = format_received_args(*args)
33
+ __raise "#{intro} received #{expectation.message.inspect} with unexpected arguments\n expected: #{expected_args}\n got: #{actual_args}\n Please stub a default value first if message might be received with other args as well. \n"
34
+ end
35
+
36
+ # @private
37
+ def raise_similar_message_args_error(expectation, *args_for_multiple_calls)
38
+ expected_args = format_args(*expectation.expected_args)
39
+ actual_args = args_for_multiple_calls.collect {|a| format_received_args(*a)}.join(", ")
40
+ __raise "#{intro} received #{expectation.message.inspect} with unexpected arguments\n expected: #{expected_args}\n got: #{actual_args}"
41
+ end
42
+
43
+ # @private
44
+ def raise_expectation_error(message, expected_received_count, argument_list_matcher, actual_received_count, expectation_count_type, *args)
45
+ expected_part = expected_part_of_expectation_error(expected_received_count, expectation_count_type, argument_list_matcher)
46
+ received_part = received_part_of_expectation_error(actual_received_count, *args)
47
+ __raise "(#{intro}).#{message}#{format_args(*args)}\n #{expected_part}\n #{received_part}"
48
+ end
49
+
50
+ # @private
51
+ def raise_unimplemented_error(doubled_module, method_name)
52
+ __raise "%s does not implement:\n %s" % [
53
+ doubled_module.description,
54
+ method_name
55
+ ]
56
+ end
57
+
58
+ # @private
59
+ def raise_arity_error(calculator, actual)
60
+ __raise "Wrong number of arguments. Expected %s, got %s." % [
61
+ calculator.range_description,
62
+ actual
63
+ ]
64
+ end
65
+
66
+ # @private
67
+ def received_part_of_expectation_error(actual_received_count, *args)
68
+ "received: #{count_message(actual_received_count)}" +
69
+ method_call_args_description(args)
70
+ end
71
+
72
+ # @private
73
+ def expected_part_of_expectation_error(expected_received_count, expectation_count_type, argument_list_matcher)
74
+ "expected: #{count_message(expected_received_count, expectation_count_type)}" +
75
+ method_call_args_description(argument_list_matcher.expected_args)
76
+ end
77
+
78
+ # @private
79
+ def method_call_args_description(args)
80
+ case args.first
81
+ when ArgumentMatchers::AnyArgsMatcher
82
+ return " with any arguments"
83
+ when ArgumentMatchers::NoArgsMatcher
84
+ return " with no arguments"
85
+ end
86
+
87
+ if args.length > 0
88
+ " with arguments: #{args.inspect.gsub(/\A\[(.+)\]\z/, '(\1)')}"
89
+ else
90
+ ""
91
+ end
92
+ end
93
+
94
+ # @private
95
+ def describe_expectation(message, expected_received_count, actual_received_count, *args)
96
+ "have received #{message}#{format_args(*args)} #{count_message(expected_received_count)}"
97
+ end
98
+
99
+ # @private
100
+ def raise_out_of_order_error(message)
101
+ __raise "#{intro} received :#{message} out of order"
102
+ end
103
+
104
+ # @private
105
+ def raise_block_failed_error(message, detail)
106
+ __raise "#{intro} received :#{message} but passed block failed with: #{detail}"
107
+ end
108
+
109
+ # @private
110
+ def raise_missing_block_error(args_to_yield)
111
+ __raise "#{intro} asked to yield |#{arg_list(*args_to_yield)}| but no block was passed"
112
+ end
113
+
114
+ # @private
115
+ def raise_wrong_arity_error(args_to_yield, arity)
116
+ __raise "#{intro} yielded |#{arg_list(*args_to_yield)}| to block with arity of #{arity}"
117
+ end
118
+
119
+ # @private
120
+ def raise_only_valid_on_a_partial_mock(method)
121
+ __raise "#{intro} is a pure mock object. `#{method}` is only " +
122
+ "available on a partial mock object."
123
+ end
124
+
125
+ # @private
126
+ def raise_expectation_on_unstubbed_method(method)
127
+ __raise "#{intro} expected to have received #{method}, but that " +
128
+ "method has not been stubbed."
129
+ end
130
+
131
+ # @private
132
+ def raise_expectation_on_mocked_method(method)
133
+ __raise "#{intro} expected to have received #{method}, but that " +
134
+ "method has been mocked instead of stubbed."
135
+ end
136
+
137
+ def self.raise_double_negation_error(wrapped_expression)
138
+ raise "Isn't life confusing enough? You've already set a " +
139
+ "negative message expectation and now you are trying to " +
140
+ "negate it again with `never`. What does an expression like " +
141
+ "`#{wrapped_expression}.not_to receive(:msg).never` even mean?"
142
+ end
143
+
144
+ private
145
+
146
+ def intro
147
+ if @name
148
+ "Double #{@name.inspect}"
149
+ elsif TestDouble === @target
150
+ "Double"
151
+ elsif Class === @target
152
+ "<#{@target.inspect} (class)>"
153
+ elsif @target
154
+ @target
155
+ else
156
+ "nil"
157
+ end
158
+ end
159
+
160
+ def __raise(message)
161
+ message = opts[:message] unless opts[:message].nil?
162
+ Kernel::raise(RSpec::Mocks::MockExpectationError, message)
163
+ end
164
+
165
+ def arg_message(*args)
166
+ " with " + format_args(*args)
167
+ end
168
+
169
+ def format_args(*args)
170
+ args.empty? ? "(no args)" : "(" + arg_list(*args) + ")"
171
+ end
172
+
173
+ def arg_list(*args)
174
+ args.collect {|arg| arg_has_valid_description(arg) ? arg.description : arg.inspect }.join(", ")
175
+ end
176
+
177
+ def arg_has_valid_description(arg)
178
+ return false unless arg.respond_to?(:description)
179
+
180
+ !arg.description.nil? && !arg.description.empty?
181
+ end
182
+
183
+ def format_received_args(*args)
184
+ args.empty? ? "(no args)" : "(" + received_arg_list(*args) + ")"
185
+ end
186
+
187
+ def received_arg_list(*args)
188
+ args.collect(&:inspect).join(", ")
189
+ end
190
+
191
+ def count_message(count, expectation_count_type=nil)
192
+ return "at least #{pretty_print(count.abs)}" if count < 0 || expectation_count_type == :at_least
193
+ return "at most #{pretty_print(count)}" if expectation_count_type == :at_most
194
+ return pretty_print(count)
195
+ end
196
+
197
+ def pretty_print(count)
198
+ "#{count} time#{count == 1 ? '' : 's'}"
199
+ end
200
+
201
+ end
202
+ end
203
+ end
@@ -0,0 +1,12 @@
1
+ module RSpec
2
+ module Mocks
3
+ # @private
4
+ class MockExpectationError < Exception
5
+ end
6
+
7
+ # @private
8
+ class AmbiguousReturnError < StandardError
9
+ end
10
+ end
11
+ end
12
+