rspec-instructure 1.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (395) hide show
  1. data/.autotest +5 -0
  2. data/.document +7 -0
  3. data/.gitignore +15 -0
  4. data/Gemfile +20 -0
  5. data/History.rdoc +1565 -0
  6. data/License.txt +22 -0
  7. data/README.rdoc +44 -0
  8. data/Rakefile +110 -0
  9. data/Ruby1.9.rdoc +31 -0
  10. data/TODO.txt +17 -0
  11. data/Upgrade.rdoc +260 -0
  12. data/bin/autospec +4 -0
  13. data/bin/spec +5 -0
  14. data/cucumber.yml +5 -0
  15. data/example_spec.rb +4 -0
  16. data/examples/failing/README.txt +11 -0
  17. data/examples/failing/diffing_spec.rb +36 -0
  18. data/examples/failing/failing_implicit_docstrings_example.rb +17 -0
  19. data/examples/failing/failure_in_after.rb +10 -0
  20. data/examples/failing/failure_in_before.rb +10 -0
  21. data/examples/failing/mocking_example.rb +38 -0
  22. data/examples/failing/mocking_with_flexmock.rb +26 -0
  23. data/examples/failing/mocking_with_mocha.rb +25 -0
  24. data/examples/failing/mocking_with_rr.rb +27 -0
  25. data/examples/failing/partial_mock_example.rb +18 -0
  26. data/examples/failing/pending_example.rb +7 -0
  27. data/examples/failing/predicate_example.rb +32 -0
  28. data/examples/failing/raising_example.rb +47 -0
  29. data/examples/failing/syntax_error_example.rb +7 -0
  30. data/examples/failing/team_spec.rb +41 -0
  31. data/examples/failing/timeout_behaviour.rb +5 -0
  32. data/examples/passing/custom_formatter.rb +11 -0
  33. data/examples/passing/custom_matchers.rb +54 -0
  34. data/examples/passing/dynamic_spec.rb +7 -0
  35. data/examples/passing/file_accessor.rb +18 -0
  36. data/examples/passing/file_accessor_spec.rb +37 -0
  37. data/examples/passing/filtered_formatter.rb +17 -0
  38. data/examples/passing/filtered_formatter_example.rb +31 -0
  39. data/examples/passing/greeter_spec.rb +30 -0
  40. data/examples/passing/helper_method_example.rb +12 -0
  41. data/examples/passing/implicit_docstrings_example.rb +16 -0
  42. data/examples/passing/io_processor.rb +8 -0
  43. data/examples/passing/io_processor_spec.rb +20 -0
  44. data/examples/passing/mocking_example.rb +25 -0
  45. data/examples/passing/multi_threaded_example_group_runner.rb +26 -0
  46. data/examples/passing/nested_classes_example.rb +35 -0
  47. data/examples/passing/options_example.rb +29 -0
  48. data/examples/passing/options_formatter.rb +20 -0
  49. data/examples/passing/partial_mock_example.rb +27 -0
  50. data/examples/passing/pending_example.rb +18 -0
  51. data/examples/passing/predicate_example.rb +25 -0
  52. data/examples/passing/shared_example_group_example.rb +43 -0
  53. data/examples/passing/shared_stack_examples.rb +36 -0
  54. data/examples/passing/simple_matcher_example.rb +29 -0
  55. data/examples/passing/stack.rb +36 -0
  56. data/examples/passing/stack_spec.rb +63 -0
  57. data/examples/passing/stack_spec_with_nested_example_groups.rb +66 -0
  58. data/examples/passing/stubbing_example.rb +67 -0
  59. data/examples/passing/yielding_example.rb +31 -0
  60. data/examples/ruby1.9.compatibility/access_to_constants_spec.rb +85 -0
  61. data/features-pending/cli/conditional_exclusion.feature +39 -0
  62. data/features-pending/heckle/heckle.feature +56 -0
  63. data/features/before_and_after_blocks/before_and_after_blocks.feature +167 -0
  64. data/features/command_line/line_number_option.feature +56 -0
  65. data/features/command_line/line_number_option_with_example_with_no_name.feature +22 -0
  66. data/features/example_groups/define_example_attribute.feature +41 -0
  67. data/features/example_groups/example_group_with_should_methods.feature +29 -0
  68. data/features/example_groups/implicit_docstrings.feature +59 -0
  69. data/features/example_groups/nested_groups.feature +32 -0
  70. data/features/expectations/customized_message.feature +54 -0
  71. data/features/expectations/expect_change.feature +65 -0
  72. data/features/expectations/expect_error.feature +44 -0
  73. data/features/extensions/custom_example_group.feature +19 -0
  74. data/features/formatters/custom_formatter.feature +30 -0
  75. data/features/formatters/nested_formatter.feature +32 -0
  76. data/features/interop/cucumber_stubs_dont_leak.feature +11 -0
  77. data/features/interop/examples_and_tests_together.feature +84 -0
  78. data/features/interop/rspec_output.feature +25 -0
  79. data/features/interop/test_but_not_test_unit.feature +26 -0
  80. data/features/interop/test_case_with_should_methods.feature +46 -0
  81. data/features/load_paths/add_lib_to_load_path.feature +20 -0
  82. data/features/load_paths/add_spec_to_load_path.feature +20 -0
  83. data/features/matchers/define_diffable_matcher.feature +26 -0
  84. data/features/matchers/define_matcher.feature +179 -0
  85. data/features/matchers/define_matcher_outside_rspec.feature +37 -0
  86. data/features/matchers/define_matcher_with_fluent_interface.feature +48 -0
  87. data/features/matchers/define_wrapped_matcher.feature +56 -0
  88. data/features/matchers/match_unless_raises.feature +60 -0
  89. data/features/matchers/match_unless_raises_unexpected_error.feature +39 -0
  90. data/features/mock_framework_integration/use_flexmock.feature +27 -0
  91. data/features/mock_framework_integration/use_mocha.feature +27 -0
  92. data/features/mock_framework_integration/use_rr.feature +27 -0
  93. data/features/mocks/block_local_expectations.feature +62 -0
  94. data/features/mocks/mix_stubs_and_mocks.feature +22 -0
  95. data/features/mocks/stub_implementation.feature +26 -0
  96. data/features/pending/pending_examples.feature +81 -0
  97. data/features/runner/specify_line_number.feature +32 -0
  98. data/features/spec_helper/spec_helper.feature +25 -0
  99. data/features/step_definitions/running_rspec_steps.rb +52 -0
  100. data/features/step_definitions/stubbing_steps.rb +16 -0
  101. data/features/subject/explicit_subject.feature +31 -0
  102. data/features/subject/implicit_subject.feature +43 -0
  103. data/features/support/env.rb +83 -0
  104. data/features/support/matchers/smart_match.rb +31 -0
  105. data/init.rb +9 -0
  106. data/lib/autotest/discover.rb +3 -0
  107. data/lib/autotest/rspec.rb +54 -0
  108. data/lib/spec.rb +8 -0
  109. data/lib/spec/adapters/mock_frameworks/flexmock.rb +24 -0
  110. data/lib/spec/adapters/mock_frameworks/mocha.rb +25 -0
  111. data/lib/spec/adapters/mock_frameworks/rr.rb +22 -0
  112. data/lib/spec/adapters/mock_frameworks/rspec.rb +21 -0
  113. data/lib/spec/autorun.rb +3 -0
  114. data/lib/spec/deprecation.rb +41 -0
  115. data/lib/spec/dsl.rb +1 -0
  116. data/lib/spec/dsl/main.rb +93 -0
  117. data/lib/spec/example.rb +164 -0
  118. data/lib/spec/example/args_and_options.rb +27 -0
  119. data/lib/spec/example/before_and_after_hooks.rb +93 -0
  120. data/lib/spec/example/errors.rb +25 -0
  121. data/lib/spec/example/example_group.rb +10 -0
  122. data/lib/spec/example/example_group_factory.rb +82 -0
  123. data/lib/spec/example/example_group_hierarchy.rb +53 -0
  124. data/lib/spec/example/example_group_methods.rb +287 -0
  125. data/lib/spec/example/example_group_proxy.rb +61 -0
  126. data/lib/spec/example/example_matcher.rb +43 -0
  127. data/lib/spec/example/example_methods.rb +152 -0
  128. data/lib/spec/example/example_proxy.rb +41 -0
  129. data/lib/spec/example/module_reopening_fix.rb +43 -0
  130. data/lib/spec/example/pending.rb +18 -0
  131. data/lib/spec/example/predicate_matchers.rb +46 -0
  132. data/lib/spec/example/shared_example_group.rb +59 -0
  133. data/lib/spec/example/subject.rb +114 -0
  134. data/lib/spec/expectations.rb +35 -0
  135. data/lib/spec/expectations/errors.rb +12 -0
  136. data/lib/spec/expectations/extensions.rb +1 -0
  137. data/lib/spec/expectations/extensions/kernel.rb +52 -0
  138. data/lib/spec/expectations/fail_with.rb +45 -0
  139. data/lib/spec/expectations/handler.rb +50 -0
  140. data/lib/spec/extensions/instance_exec.rb +31 -0
  141. data/lib/spec/interop/test.rb +44 -0
  142. data/lib/spec/interop/test/unit/autorunner.rb +6 -0
  143. data/lib/spec/interop/test/unit/testcase.rb +56 -0
  144. data/lib/spec/interop/test/unit/testresult.rb +6 -0
  145. data/lib/spec/interop/test/unit/testsuite_adapter.rb +36 -0
  146. data/lib/spec/interop/test/unit/ui/console/testrunner.rb +61 -0
  147. data/lib/spec/matchers.rb +214 -0
  148. data/lib/spec/matchers/be.rb +249 -0
  149. data/lib/spec/matchers/be_close.rb +32 -0
  150. data/lib/spec/matchers/be_instance_of.rb +26 -0
  151. data/lib/spec/matchers/be_kind_of.rb +26 -0
  152. data/lib/spec/matchers/change.rb +151 -0
  153. data/lib/spec/matchers/compatibility.rb +14 -0
  154. data/lib/spec/matchers/dsl.rb +20 -0
  155. data/lib/spec/matchers/eql.rb +42 -0
  156. data/lib/spec/matchers/equal.rb +53 -0
  157. data/lib/spec/matchers/errors.rb +5 -0
  158. data/lib/spec/matchers/exist.rb +16 -0
  159. data/lib/spec/matchers/generated_descriptions.rb +36 -0
  160. data/lib/spec/matchers/has.rb +35 -0
  161. data/lib/spec/matchers/have.rb +152 -0
  162. data/lib/spec/matchers/include.rb +44 -0
  163. data/lib/spec/matchers/match.rb +21 -0
  164. data/lib/spec/matchers/match_array.rb +71 -0
  165. data/lib/spec/matchers/matcher.rb +132 -0
  166. data/lib/spec/matchers/method_missing.rb +9 -0
  167. data/lib/spec/matchers/operator_matcher.rb +83 -0
  168. data/lib/spec/matchers/pretty.rb +37 -0
  169. data/lib/spec/matchers/raise_exception.rb +131 -0
  170. data/lib/spec/matchers/respond_to.rb +71 -0
  171. data/lib/spec/matchers/satisfy.rb +47 -0
  172. data/lib/spec/matchers/simple_matcher.rb +134 -0
  173. data/lib/spec/matchers/throw_symbol.rb +100 -0
  174. data/lib/spec/matchers/wrap_expectation.rb +55 -0
  175. data/lib/spec/mocks.rb +200 -0
  176. data/lib/spec/mocks/argument_expectation.rb +51 -0
  177. data/lib/spec/mocks/argument_matchers.rb +237 -0
  178. data/lib/spec/mocks/error_generator.rb +92 -0
  179. data/lib/spec/mocks/errors.rb +10 -0
  180. data/lib/spec/mocks/example_methods.rb +69 -0
  181. data/lib/spec/mocks/extensions.rb +1 -0
  182. data/lib/spec/mocks/extensions/object.rb +3 -0
  183. data/lib/spec/mocks/framework.rb +15 -0
  184. data/lib/spec/mocks/message_expectation.rb +344 -0
  185. data/lib/spec/mocks/methods.rb +94 -0
  186. data/lib/spec/mocks/mock.rb +71 -0
  187. data/lib/spec/mocks/order_group.rb +29 -0
  188. data/lib/spec/mocks/proxy.rb +254 -0
  189. data/lib/spec/mocks/space.rb +28 -0
  190. data/lib/spec/rake/spectask.rb +230 -0
  191. data/lib/spec/rake/verify_rcov.rb +52 -0
  192. data/lib/spec/ruby.rb +9 -0
  193. data/lib/spec/runner.rb +66 -0
  194. data/lib/spec/runner/backtrace_tweaker.rb +78 -0
  195. data/lib/spec/runner/class_and_arguments_parser.rb +14 -0
  196. data/lib/spec/runner/command_line.rb +15 -0
  197. data/lib/spec/runner/configuration.rb +202 -0
  198. data/lib/spec/runner/differs/default.rb +93 -0
  199. data/lib/spec/runner/differs/load-diff-lcs.rb +12 -0
  200. data/lib/spec/runner/drb_command_line.rb +32 -0
  201. data/lib/spec/runner/example_group_runner.rb +62 -0
  202. data/lib/spec/runner/extensions/kernel.rb +9 -0
  203. data/lib/spec/runner/formatter/base_formatter.rb +139 -0
  204. data/lib/spec/runner/formatter/base_text_formatter.rb +142 -0
  205. data/lib/spec/runner/formatter/failing_example_groups_formatter.rb +25 -0
  206. data/lib/spec/runner/formatter/failing_examples_formatter.rb +20 -0
  207. data/lib/spec/runner/formatter/html_formatter.rb +338 -0
  208. data/lib/spec/runner/formatter/nested_text_formatter.rb +50 -0
  209. data/lib/spec/runner/formatter/no_op_method_missing.rb +21 -0
  210. data/lib/spec/runner/formatter/profile_formatter.rb +47 -0
  211. data/lib/spec/runner/formatter/progress_bar_formatter.rb +33 -0
  212. data/lib/spec/runner/formatter/silent_formatter.rb +10 -0
  213. data/lib/spec/runner/formatter/snippet_extractor.rb +52 -0
  214. data/lib/spec/runner/formatter/specdoc_formatter.rb +33 -0
  215. data/lib/spec/runner/formatter/text_mate_formatter.rb +16 -0
  216. data/lib/spec/runner/heckle_runner.rb +77 -0
  217. data/lib/spec/runner/heckle_runner_unsupported.rb +10 -0
  218. data/lib/spec/runner/line_number_query.rb +78 -0
  219. data/lib/spec/runner/option_parser.rb +225 -0
  220. data/lib/spec/runner/options.rb +406 -0
  221. data/lib/spec/runner/reporter.rb +171 -0
  222. data/lib/spec/stubs/cucumber.rb +5 -0
  223. data/lib/spec/test/unit.rb +10 -0
  224. data/lib/spec/version.rb +14 -0
  225. data/resources/helpers/cmdline.rb +8 -0
  226. data/resources/rake/examples.rake +7 -0
  227. data/resources/rake/examples_with_rcov.rake +9 -0
  228. data/resources/rake/failing_examples_with_html.rake +9 -0
  229. data/resources/rake/verify_rcov.rake +7 -0
  230. data/rspec.gemspec +26 -0
  231. data/spec/README.jruby +15 -0
  232. data/spec/autotest/autotest_helper.rb +8 -0
  233. data/spec/autotest/autotest_matchers.rb +38 -0
  234. data/spec/autotest/discover_spec.rb +8 -0
  235. data/spec/autotest/failed_results_re_spec.rb +31 -0
  236. data/spec/autotest/rspec_spec.rb +126 -0
  237. data/spec/ruby_forker.rb +13 -0
  238. data/spec/spec.opts +6 -0
  239. data/spec/spec/dsl/main_spec.rb +103 -0
  240. data/spec/spec/example/example_group_class_definition_spec.rb +51 -0
  241. data/spec/spec/example/example_group_factory_spec.rb +180 -0
  242. data/spec/spec/example/example_group_methods_spec.rb +778 -0
  243. data/spec/spec/example/example_group_proxy_spec.rb +107 -0
  244. data/spec/spec/example/example_group_spec.rb +632 -0
  245. data/spec/spec/example/example_matcher_spec.rb +85 -0
  246. data/spec/spec/example/example_methods_spec.rb +162 -0
  247. data/spec/spec/example/example_proxy_spec.rb +57 -0
  248. data/spec/spec/example/helper_method_spec.rb +24 -0
  249. data/spec/spec/example/nested_example_group_spec.rb +71 -0
  250. data/spec/spec/example/pending_module_spec.rb +58 -0
  251. data/spec/spec/example/predicate_matcher_spec.rb +41 -0
  252. data/spec/spec/example/shared_example_group_spec.rb +257 -0
  253. data/spec/spec/example/subclassing_example_group_spec.rb +25 -0
  254. data/spec/spec/example/subject_spec.rb +110 -0
  255. data/spec/spec/expectations/differs/default_spec.rb +194 -0
  256. data/spec/spec/expectations/extensions/kernel_spec.rb +45 -0
  257. data/spec/spec/expectations/fail_with_spec.rb +96 -0
  258. data/spec/spec/expectations/handler_spec.rb +206 -0
  259. data/spec/spec/expectations/wrap_expectation_spec.rb +31 -0
  260. data/spec/spec/interop/test/unit/resources/spec_that_fails.rb +10 -0
  261. data/spec/spec/interop/test/unit/resources/spec_that_passes.rb +10 -0
  262. data/spec/spec/interop/test/unit/resources/spec_with_errors.rb +10 -0
  263. data/spec/spec/interop/test/unit/resources/spec_with_options_hash.rb +13 -0
  264. data/spec/spec/interop/test/unit/resources/test_case_that_fails.rb +10 -0
  265. data/spec/spec/interop/test/unit/resources/test_case_that_passes.rb +10 -0
  266. data/spec/spec/interop/test/unit/resources/test_case_with_errors.rb +10 -0
  267. data/spec/spec/interop/test/unit/resources/test_case_with_various_names.rb +22 -0
  268. data/spec/spec/interop/test/unit/resources/testsuite_adapter_spec_with_test_unit.rb +38 -0
  269. data/spec/spec/interop/test/unit/spec_spec.rb +48 -0
  270. data/spec/spec/interop/test/unit/test_unit_spec_helper.rb +18 -0
  271. data/spec/spec/interop/test/unit/testcase_spec.rb +50 -0
  272. data/spec/spec/interop/test/unit/testsuite_adapter_spec.rb +9 -0
  273. data/spec/spec/matchers/be_close_spec.rb +50 -0
  274. data/spec/spec/matchers/be_instance_of_spec.rb +36 -0
  275. data/spec/spec/matchers/be_kind_of_spec.rb +33 -0
  276. data/spec/spec/matchers/be_spec.rb +460 -0
  277. data/spec/spec/matchers/change_spec.rb +349 -0
  278. data/spec/spec/matchers/compatibility_spec.rb +28 -0
  279. data/spec/spec/matchers/description_generation_spec.rb +160 -0
  280. data/spec/spec/matchers/dsl_spec.rb +34 -0
  281. data/spec/spec/matchers/eql_spec.rb +33 -0
  282. data/spec/spec/matchers/equal_spec.rb +57 -0
  283. data/spec/spec/matchers/exist_spec.rb +65 -0
  284. data/spec/spec/matchers/has_spec.rb +190 -0
  285. data/spec/spec/matchers/have_spec.rb +381 -0
  286. data/spec/spec/matchers/include_spec.rb +88 -0
  287. data/spec/spec/matchers/match_array_spec.rb +115 -0
  288. data/spec/spec/matchers/match_spec.rb +57 -0
  289. data/spec/spec/matchers/matcher_spec.rb +289 -0
  290. data/spec/spec/matchers/matchers_spec.rb +2 -0
  291. data/spec/spec/matchers/operator_matcher_spec.rb +191 -0
  292. data/spec/spec/matchers/pretty_spec.rb +22 -0
  293. data/spec/spec/matchers/raise_exception_spec.rb +345 -0
  294. data/spec/spec/matchers/respond_to_spec.rb +116 -0
  295. data/spec/spec/matchers/satisfy_spec.rb +36 -0
  296. data/spec/spec/matchers/simple_matcher_spec.rb +100 -0
  297. data/spec/spec/matchers/throw_symbol_spec.rb +121 -0
  298. data/spec/spec/mocks/and_yield_spec.rb +117 -0
  299. data/spec/spec/mocks/any_number_of_times_spec.rb +36 -0
  300. data/spec/spec/mocks/argument_expectation_spec.rb +23 -0
  301. data/spec/spec/mocks/argument_matchers_spec.rb +19 -0
  302. data/spec/spec/mocks/at_least_spec.rb +97 -0
  303. data/spec/spec/mocks/at_most_spec.rb +93 -0
  304. data/spec/spec/mocks/bug_report_10260_spec.rb +8 -0
  305. data/spec/spec/mocks/bug_report_10263_spec.rb +27 -0
  306. data/spec/spec/mocks/bug_report_1049_spec.rb +30 -0
  307. data/spec/spec/mocks/bug_report_11545_spec.rb +32 -0
  308. data/spec/spec/mocks/bug_report_15719_spec.rb +30 -0
  309. data/spec/spec/mocks/bug_report_496_spec.rb +17 -0
  310. data/spec/spec/mocks/bug_report_600_spec.rb +22 -0
  311. data/spec/spec/mocks/bug_report_7611_spec.rb +19 -0
  312. data/spec/spec/mocks/bug_report_7805_spec.rb +22 -0
  313. data/spec/spec/mocks/bug_report_8165_spec.rb +31 -0
  314. data/spec/spec/mocks/bug_report_8302_spec.rb +26 -0
  315. data/spec/spec/mocks/bug_report_830_spec.rb +21 -0
  316. data/spec/spec/mocks/bug_report_957_spec.rb +22 -0
  317. data/spec/spec/mocks/double_spec.rb +12 -0
  318. data/spec/spec/mocks/failing_argument_matchers_spec.rb +95 -0
  319. data/spec/spec/mocks/hash_including_matcher_spec.rb +90 -0
  320. data/spec/spec/mocks/hash_not_including_matcher_spec.rb +67 -0
  321. data/spec/spec/mocks/mock_ordering_spec.rb +94 -0
  322. data/spec/spec/mocks/mock_space_spec.rb +54 -0
  323. data/spec/spec/mocks/mock_spec.rb +601 -0
  324. data/spec/spec/mocks/multiple_return_value_spec.rb +113 -0
  325. data/spec/spec/mocks/nil_expectation_warning_spec.rb +53 -0
  326. data/spec/spec/mocks/null_object_mock_spec.rb +54 -0
  327. data/spec/spec/mocks/once_counts_spec.rb +53 -0
  328. data/spec/spec/mocks/options_hash_spec.rb +35 -0
  329. data/spec/spec/mocks/partial_mock_spec.rb +164 -0
  330. data/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb +66 -0
  331. data/spec/spec/mocks/passing_argument_matchers_spec.rb +145 -0
  332. data/spec/spec/mocks/precise_counts_spec.rb +52 -0
  333. data/spec/spec/mocks/record_messages_spec.rb +26 -0
  334. data/spec/spec/mocks/stub_chain_spec.rb +42 -0
  335. data/spec/spec/mocks/stub_implementation_spec.rb +31 -0
  336. data/spec/spec/mocks/stub_spec.rb +203 -0
  337. data/spec/spec/mocks/stubbed_message_expectations_spec.rb +26 -0
  338. data/spec/spec/mocks/twice_counts_spec.rb +67 -0
  339. data/spec/spec/mocks/unstub_spec.rb +127 -0
  340. data/spec/spec/package/bin_spec_spec.rb +16 -0
  341. data/spec/spec/rake/spectask_spec.rb +150 -0
  342. data/spec/spec/runner/class_and_argument_parser_spec.rb +23 -0
  343. data/spec/spec/runner/command_line_spec.rb +162 -0
  344. data/spec/spec/runner/configuration_spec.rb +320 -0
  345. data/spec/spec/runner/drb_command_line_spec.rb +146 -0
  346. data/spec/spec/runner/empty_file.txt +0 -0
  347. data/spec/spec/runner/example_group_runner_spec.rb +26 -0
  348. data/spec/spec/runner/examples.txt +2 -0
  349. data/spec/spec/runner/failed.txt +3 -0
  350. data/spec/spec/runner/formatter/base_formatter_spec.rb +30 -0
  351. data/spec/spec/runner/formatter/base_text_formatter_spec.rb +113 -0
  352. data/spec/spec/runner/formatter/failing_example_groups_formatter_spec.rb +45 -0
  353. data/spec/spec/runner/formatter/failing_examples_formatter_spec.rb +33 -0
  354. data/spec/spec/runner/formatter/html_formatted-1.8.6-jruby.html +377 -0
  355. data/spec/spec/runner/formatter/html_formatted-1.8.6.html +377 -0
  356. data/spec/spec/runner/formatter/html_formatted-1.8.7.html +377 -0
  357. data/spec/spec/runner/formatter/html_formatted-1.9.1.html +377 -0
  358. data/spec/spec/runner/formatter/html_formatted-1.9.2.html +377 -0
  359. data/spec/spec/runner/formatter/html_formatter_spec.rb +118 -0
  360. data/spec/spec/runner/formatter/nested_text_formatter_spec.rb +329 -0
  361. data/spec/spec/runner/formatter/profile_formatter_spec.rb +70 -0
  362. data/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +149 -0
  363. data/spec/spec/runner/formatter/snippet_extractor_spec.rb +18 -0
  364. data/spec/spec/runner/formatter/specdoc_formatter_spec.rb +159 -0
  365. data/spec/spec/runner/formatter/text_mate_formatted-1.8.6-jruby.html +371 -0
  366. data/spec/spec/runner/formatter/text_mate_formatted-1.8.6.html +371 -0
  367. data/spec/spec/runner/formatter/text_mate_formatted-1.8.7.html +371 -0
  368. data/spec/spec/runner/formatter/text_mate_formatted-1.9.1.html +371 -0
  369. data/spec/spec/runner/formatter/text_mate_formatted-1.9.2.html +371 -0
  370. data/spec/spec/runner/formatter/text_mate_formatter_spec.rb +106 -0
  371. data/spec/spec/runner/heckle_runner_spec.rb +78 -0
  372. data/spec/spec/runner/heckler_spec.rb +20 -0
  373. data/spec/spec/runner/line_number_query/line_number_query_fixture.rb +70 -0
  374. data/spec/spec/runner/line_number_query_spec.rb +129 -0
  375. data/spec/spec/runner/noisy_backtrace_tweaker_spec.rb +51 -0
  376. data/spec/spec/runner/option_parser_spec.rb +552 -0
  377. data/spec/spec/runner/options_spec.rb +554 -0
  378. data/spec/spec/runner/output_one_time_fixture.rb +7 -0
  379. data/spec/spec/runner/output_one_time_fixture_runner.rb +7 -0
  380. data/spec/spec/runner/output_one_time_spec.rb +15 -0
  381. data/spec/spec/runner/quiet_backtrace_tweaker_spec.rb +123 -0
  382. data/spec/spec/runner/reporter_spec.rb +244 -0
  383. data/spec/spec/runner/resources/a_bar.rb +0 -0
  384. data/spec/spec/runner/resources/a_foo.rb +0 -0
  385. data/spec/spec/runner/resources/a_spec.rb +1 -0
  386. data/spec/spec/runner/resources/custom_example_group_runner.rb +14 -0
  387. data/spec/spec/runner/resources/utf8_encoded.rb +8 -0
  388. data/spec/spec/runner/spec.opts +2 -0
  389. data/spec/spec/runner/spec_drb.opts +2 -0
  390. data/spec/spec/runner/spec_spaced.opts +2 -0
  391. data/spec/spec/runner_spec.rb +13 -0
  392. data/spec/spec_helper.rb +113 -0
  393. data/spec/support/macros.rb +29 -0
  394. data/spec/support/spec_classes.rb +133 -0
  395. metadata +727 -0
@@ -0,0 +1,71 @@
1
+ module Spec
2
+ module Matchers
3
+
4
+ class RespondTo #:nodoc:
5
+ def initialize(*names)
6
+ @names = names
7
+ @expected_arity = nil
8
+ @names_not_responded_to = []
9
+ end
10
+
11
+ def matches?(actual)
12
+ @actual = actual
13
+ @names.each do |name|
14
+ @names_not_responded_to << name unless actual.respond_to?(name) && matches_arity?(actual, name)
15
+ end
16
+ return @names_not_responded_to.empty?
17
+ end
18
+
19
+ def failure_message_for_should
20
+ "expected #{@actual.inspect} to respond to #{@names_not_responded_to.collect {|name| name.inspect }.join(', ')}#{with_arity}"
21
+ end
22
+
23
+ def failure_message_for_should_not
24
+ "expected #{@actual.inspect} not to respond to #{@names.collect {|name| name.inspect }.join(', ')}"
25
+ end
26
+
27
+ def description
28
+ "respond to #{pp_names}#{with_arity}"
29
+ end
30
+
31
+ def with(n)
32
+ @expected_arity = n
33
+ self
34
+ end
35
+
36
+ def argument
37
+ self
38
+ end
39
+ alias :arguments :argument
40
+
41
+ private
42
+
43
+ def matches_arity?(actual, name)
44
+ @expected_arity.nil?? true : @expected_arity == actual.method(name).arity
45
+ end
46
+
47
+ def with_arity
48
+ @expected_arity.nil?? "" :
49
+ " with #{@expected_arity} argument#{@expected_arity == 1 ? '' : 's'}"
50
+ end
51
+
52
+ def pp_names
53
+ # Ruby 1.9 returns the same thing for array.to_s as array.inspect, so just use array.inspect here
54
+ @names.length == 1 ? "##{@names.first}" : @names.inspect
55
+ end
56
+ end
57
+
58
+ # :call-seq:
59
+ # should respond_to(*names)
60
+ # should_not respond_to(*names)
61
+ #
62
+ # Matches if the target object responds to all of the names
63
+ # provided. Names can be Strings or Symbols.
64
+ #
65
+ # == Examples
66
+ #
67
+ def respond_to(*names)
68
+ Matchers::RespondTo.new(*names)
69
+ end
70
+ end
71
+ end
@@ -0,0 +1,47 @@
1
+ module Spec
2
+ module Matchers
3
+
4
+ class Satisfy #:nodoc:
5
+ def initialize(&block)
6
+ @block = block
7
+ end
8
+
9
+ def matches?(actual, &block)
10
+ @block = block if block
11
+ @actual = actual
12
+ @block.call(actual)
13
+ end
14
+
15
+ def failure_message_for_should
16
+ "expected #{@actual} to satisfy block"
17
+ end
18
+
19
+ def failure_message_for_should_not
20
+ "expected #{@actual} not to satisfy block"
21
+ end
22
+ end
23
+
24
+ # :call-seq:
25
+ # should satisfy {}
26
+ # should_not satisfy {}
27
+ #
28
+ # Passes if the submitted block returns true. Yields target to the
29
+ # block.
30
+ #
31
+ # Generally speaking, this should be thought of as a last resort when
32
+ # you can't find any other way to specify the behaviour you wish to
33
+ # specify.
34
+ #
35
+ # If you do find yourself in such a situation, you could always write
36
+ # a custom matcher, which would likely make your specs more expressive.
37
+ #
38
+ # == Examples
39
+ #
40
+ # 5.should satisfy { |n|
41
+ # n > 3
42
+ # }
43
+ def satisfy(&block)
44
+ Matchers::Satisfy.new(&block)
45
+ end
46
+ end
47
+ end
@@ -0,0 +1,134 @@
1
+ module Spec
2
+ module Matchers
3
+ class SimpleMatcher
4
+ attr_writer :failure_message, :negative_failure_message, :description
5
+
6
+ def initialize(description, &match_block)
7
+ @description = description
8
+ @match_block = match_block
9
+ @failure_message = @negative_failure_message = nil
10
+ end
11
+
12
+ def matches?(given)
13
+ @given = given
14
+ case @match_block.arity
15
+ when 2
16
+ @match_block.call(@given, self)
17
+ else
18
+ @match_block.call(@given)
19
+ end
20
+ end
21
+
22
+ def description
23
+ @description || explanation
24
+ end
25
+
26
+ def failure_message_for_should
27
+ @failure_message || (@description.nil? ? explanation : %[expected #{@description.inspect} but got #{@given.inspect}])
28
+ end
29
+
30
+ def failure_message_for_should_not
31
+ @negative_failure_message || (@description.nil? ? explanation : %[expected not to get #{@description.inspect}, but got #{@given.inspect}])
32
+ end
33
+
34
+ def explanation
35
+ "No description provided. See RDoc for simple_matcher()"
36
+ end
37
+ end
38
+
39
+ # simple_matcher makes it easy for you to create your own custom matchers
40
+ # in just a few lines of code when you don't need all the power of a
41
+ # completely custom matcher object.
42
+ #
43
+ # The <tt>description</tt> argument will appear as part of any failure
44
+ # message, and is also the source for auto-generated descriptions.
45
+ #
46
+ # The <tt>match_block</tt> can have an arity of 1 or 2. The first block
47
+ # argument will be the given value. The second, if the block accepts it
48
+ # will be the matcher itself, giving you access to set custom failure
49
+ # messages in favor of the defaults.
50
+ #
51
+ # The <tt>match_block</tt> should return a boolean: <tt>true</tt>
52
+ # indicates a match, which will pass if you use <tt>should</tt> and fail
53
+ # if you use <tt>should_not</tt>. false (or nil) indicates no match,
54
+ # which will do the reverse: fail if you use <tt>should</tt> and pass if
55
+ # you use <tt>should_not</tt>.
56
+ #
57
+ # An error in the <tt>match_block</tt> will bubble up, resulting in a
58
+ # failure.
59
+ #
60
+ # == Example with default messages
61
+ #
62
+ # def be_even
63
+ # simple_matcher("an even number") { |given| given % 2 == 0 }
64
+ # end
65
+ #
66
+ # describe 2 do
67
+ # it "should be even" do
68
+ # 2.should be_even
69
+ # end
70
+ # end
71
+ #
72
+ # Given an odd number, this example would produce an error message stating:
73
+ # expected "an even number", got 3.
74
+ #
75
+ # Unfortunately, if you're a fan of auto-generated descriptions, this will
76
+ # produce "should an even number." Not the most desirable result. You can
77
+ # control that using custom messages:
78
+ #
79
+ # == Example with custom messages
80
+ #
81
+ # def rhyme_with(expected)
82
+ # simple_matcher("rhyme with #{expected.inspect}") do |given, matcher|
83
+ # matcher.failure_message = "expected #{given.inspect} to rhyme with #{expected.inspect}"
84
+ # matcher.negative_failure_message = "expected #{given.inspect} not to rhyme with #{expected.inspect}"
85
+ # given.rhymes_with? expected
86
+ # end
87
+ # end
88
+ #
89
+ # # OR
90
+ #
91
+ # def rhyme_with(expected)
92
+ # simple_matcher do |given, matcher|
93
+ # matcher.description = "rhyme with #{expected.inspect}"
94
+ # matcher.failure_message = "expected #{given.inspect} to rhyme with #{expected.inspect}"
95
+ # matcher.negative_failure_message = "expected #{given.inspect} not to rhyme with #{expected.inspect}"
96
+ # given.rhymes_with? expected
97
+ # end
98
+ # end
99
+ #
100
+ # describe "pecan" do
101
+ # it "should rhyme with 'be gone'" do
102
+ # nut = "pecan"
103
+ # nut.extend Rhymer
104
+ # nut.should rhyme_with("be gone")
105
+ # end
106
+ # end
107
+ #
108
+ # The resulting messages would be:
109
+ # description: rhyme with "be gone"
110
+ # failure_message: expected "pecan" to rhyme with "be gone"
111
+ # negative failure_message: expected "pecan" not to rhyme with "be gone"
112
+ #
113
+ # == Wrapped Expectations
114
+ #
115
+ # Because errors will bubble up, it is possible to wrap other expectations
116
+ # in a SimpleMatcher.
117
+ #
118
+ # def be_even
119
+ # simple_matcher("an even number") { |given| (given % 2).should == 0 }
120
+ # end
121
+ #
122
+ # BE VERY CAREFUL when you do this. Only use wrapped expectations for
123
+ # matchers that will always be used in only the positive
124
+ # (<tt>should</tt>) or negative (<tt>should_not</tt>), but not both.
125
+ # The reason is that is you wrap a <tt>should</tt> and call the wrapper
126
+ # with <tt>should_not</tt>, the correct result (the <tt>should</tt>
127
+ # failing), will fail when you want it to pass.
128
+ #
129
+ def simple_matcher(description=nil, &match_block)
130
+ Spec.deprecate("simple_matcher", "Matcher DSL (http://rspec.rubyforge.org/rspec/1.3.0/classes/Spec/Matchers.html)")
131
+ SimpleMatcher.new(description, &match_block)
132
+ end
133
+ end
134
+ end
@@ -0,0 +1,100 @@
1
+ module Spec
2
+ module Matchers
3
+
4
+ class ThrowSymbol #:nodoc:
5
+ def initialize(expected_symbol = nil, expected_arg=nil)
6
+ @expected_symbol = expected_symbol
7
+ @expected_arg = expected_arg
8
+ @caught_symbol = @caught_arg = nil
9
+ end
10
+
11
+ def matches?(given_proc)
12
+ begin
13
+ if @expected_symbol.nil?
14
+ given_proc.call
15
+ else
16
+ @caught_arg = catch :proc_did_not_throw_anything do
17
+ catch @expected_symbol do
18
+ given_proc.call
19
+ throw :proc_did_not_throw_anything, :nothing_thrown
20
+ end
21
+ end
22
+ @caught_symbol = @expected_symbol unless @caught_arg == :nothing_thrown
23
+ end
24
+
25
+ # Ruby 1.8 uses NameError with `symbol'
26
+ # Ruby 1.9 uses ArgumentError with :symbol
27
+ rescue NameError, ArgumentError => e
28
+ raise e unless e.message =~ /uncaught throw (`|\:)([a-zA-Z0-9_]*)(')?/
29
+ @caught_symbol = $2.to_sym
30
+ end
31
+ if @expected_symbol.nil?
32
+ !@caught_symbol.nil?
33
+ elsif @expected_arg.nil?
34
+ @caught_symbol == @expected_symbol
35
+ else
36
+ (@caught_symbol == @expected_symbol) & (@caught_arg == @expected_arg)
37
+ end
38
+ end
39
+
40
+ def failure_message_for_should
41
+ if @caught_symbol
42
+ "expected #{expected}, got #{@caught_symbol.inspect}"
43
+ else
44
+ "expected #{expected} but nothing was thrown"
45
+ end
46
+ end
47
+
48
+ def failure_message_for_should_not
49
+ if @expected_symbol
50
+ "expected #{expected} not to be thrown"
51
+ else
52
+ "expected no Symbol, got :#{@caught_symbol}"
53
+ end
54
+ end
55
+
56
+ def description
57
+ "throw #{expected}"
58
+ end
59
+
60
+ private
61
+
62
+ def expected
63
+ @expected_symbol.nil? ? "a Symbol" : "#{@expected_symbol.inspect}#{args}"
64
+ end
65
+
66
+ def args
67
+ @expected_arg.nil? ? "" : " with #{@expected_arg.inspect}"
68
+ end
69
+
70
+ end
71
+
72
+ # :call-seq:
73
+ # should throw_symbol()
74
+ # should throw_symbol(:sym)
75
+ # should throw_symbol(:sym, arg)
76
+ # should_not throw_symbol()
77
+ # should_not throw_symbol(:sym)
78
+ # should_not throw_symbol(:sym, arg)
79
+ #
80
+ # Given no argument, matches if a proc throws any Symbol.
81
+ #
82
+ # Given a Symbol, matches if the given proc throws the specified Symbol.
83
+ #
84
+ # Given a Symbol and an arg, matches if the given proc throws the
85
+ # specified Symbol with the specified arg.
86
+ #
87
+ # == Examples
88
+ #
89
+ # lambda { do_something_risky }.should throw_symbol
90
+ # lambda { do_something_risky }.should throw_symbol(:that_was_risky)
91
+ # lambda { do_something_risky }.should throw_symbol(:that_was_risky, culprit)
92
+ #
93
+ # lambda { do_something_risky }.should_not throw_symbol
94
+ # lambda { do_something_risky }.should_not throw_symbol(:that_was_risky)
95
+ # lambda { do_something_risky }.should_not throw_symbol(:that_was_risky, culprit)
96
+ def throw_symbol(expected_symbol = nil, expected_arg=nil)
97
+ Matchers::ThrowSymbol.new(expected_symbol, expected_arg)
98
+ end
99
+ end
100
+ end
@@ -0,0 +1,55 @@
1
+ module Spec
2
+ module Matchers
3
+ # wraps an expectation in a block that will return true if the
4
+ # expectation passes and false if it fails (without bubbling up
5
+ # the failure).
6
+ #
7
+ # This is intended to be used in the context of a simple matcher,
8
+ # and is especially useful for wrapping multiple expectations or
9
+ # one or more assertions from test/unit extensions when running
10
+ # with test/unit.
11
+ #
12
+ # == Examples
13
+ #
14
+ # def eat_cheese(cheese)
15
+ # simple_matcher do |mouse, matcher|
16
+ # matcher.failure_message = "expected #{mouse} to eat cheese"
17
+ # wrap_expectation do |matcher|
18
+ # assert_eats_cheese(mouse)
19
+ # end
20
+ # end
21
+ # end
22
+ #
23
+ # describe Mouse do
24
+ # it "eats cheese" do
25
+ # Mouse.new.should eat_cheese
26
+ # end
27
+ # end
28
+ #
29
+ # You might be wondering "why would I do this if I could just say"
30
+ # assert_eats_cheese?", a fair question, indeed. You might prefer
31
+ # to replace the word assert with something more aligned with the
32
+ # rest of your code examples. You are using rspec, after all.
33
+ #
34
+ # The other benefit you get is that you can use the negative version
35
+ # of the matcher:
36
+ #
37
+ # describe Cat do
38
+ # it "does not eat cheese" do
39
+ # Cat.new.should_not eat_cheese
40
+ # end
41
+ # end
42
+ #
43
+ # So in the event there is no assert_does_not_eat_cheese available,
44
+ # you're all set!
45
+ def wrap_expectation(matcher, &block)
46
+ begin
47
+ block.call(matcher)
48
+ return true
49
+ rescue Exception => e
50
+ matcher.failure_message = e.message
51
+ return false
52
+ end
53
+ end
54
+ end
55
+ end
data/lib/spec/mocks.rb ADDED
@@ -0,0 +1,200 @@
1
+ require 'spec/mocks/framework'
2
+ require 'spec/mocks/extensions/object'
3
+
4
+ module Spec
5
+ # == Mocks and Stubs
6
+ #
7
+ # RSpec will create Mock Objects and Stubs for you at runtime, or attach stub/mock behaviour
8
+ # to any of your real objects (Partial Mock/Stub). Because the underlying implementation
9
+ # for mocks and stubs is the same, you can intermingle mock and stub
10
+ # behaviour in either dynamically generated mocks or your pre-existing classes.
11
+ # There is a semantic difference in how they are created, however,
12
+ # which can help clarify the role it is playing within a given spec.
13
+ #
14
+ # == Mock Objects
15
+ #
16
+ # Mocks are objects that allow you to set and verify expectations that they will
17
+ # receive specific messages during run time. They are very useful for specifying how the subject of
18
+ # the spec interacts with its collaborators. This approach is widely known as "interaction
19
+ # testing".
20
+ #
21
+ # Mocks are also very powerful as a design tool. As you are
22
+ # driving the implementation of a given class, Mocks provide an anonymous
23
+ # collaborator that can change in behaviour as quickly as you can write an expectation in your
24
+ # spec. This flexibility allows you to design the interface of a collaborator that often
25
+ # does not yet exist. As the shape of the class being specified becomes more clear, so do the
26
+ # requirements for its collaborators - often leading to the discovery of new types that are
27
+ # needed in your system.
28
+ #
29
+ # Read Endo-Testing[http://www.mockobjects.com/files/endotesting.pdf] for a much
30
+ # more in depth description of this process.
31
+ #
32
+ # == Stubs
33
+ #
34
+ # Stubs are objects that allow you to set "stub" responses to
35
+ # messages. As Martin Fowler points out on his site,
36
+ # mocks_arent_stubs[http://www.martinfowler.com/articles/mocksArentStubs.html].
37
+ # Paraphrasing Fowler's paraphrasing
38
+ # of Gerard Meszaros: Stubs provide canned responses to messages they might receive in a test, while
39
+ # mocks allow you to specify and, subsquently, verify that certain messages should be received during
40
+ # the execution of a test.
41
+ #
42
+ # == Partial Mocks/Stubs
43
+ #
44
+ # RSpec also supports partial mocking/stubbing, allowing you to add stub/mock behaviour
45
+ # to instances of your existing classes. This is generally
46
+ # something to be avoided, because changes to the class can have ripple effects on
47
+ # seemingly unrelated specs. When specs fail due to these ripple effects, the fact
48
+ # that some methods are being mocked can make it difficult to understand why a
49
+ # failure is occurring.
50
+ #
51
+ # That said, partials do allow you to expect and
52
+ # verify interactions with class methods such as +#find+ and +#create+
53
+ # on Ruby on Rails model classes.
54
+ #
55
+ # == Further Reading
56
+ #
57
+ # There are many different viewpoints about the meaning of mocks and stubs. If you are interested
58
+ # in learning more, here is some recommended reading:
59
+ #
60
+ # * Mock Objects: http://www.mockobjects.com/
61
+ # * Endo-Testing: http://www.mockobjects.com/files/endotesting.pdf
62
+ # * Mock Roles, Not Objects: http://www.mockobjects.com/files/mockrolesnotobjects.pdf
63
+ # * Test Double Patterns: http://xunitpatterns.com/Test%20Double%20Patterns.html
64
+ # * Mocks aren't stubs: http://www.martinfowler.com/articles/mocksArentStubs.html
65
+ #
66
+ # == Creating a Mock
67
+ #
68
+ # You can create a mock in any specification (or setup) using:
69
+ #
70
+ # mock(name, options={})
71
+ #
72
+ # The optional +options+ argument is a +Hash+. Currently the only supported
73
+ # option is +:null_object+. Setting this to true instructs the mock to ignore
74
+ # any messages it hasn’t been told to expect – and quietly return itself. For example:
75
+ #
76
+ # mock("person", :null_object => true)
77
+ #
78
+ # == Creating a Stub
79
+ #
80
+ # You can create a stub in any specification (or setup) using:
81
+ #
82
+ # stub(name, stub_methods_and_values_hash)
83
+ #
84
+ # For example, if you wanted to create an object that always returns
85
+ # "More?!?!?!" to "please_sir_may_i_have_some_more" you would do this:
86
+ #
87
+ # stub("Mr Sykes", :please_sir_may_i_have_some_more => "More?!?!?!")
88
+ #
89
+ # == Creating a Partial Mock
90
+ #
91
+ # You don't really "create" a partial mock, you simply add method stubs and/or
92
+ # mock expectations to existing classes and objects:
93
+ #
94
+ # Factory.should_receive(:find).with(id).and_return(value)
95
+ # obj.stub!(:to_i).and_return(3)
96
+ # etc ...
97
+ #
98
+ # == Expecting Messages
99
+ #
100
+ # my_mock.should_receive(:sym)
101
+ # my_mock.should_not_receive(:sym)
102
+ #
103
+ # == Expecting Arguments
104
+ #
105
+ # my_mock.should_receive(:sym).with(*args)
106
+ # my_mock.should_not_receive(:sym).with(*args)
107
+ #
108
+ # == Argument Matchers
109
+ #
110
+ # Arguments that are passed to #with are compared with actual arguments received
111
+ # using == by default. In cases in which you want to specify things about the arguments
112
+ # rather than the arguments themselves, you can use any of RSpec's Expression Matchers.
113
+ # They don't all make syntactic sense (they were primarily designed for use with
114
+ # Spec::Expectations), but you are free to create your own custom Spec::Matchers.
115
+ #
116
+ # Spec::Mocks does provide one additional Matcher method named #ducktype.
117
+ #
118
+ # In addition, Spec::Mocks adds some keyword Symbols that you can use to
119
+ # specify certain kinds of arguments:
120
+ #
121
+ # my_mock.should_receive(:sym).with(no_args())
122
+ # my_mock.should_receive(:sym).with(any_args())
123
+ # my_mock.should_receive(:sym).with(1, kind_of(Numeric), "b") #2nd argument can any kind of Numeric
124
+ # my_mock.should_receive(:sym).with(1, boolean(), "b") #2nd argument can true or false
125
+ # my_mock.should_receive(:sym).with(1, /abc/, "b") #2nd argument can be any String matching the submitted Regexp
126
+ # my_mock.should_receive(:sym).with(1, anything(), "b") #2nd argument can be anything at all
127
+ # my_mock.should_receive(:sym).with(1, ducktype(:abs, :div), "b")
128
+ # #2nd argument can be object that responds to #abs and #div
129
+ #
130
+ # == Receive Counts
131
+ #
132
+ # my_mock.should_receive(:sym).once
133
+ # my_mock.should_receive(:sym).twice
134
+ # my_mock.should_receive(:sym).exactly(n).times
135
+ # my_mock.should_receive(:sym).at_least(:once)
136
+ # my_mock.should_receive(:sym).at_least(:twice)
137
+ # my_mock.should_receive(:sym).at_least(n).times
138
+ # my_mock.should_receive(:sym).at_most(:once)
139
+ # my_mock.should_receive(:sym).at_most(:twice)
140
+ # my_mock.should_receive(:sym).at_most(n).times
141
+ # my_mock.should_receive(:sym).any_number_of_times
142
+ #
143
+ # == Ordering
144
+ #
145
+ # my_mock.should_receive(:sym).ordered
146
+ # my_mock.should_receive(:other_sym).ordered
147
+ # #This will fail if the messages are received out of order
148
+ #
149
+ # == Setting Reponses
150
+ #
151
+ # Whether you are setting a mock expectation or a simple stub, you can tell the
152
+ # object precisely how to respond:
153
+ #
154
+ # my_mock.should_receive(:sym).and_return(value)
155
+ # my_mock.should_receive(:sym).exactly(3).times.and_return(value1, value2, value3)
156
+ # # returns value1 the first time, value2 the second, etc
157
+ # my_mock.should_receive(:sym).and_return { ... } #returns value returned by the block
158
+ # my_mock.should_receive(:sym).and_raise(error)
159
+ # #error can be an instantiated object or a class
160
+ # #if it is a class, it must be instantiable with no args
161
+ # my_mock.should_receive(:sym).and_throw(:sym)
162
+ # my_mock.should_receive(:sym).and_yield(values,to,yield)
163
+ # my_mock.should_receive(:sym).and_yield(values,to,yield).and_yield(some,other,values,this,time)
164
+ # # for methods that yield to a block multiple times
165
+ #
166
+ # Any of these responses can be applied to a stub as well, but stubs do
167
+ # not support any qualifiers about the message received (i.e. you can't specify arguments
168
+ # or receive counts):
169
+ #
170
+ # my_mock.stub!(:sym).and_return(value)
171
+ # my_mock.stub!(:sym).and_return(value1, value2, value3)
172
+ # my_mock.stub!(:sym).and_raise(error)
173
+ # my_mock.stub!(:sym).and_throw(:sym)
174
+ # my_mock.stub!(:sym).and_yield(values,to,yield)
175
+ # my_mock.stub!(:sym).and_yield(values,to,yield).and_yield(some,other,values,this,time)
176
+ #
177
+ # == Arbitrary Handling
178
+ #
179
+ # Once in a while you'll find that the available expectations don't solve the
180
+ # particular problem you are trying to solve. Imagine that you expect the message
181
+ # to come with an Array argument that has a specific length, but you don't care
182
+ # what is in it. You could do this:
183
+ #
184
+ # my_mock.should_receive(:sym) do |arg|
185
+ # arg.should be_an_istance_of(Array)
186
+ # arg.length.should == 7
187
+ # end
188
+ #
189
+ # Note that this would fail if the number of arguments received was different from
190
+ # the number of block arguments (in this case 1).
191
+ #
192
+ # == Combining Expectation Details
193
+ #
194
+ # Combining the message name with specific arguments, receive counts and responses
195
+ # you can get quite a bit of detail in your expectations:
196
+ #
197
+ # my_mock.should_receive(:<<).with("illegal value").once.and_raise(ArgumentError)
198
+ module Mocks
199
+ end
200
+ end