newbamboo-rspec 1.1.12

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 (324) hide show
  1. data/.autotest +4 -0
  2. data/History.txt +1263 -0
  3. data/License.txt +22 -0
  4. data/Manifest.txt +327 -0
  5. data/README.txt +57 -0
  6. data/Rakefile +104 -0
  7. data/TODO.txt +18 -0
  8. data/bin/autospec +4 -0
  9. data/bin/spec +4 -0
  10. data/examples/failing/README.txt +7 -0
  11. data/examples/failing/diffing_spec.rb +36 -0
  12. data/examples/failing/failing_autogenerated_docstrings_example.rb +19 -0
  13. data/examples/failing/failure_in_after.rb +10 -0
  14. data/examples/failing/failure_in_before.rb +10 -0
  15. data/examples/failing/mocking_example.rb +40 -0
  16. data/examples/failing/mocking_with_flexmock.rb +26 -0
  17. data/examples/failing/mocking_with_mocha.rb +25 -0
  18. data/examples/failing/mocking_with_rr.rb +27 -0
  19. data/examples/failing/partial_mock_example.rb +20 -0
  20. data/examples/failing/predicate_example.rb +34 -0
  21. data/examples/failing/raising_example.rb +47 -0
  22. data/examples/failing/spec_helper.rb +3 -0
  23. data/examples/failing/syntax_error_example.rb +7 -0
  24. data/examples/failing/team_spec.rb +44 -0
  25. data/examples/failing/timeout_behaviour.rb +7 -0
  26. data/examples/passing/autogenerated_docstrings_example.rb +25 -0
  27. data/examples/passing/before_and_after_example.rb +40 -0
  28. data/examples/passing/behave_as_example.rb +45 -0
  29. data/examples/passing/custom_expectation_matchers.rb +54 -0
  30. data/examples/passing/custom_formatter.rb +12 -0
  31. data/examples/passing/dynamic_spec.rb +9 -0
  32. data/examples/passing/file_accessor.rb +19 -0
  33. data/examples/passing/file_accessor_spec.rb +38 -0
  34. data/examples/passing/greeter_spec.rb +31 -0
  35. data/examples/passing/helper_method_example.rb +14 -0
  36. data/examples/passing/io_processor.rb +8 -0
  37. data/examples/passing/io_processor_spec.rb +21 -0
  38. data/examples/passing/legacy_spec.rb +11 -0
  39. data/examples/passing/mocking_example.rb +27 -0
  40. data/examples/passing/multi_threaded_example_group_runner.rb +26 -0
  41. data/examples/passing/nested_classes_example.rb +36 -0
  42. data/examples/passing/partial_mock_example.rb +29 -0
  43. data/examples/passing/pending_example.rb +20 -0
  44. data/examples/passing/predicate_example.rb +27 -0
  45. data/examples/passing/priority.txt +1 -0
  46. data/examples/passing/shared_example_group_example.rb +81 -0
  47. data/examples/passing/shared_stack_examples.rb +36 -0
  48. data/examples/passing/simple_matcher_example.rb +31 -0
  49. data/examples/passing/spec_helper.rb +3 -0
  50. data/examples/passing/stack.rb +36 -0
  51. data/examples/passing/stack_spec.rb +64 -0
  52. data/examples/passing/stack_spec_with_nested_example_groups.rb +67 -0
  53. data/examples/passing/stubbing_example.rb +69 -0
  54. data/examples/passing/yielding_example.rb +33 -0
  55. data/examples/ruby1.9.compatibility/access_to_constants_spec.rb +86 -0
  56. data/features/before_and_after_blocks/before_and_after_blocks.feature +168 -0
  57. data/features/example_groups/autogenerated_docstrings.feature +45 -0
  58. data/features/example_groups/example_group_with_should_methods.feature +17 -0
  59. data/features/example_groups/nested_groups.feature +17 -0
  60. data/features/example_groups/output.feature +20 -0
  61. data/features/interop/examples_and_tests_together.feature +31 -0
  62. data/features/interop/test_but_not_test_unit.feature +14 -0
  63. data/features/interop/test_case_with_should_methods.feature +17 -0
  64. data/features/mock_framework_integration/use_flexmock.feature +27 -0
  65. data/features/step_definitions/running_rspec.rb +54 -0
  66. data/features/support/env.rb +26 -0
  67. data/features/support/helpers/cmdline.rb +9 -0
  68. data/features/support/matchers/smart_match.rb +37 -0
  69. data/init.rb +9 -0
  70. data/lib/adapters/mock_frameworks/flexmock.rb +24 -0
  71. data/lib/adapters/mock_frameworks/mocha.rb +20 -0
  72. data/lib/adapters/mock_frameworks/rr.rb +22 -0
  73. data/lib/adapters/mock_frameworks/rspec.rb +20 -0
  74. data/lib/autotest/discover.rb +3 -0
  75. data/lib/autotest/rspec.rb +47 -0
  76. data/lib/spec/dsl/main.rb +87 -0
  77. data/lib/spec/dsl.rb +1 -0
  78. data/lib/spec/example/before_and_after_hooks.rb +99 -0
  79. data/lib/spec/example/errors.rb +30 -0
  80. data/lib/spec/example/example_group.rb +26 -0
  81. data/lib/spec/example/example_group_factory.rb +98 -0
  82. data/lib/spec/example/example_group_methods.rb +376 -0
  83. data/lib/spec/example/example_matcher.rb +44 -0
  84. data/lib/spec/example/example_methods.rb +137 -0
  85. data/lib/spec/example/module_reopening_fix.rb +21 -0
  86. data/lib/spec/example/pending.rb +18 -0
  87. data/lib/spec/example/shared_example_group.rb +59 -0
  88. data/lib/spec/example.rb +187 -0
  89. data/lib/spec/expectations/differs/default.rb +66 -0
  90. data/lib/spec/expectations/errors.rb +12 -0
  91. data/lib/spec/expectations/extensions/object.rb +63 -0
  92. data/lib/spec/expectations/extensions/string_and_symbol.rb +17 -0
  93. data/lib/spec/expectations/extensions.rb +2 -0
  94. data/lib/spec/expectations/handler.rb +32 -0
  95. data/lib/spec/expectations.rb +60 -0
  96. data/lib/spec/interop/test/unit/autorunner.rb +6 -0
  97. data/lib/spec/interop/test/unit/testcase.rb +73 -0
  98. data/lib/spec/interop/test/unit/testresult.rb +6 -0
  99. data/lib/spec/interop/test/unit/testsuite_adapter.rb +34 -0
  100. data/lib/spec/interop/test/unit/ui/console/testrunner.rb +61 -0
  101. data/lib/spec/interop/test.rb +12 -0
  102. data/lib/spec/matchers/be.rb +208 -0
  103. data/lib/spec/matchers/be_close.rb +21 -0
  104. data/lib/spec/matchers/change.rb +148 -0
  105. data/lib/spec/matchers/eql.rb +25 -0
  106. data/lib/spec/matchers/equal.rb +25 -0
  107. data/lib/spec/matchers/errors.rb +5 -0
  108. data/lib/spec/matchers/exist.rb +16 -0
  109. data/lib/spec/matchers/generated_descriptions.rb +48 -0
  110. data/lib/spec/matchers/has.rb +15 -0
  111. data/lib/spec/matchers/have.rb +150 -0
  112. data/lib/spec/matchers/include.rb +80 -0
  113. data/lib/spec/matchers/match.rb +22 -0
  114. data/lib/spec/matchers/match_array.rb +79 -0
  115. data/lib/spec/matchers/method_missing.rb +9 -0
  116. data/lib/spec/matchers/operator_matcher.rb +70 -0
  117. data/lib/spec/matchers/raise_error.rb +128 -0
  118. data/lib/spec/matchers/respond_to.rb +71 -0
  119. data/lib/spec/matchers/satisfy.rb +47 -0
  120. data/lib/spec/matchers/simple_matcher.rb +132 -0
  121. data/lib/spec/matchers/throw_symbol.rb +106 -0
  122. data/lib/spec/matchers/wrap_expectation.rb +55 -0
  123. data/lib/spec/matchers.rb +141 -0
  124. data/lib/spec/mocks/argument_expectation.rb +49 -0
  125. data/lib/spec/mocks/argument_matchers.rb +237 -0
  126. data/lib/spec/mocks/error_generator.rb +82 -0
  127. data/lib/spec/mocks/errors.rb +10 -0
  128. data/lib/spec/mocks/extensions/object.rb +3 -0
  129. data/lib/spec/mocks/extensions.rb +1 -0
  130. data/lib/spec/mocks/framework.rb +15 -0
  131. data/lib/spec/mocks/message_expectation.rb +331 -0
  132. data/lib/spec/mocks/methods.rb +51 -0
  133. data/lib/spec/mocks/mock.rb +55 -0
  134. data/lib/spec/mocks/order_group.rb +29 -0
  135. data/lib/spec/mocks/proxy.rb +230 -0
  136. data/lib/spec/mocks/space.rb +28 -0
  137. data/lib/spec/mocks/spec_methods.rb +55 -0
  138. data/lib/spec/mocks.rb +200 -0
  139. data/lib/spec/rake/spectask.rb +225 -0
  140. data/lib/spec/rake/verify_rcov.rb +52 -0
  141. data/lib/spec/ruby.rb +9 -0
  142. data/lib/spec/runner/backtrace_tweaker.rb +58 -0
  143. data/lib/spec/runner/class_and_arguments_parser.rb +14 -0
  144. data/lib/spec/runner/command_line.rb +35 -0
  145. data/lib/spec/runner/configuration.rb +166 -0
  146. data/lib/spec/runner/drb_command_line.rb +20 -0
  147. data/lib/spec/runner/example_group_runner.rb +70 -0
  148. data/lib/spec/runner/formatter/base_formatter.rb +79 -0
  149. data/lib/spec/runner/formatter/base_text_formatter.rb +127 -0
  150. data/lib/spec/runner/formatter/failing_example_groups_formatter.rb +27 -0
  151. data/lib/spec/runner/formatter/failing_examples_formatter.rb +20 -0
  152. data/lib/spec/runner/formatter/html_formatter.rb +340 -0
  153. data/lib/spec/runner/formatter/nested_text_formatter.rb +65 -0
  154. data/lib/spec/runner/formatter/profile_formatter.rb +51 -0
  155. data/lib/spec/runner/formatter/progress_bar_formatter.rb +34 -0
  156. data/lib/spec/runner/formatter/snippet_extractor.rb +52 -0
  157. data/lib/spec/runner/formatter/specdoc_formatter.rb +39 -0
  158. data/lib/spec/runner/formatter/text_mate_formatter.rb +16 -0
  159. data/lib/spec/runner/heckle_runner.rb +74 -0
  160. data/lib/spec/runner/heckle_runner_unsupported.rb +10 -0
  161. data/lib/spec/runner/option_parser.rb +204 -0
  162. data/lib/spec/runner/options.rb +320 -0
  163. data/lib/spec/runner/reporter.rb +167 -0
  164. data/lib/spec/runner/spec_parser.rb +73 -0
  165. data/lib/spec/runner.rb +88 -0
  166. data/lib/spec/version.rb +15 -0
  167. data/lib/spec.rb +7 -0
  168. data/resources/rake/examples.rake +7 -0
  169. data/resources/rake/examples_with_rcov.rake +9 -0
  170. data/resources/rake/failing_examples_with_html.rake +9 -0
  171. data/resources/rake/verify_rcov.rake +7 -0
  172. data/resources/spec/example_group_with_should_methods.rb +12 -0
  173. data/resources/spec/simple_spec.rb +8 -0
  174. data/resources/test/spec_and_test_together.rb +57 -0
  175. data/resources/test/spec_including_test_but_not_unit.rb +11 -0
  176. data/resources/test/test_case_with_should_methods.rb +30 -0
  177. data/rspec.gemspec +32 -0
  178. data/spec/README.jruby +15 -0
  179. data/spec/autotest/autotest_helper.rb +6 -0
  180. data/spec/autotest/autotest_matchers.rb +47 -0
  181. data/spec/autotest/discover_spec.rb +8 -0
  182. data/spec/autotest/failed_results_re_spec.rb +24 -0
  183. data/spec/autotest/rspec_spec.rb +114 -0
  184. data/spec/rspec_suite.rb +6 -0
  185. data/spec/ruby_forker.rb +13 -0
  186. data/spec/spec/dsl/main_spec.rb +88 -0
  187. data/spec/spec/example/example_group_class_definition_spec.rb +49 -0
  188. data/spec/spec/example/example_group_factory_spec.rb +224 -0
  189. data/spec/spec/example/example_group_methods_spec.rb +653 -0
  190. data/spec/spec/example/example_group_spec.rb +661 -0
  191. data/spec/spec/example/example_matcher_spec.rb +79 -0
  192. data/spec/spec/example/example_methods_spec.rb +204 -0
  193. data/spec/spec/example/helper_method_spec.rb +24 -0
  194. data/spec/spec/example/nested_example_group_spec.rb +71 -0
  195. data/spec/spec/example/pending_module_spec.rb +139 -0
  196. data/spec/spec/example/predicate_matcher_spec.rb +21 -0
  197. data/spec/spec/example/shared_example_group_spec.rb +257 -0
  198. data/spec/spec/example/subclassing_example_group_spec.rb +25 -0
  199. data/spec/spec/expectations/differs/default_spec.rb +127 -0
  200. data/spec/spec/expectations/extensions/object_spec.rb +45 -0
  201. data/spec/spec/expectations/fail_with_spec.rb +71 -0
  202. data/spec/spec/expectations/wrap_expectation_spec.rb +30 -0
  203. data/spec/spec/interop/test/unit/resources/spec_that_fails.rb +10 -0
  204. data/spec/spec/interop/test/unit/resources/spec_that_passes.rb +10 -0
  205. data/spec/spec/interop/test/unit/resources/spec_with_errors.rb +10 -0
  206. data/spec/spec/interop/test/unit/resources/spec_with_options_hash.rb +13 -0
  207. data/spec/spec/interop/test/unit/resources/test_case_that_fails.rb +10 -0
  208. data/spec/spec/interop/test/unit/resources/test_case_that_passes.rb +10 -0
  209. data/spec/spec/interop/test/unit/resources/test_case_with_errors.rb +10 -0
  210. data/spec/spec/interop/test/unit/resources/testsuite_adapter_spec_with_test_unit.rb +38 -0
  211. data/spec/spec/interop/test/unit/spec_spec.rb +48 -0
  212. data/spec/spec/interop/test/unit/test_unit_spec_helper.rb +18 -0
  213. data/spec/spec/interop/test/unit/testcase_spec.rb +49 -0
  214. data/spec/spec/interop/test/unit/testsuite_adapter_spec.rb +9 -0
  215. data/spec/spec/matchers/be_close_spec.rb +41 -0
  216. data/spec/spec/matchers/be_spec.rb +303 -0
  217. data/spec/spec/matchers/change_spec.rb +329 -0
  218. data/spec/spec/matchers/description_generation_spec.rb +172 -0
  219. data/spec/spec/matchers/eql_spec.rb +29 -0
  220. data/spec/spec/matchers/equal_spec.rb +29 -0
  221. data/spec/spec/matchers/exist_spec.rb +57 -0
  222. data/spec/spec/matchers/handler_spec.rb +111 -0
  223. data/spec/spec/matchers/has_spec.rb +63 -0
  224. data/spec/spec/matchers/have_spec.rb +399 -0
  225. data/spec/spec/matchers/include_spec.rb +88 -0
  226. data/spec/spec/matchers/match_array_spec.rb +83 -0
  227. data/spec/spec/matchers/match_spec.rb +37 -0
  228. data/spec/spec/matchers/matcher_methods_spec.rb +66 -0
  229. data/spec/spec/matchers/operator_matcher_spec.rb +191 -0
  230. data/spec/spec/matchers/raise_error_spec.rb +333 -0
  231. data/spec/spec/matchers/respond_to_spec.rb +116 -0
  232. data/spec/spec/matchers/satisfy_spec.rb +36 -0
  233. data/spec/spec/matchers/simple_matcher_spec.rb +93 -0
  234. data/spec/spec/matchers/throw_symbol_spec.rb +96 -0
  235. data/spec/spec/mocks/any_number_of_times_spec.rb +36 -0
  236. data/spec/spec/mocks/argument_expectation_spec.rb +23 -0
  237. data/spec/spec/mocks/at_least_spec.rb +97 -0
  238. data/spec/spec/mocks/at_most_spec.rb +93 -0
  239. data/spec/spec/mocks/bug_report_10260_spec.rb +8 -0
  240. data/spec/spec/mocks/bug_report_10263_spec.rb +24 -0
  241. data/spec/spec/mocks/bug_report_11545_spec.rb +32 -0
  242. data/spec/spec/mocks/bug_report_15719_spec.rb +30 -0
  243. data/spec/spec/mocks/bug_report_496.rb +19 -0
  244. data/spec/spec/mocks/bug_report_600_spec.rb +22 -0
  245. data/spec/spec/mocks/bug_report_7611_spec.rb +19 -0
  246. data/spec/spec/mocks/bug_report_7805_spec.rb +22 -0
  247. data/spec/spec/mocks/bug_report_8165_spec.rb +31 -0
  248. data/spec/spec/mocks/bug_report_8302_spec.rb +26 -0
  249. data/spec/spec/mocks/failing_argument_matchers_spec.rb +95 -0
  250. data/spec/spec/mocks/hash_including_matcher_spec.rb +90 -0
  251. data/spec/spec/mocks/hash_not_including_matcher_spec.rb +67 -0
  252. data/spec/spec/mocks/mock_ordering_spec.rb +84 -0
  253. data/spec/spec/mocks/mock_space_spec.rb +54 -0
  254. data/spec/spec/mocks/mock_spec.rb +579 -0
  255. data/spec/spec/mocks/multiple_return_value_spec.rb +113 -0
  256. data/spec/spec/mocks/nil_expectation_warning_spec.rb +53 -0
  257. data/spec/spec/mocks/null_object_mock_spec.rb +54 -0
  258. data/spec/spec/mocks/once_counts_spec.rb +53 -0
  259. data/spec/spec/mocks/options_hash_spec.rb +35 -0
  260. data/spec/spec/mocks/partial_mock_spec.rb +149 -0
  261. data/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb +66 -0
  262. data/spec/spec/mocks/passing_argument_matchers_spec.rb +145 -0
  263. data/spec/spec/mocks/precise_counts_spec.rb +52 -0
  264. data/spec/spec/mocks/record_messages_spec.rb +26 -0
  265. data/spec/spec/mocks/stub_spec.rb +194 -0
  266. data/spec/spec/mocks/stubbed_message_expectations_spec.rb +14 -0
  267. data/spec/spec/mocks/twice_counts_spec.rb +67 -0
  268. data/spec/spec/package/bin_spec_spec.rb +22 -0
  269. data/spec/spec/runner/class_and_argument_parser_spec.rb +23 -0
  270. data/spec/spec/runner/command_line_spec.rb +141 -0
  271. data/spec/spec/runner/configuration_spec.rb +301 -0
  272. data/spec/spec/runner/drb_command_line_spec.rb +97 -0
  273. data/spec/spec/runner/empty_file.txt +0 -0
  274. data/spec/spec/runner/example_group_runner_spec.rb +33 -0
  275. data/spec/spec/runner/examples.txt +2 -0
  276. data/spec/spec/runner/failed.txt +3 -0
  277. data/spec/spec/runner/formatter/base_formatter_spec.rb +23 -0
  278. data/spec/spec/runner/formatter/base_text_formatter_spec.rb +23 -0
  279. data/spec/spec/runner/formatter/failing_example_groups_formatter_spec.rb +45 -0
  280. data/spec/spec/runner/formatter/failing_examples_formatter_spec.rb +33 -0
  281. data/spec/spec/runner/formatter/html_formatted-1.8.4.html +365 -0
  282. data/spec/spec/runner/formatter/html_formatted-1.8.5-jruby.html +387 -0
  283. data/spec/spec/runner/formatter/html_formatted-1.8.5.html +371 -0
  284. data/spec/spec/runner/formatter/html_formatted-1.8.6-jruby.html +381 -0
  285. data/spec/spec/runner/formatter/html_formatted-1.8.6.html +379 -0
  286. data/spec/spec/runner/formatter/html_formatted-1.8.7.html +379 -0
  287. data/spec/spec/runner/formatter/html_formatted-1.9.1.html +379 -0
  288. data/spec/spec/runner/formatter/html_formatter_spec.rb +62 -0
  289. data/spec/spec/runner/formatter/nested_text_formatter_spec.rb +318 -0
  290. data/spec/spec/runner/formatter/profile_formatter_spec.rb +65 -0
  291. data/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +145 -0
  292. data/spec/spec/runner/formatter/snippet_extractor_spec.rb +18 -0
  293. data/spec/spec/runner/formatter/spec_mate_formatter_spec.rb +104 -0
  294. data/spec/spec/runner/formatter/specdoc_formatter_spec.rb +159 -0
  295. data/spec/spec/runner/formatter/text_mate_formatted-1.8.4.html +365 -0
  296. data/spec/spec/runner/formatter/text_mate_formatted-1.8.6.html +373 -0
  297. data/spec/spec/runner/formatter/text_mate_formatted-1.8.7.html +373 -0
  298. data/spec/spec/runner/formatter/text_mate_formatted-1.9.1.html +373 -0
  299. data/spec/spec/runner/heckle_runner_spec.rb +78 -0
  300. data/spec/spec/runner/heckler_spec.rb +20 -0
  301. data/spec/spec/runner/noisy_backtrace_tweaker_spec.rb +45 -0
  302. data/spec/spec/runner/option_parser_spec.rb +396 -0
  303. data/spec/spec/runner/options_spec.rb +469 -0
  304. data/spec/spec/runner/output_one_time_fixture.rb +7 -0
  305. data/spec/spec/runner/output_one_time_fixture_runner.rb +8 -0
  306. data/spec/spec/runner/output_one_time_spec.rb +16 -0
  307. data/spec/spec/runner/quiet_backtrace_tweaker_spec.rb +62 -0
  308. data/spec/spec/runner/reporter_spec.rb +238 -0
  309. data/spec/spec/runner/resources/a_bar.rb +0 -0
  310. data/spec/spec/runner/resources/a_foo.rb +0 -0
  311. data/spec/spec/runner/resources/a_spec.rb +1 -0
  312. data/spec/spec/runner/resources/custom_example_group_runner.rb +14 -0
  313. data/spec/spec/runner/resources/utf8_encoded.rb +7 -0
  314. data/spec/spec/runner/spec.opts +2 -0
  315. data/spec/spec/runner/spec_drb.opts +1 -0
  316. data/spec/spec/runner/spec_parser/spec_parser_fixture.rb +70 -0
  317. data/spec/spec/runner/spec_parser_spec.rb +91 -0
  318. data/spec/spec/runner/spec_spaced.opts +2 -0
  319. data/spec/spec/runner_spec.rb +11 -0
  320. data/spec/spec/spec_classes.rb +133 -0
  321. data/spec/spec/spec_spec.rb +21 -0
  322. data/spec/spec.opts +6 -0
  323. data/spec/spec_helper.rb +107 -0
  324. metadata +388 -0
@@ -0,0 +1,28 @@
1
+ module Spec
2
+ module Mocks
3
+ class Space
4
+ def add(obj)
5
+ mocks << obj unless mocks.detect {|m| m.equal? obj}
6
+ end
7
+
8
+ def verify_all
9
+ mocks.each do |mock|
10
+ mock.rspec_verify
11
+ end
12
+ end
13
+
14
+ def reset_all
15
+ mocks.each do |mock|
16
+ mock.rspec_reset
17
+ end
18
+ mocks.clear
19
+ end
20
+
21
+ private
22
+
23
+ def mocks
24
+ @mocks ||= []
25
+ end
26
+ end
27
+ end
28
+ end
@@ -0,0 +1,55 @@
1
+ module Spec
2
+ module Mocks
3
+ module ExampleMethods
4
+ include Spec::Mocks::ArgumentMatchers
5
+
6
+ # Shortcut for creating an instance of Spec::Mocks::Mock.
7
+ #
8
+ # +name+ is used for failure reporting, so you should use the
9
+ # role that the mock is playing in the example.
10
+ #
11
+ # +stubs_and_options+ lets you assign options and stub values
12
+ # at the same time. The only option available is :null_object.
13
+ # Anything else is treated as a stub value.
14
+ #
15
+ # == Examples
16
+ #
17
+ # stub_thing = mock("thing", :a => "A")
18
+ # stub_thing.a == "A" => true
19
+ #
20
+ # stub_person = stub("thing", :name => "Joe", :email => "joe@domain.com")
21
+ # stub_person.name => "Joe"
22
+ # stub_person.email => "joe@domain.com"
23
+ def mock(name, stubs_and_options={})
24
+ Spec::Mocks::Mock.new(name, stubs_and_options)
25
+ end
26
+
27
+ alias :stub :mock
28
+
29
+ # DEPRECATED - use mock('name').as_null_object instead
30
+ #
31
+ # Shortcut for creating a mock object that will return itself in response
32
+ # to any message it receives that it hasn't been explicitly instructed
33
+ # to respond to.
34
+ def stub_everything(name = 'stub')
35
+ Kernel.warn(<<-WARNING)
36
+
37
+ DEPRECATION: stub_everything('#{name}') is deprecated and will be removed
38
+ from a future version of rspec. Please use mock('#{name}').as_null_object
39
+ or stub('#{name}').as_null_object instead.
40
+
41
+ WARNING
42
+ mock(name, :null_object => true)
43
+ end
44
+
45
+ # Disables warning messages about expectations being set on nil.
46
+ #
47
+ # By default warning messages are issued when expectations are set on nil. This is to
48
+ # prevent false-positives and to catch potential bugs early on.
49
+ def allow_message_expectations_on_nil
50
+ Proxy.allow_message_expectations_on_nil
51
+ end
52
+
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
@@ -0,0 +1,225 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ # Define a task library for running RSpec contexts.
4
+
5
+ require 'rake'
6
+ require 'rake/tasklib'
7
+
8
+ module Spec
9
+ module Rake
10
+
11
+ # A Rake task that runs a set of specs.
12
+ #
13
+ # Example:
14
+ #
15
+ # Spec::Rake::SpecTask.new do |t|
16
+ # t.warning = true
17
+ # t.rcov = true
18
+ # end
19
+ #
20
+ # This will create a task that can be run with:
21
+ #
22
+ # rake spec
23
+ #
24
+ # If rake is invoked with a "SPEC=filename" command line option,
25
+ # then the list of spec files will be overridden to include only the
26
+ # filename specified on the command line. This provides an easy way
27
+ # to run just one spec.
28
+ #
29
+ # If rake is invoked with a "SPEC_OPTS=options" command line option,
30
+ # then the given options will override the value of the +spec_opts+
31
+ # attribute.
32
+ #
33
+ # If rake is invoked with a "RCOV_OPTS=options" command line option,
34
+ # then the given options will override the value of the +rcov_opts+
35
+ # attribute.
36
+ #
37
+ # Examples:
38
+ #
39
+ # rake spec # run specs normally
40
+ # rake spec SPEC=just_one_file.rb # run just one spec file.
41
+ # rake spec SPEC_OPTS="--diff" # enable diffing
42
+ # rake spec RCOV_OPTS="--aggregate myfile.txt" # see rcov --help for details
43
+ #
44
+ # Each attribute of this task may be a proc. This allows for lazy evaluation,
45
+ # which is sometimes handy if you want to defer the evaluation of an attribute value
46
+ # until the task is run (as opposed to when it is defined).
47
+ #
48
+ # This task can also be used to run existing Test::Unit tests and get RSpec
49
+ # output, for example like this:
50
+ #
51
+ # require 'rubygems'
52
+ # require 'spec/rake/spectask'
53
+ # Spec::Rake::SpecTask.new do |t|
54
+ # t.ruby_opts = ['-rtest/unit']
55
+ # t.spec_files = FileList['test/**/*_test.rb']
56
+ # end
57
+ #
58
+ class SpecTask < ::Rake::TaskLib
59
+ def self.attr_accessor(*names)
60
+ super(*names)
61
+ names.each do |name|
62
+ module_eval "def #{name}() evaluate(@#{name}) end" # Allows use of procs
63
+ end
64
+ end
65
+
66
+ # Name of spec task. (default is :spec)
67
+ attr_accessor :name
68
+
69
+ # Array of directories to be added to $LOAD_PATH before running the
70
+ # specs. Defaults to ['<the absolute path to RSpec's lib directory>']
71
+ attr_accessor :libs
72
+
73
+ # If true, requests that the specs be run with the warning flag set.
74
+ # E.g. warning=true implies "ruby -w" used to run the specs. Defaults to false.
75
+ attr_accessor :warning
76
+
77
+ # Glob pattern to match spec files. (default is 'spec/**/*_spec.rb')
78
+ # Setting the SPEC environment variable overrides this.
79
+ attr_accessor :pattern
80
+
81
+ # Array of commandline options to pass to RSpec. Defaults to [].
82
+ # Setting the SPEC_OPTS environment variable overrides this.
83
+ attr_accessor :spec_opts
84
+
85
+ # Whether or not to use RCov (default is false)
86
+ # See http://eigenclass.org/hiki.rb?rcov
87
+ attr_accessor :rcov
88
+
89
+ # Array of commandline options to pass to RCov. Defaults to ['--exclude', 'lib\/spec,bin\/spec'].
90
+ # Ignored if rcov=false
91
+ # Setting the RCOV_OPTS environment variable overrides this.
92
+ attr_accessor :rcov_opts
93
+
94
+ # Directory where the RCov report is written. Defaults to "coverage"
95
+ # Ignored if rcov=false
96
+ attr_accessor :rcov_dir
97
+
98
+ # Array of commandline options to pass to ruby. Defaults to [].
99
+ attr_accessor :ruby_opts
100
+
101
+ # Whether or not to fail Rake when an error occurs (typically when specs fail).
102
+ # Defaults to true.
103
+ attr_accessor :fail_on_error
104
+
105
+ # A message to print to stderr when there are failures.
106
+ attr_accessor :failure_message
107
+
108
+ # Where RSpec's output is written. Defaults to $stdout.
109
+ # DEPRECATED. Use --format FORMAT:WHERE in spec_opts.
110
+ attr_accessor :out
111
+
112
+ # Explicitly define the list of spec files to be included in a
113
+ # spec. +spec_files+ is expected to be an array of file names (a
114
+ # FileList is acceptable). If both +pattern+ and +spec_files+ are
115
+ # used, then the list of spec files is the union of the two.
116
+ # Setting the SPEC environment variable overrides this.
117
+ attr_accessor :spec_files
118
+
119
+ # Use verbose output. If this is set to true, the task will print
120
+ # the executed spec command to stdout. Defaults to false.
121
+ attr_accessor :verbose
122
+
123
+ # Defines a new task, using the name +name+.
124
+ def initialize(name=:spec)
125
+ @name = name
126
+ @libs = [File.expand_path(File.dirname(__FILE__) + '/../../../lib')]
127
+ @pattern = nil
128
+ @spec_files = nil
129
+ @spec_opts = []
130
+ @warning = false
131
+ @ruby_opts = []
132
+ @fail_on_error = true
133
+ @rcov = false
134
+ @rcov_opts = ['--exclude', 'lib\/spec,bin\/spec,config\/boot.rb']
135
+ @rcov_dir = "coverage"
136
+
137
+ yield self if block_given?
138
+ @pattern = 'spec/**/*_spec.rb' if pattern.nil? && spec_files.nil?
139
+ define
140
+ end
141
+
142
+ def define # :nodoc:
143
+ spec_script = File.expand_path(File.dirname(__FILE__) + '/../../../bin/spec')
144
+
145
+ lib_path = libs.join(File::PATH_SEPARATOR)
146
+ actual_name = Hash === name ? name.keys.first : name
147
+ unless ::Rake.application.last_comment
148
+ desc "Run specs" + (rcov ? " using RCov" : "")
149
+ end
150
+ task name do
151
+ RakeFileUtils.verbose(verbose) do
152
+ unless spec_file_list.empty?
153
+ # ruby [ruby_opts] -Ilib -S rcov [rcov_opts] bin/spec -- examples [spec_opts]
154
+ # or
155
+ # ruby [ruby_opts] -Ilib bin/spec examples [spec_opts]
156
+ cmd_parts = [RUBY]
157
+ cmd_parts += ruby_opts
158
+ cmd_parts << %[-I"#{lib_path}"]
159
+ cmd_parts << "-S rcov" if rcov
160
+ cmd_parts << "-w" if warning
161
+ cmd_parts << rcov_option_list
162
+ cmd_parts << %[-o "#{rcov_dir}"] if rcov
163
+ cmd_parts << %["#{spec_script}"]
164
+ cmd_parts << "--" if rcov
165
+ cmd_parts += spec_file_list.collect { |fn| %["#{fn}"] }
166
+ cmd_parts << spec_option_list
167
+ if out
168
+ cmd_parts << %[> "#{out}"]
169
+ STDERR.puts "The Spec::Rake::SpecTask#out attribute is DEPRECATED and will be removed in a future version. Use --format FORMAT:WHERE instead."
170
+ end
171
+ cmd = cmd_parts.join(" ")
172
+ puts cmd if verbose
173
+ unless system(cmd)
174
+ STDERR.puts failure_message if failure_message
175
+ raise("Command #{cmd} failed") if fail_on_error
176
+ end
177
+ end
178
+ end
179
+ end
180
+
181
+ if rcov
182
+ desc "Remove rcov products for #{actual_name}"
183
+ task paste("clobber_", actual_name) do
184
+ rm_r rcov_dir rescue nil
185
+ end
186
+
187
+ clobber_task = paste("clobber_", actual_name)
188
+ task :clobber => [clobber_task]
189
+
190
+ task actual_name => clobber_task
191
+ end
192
+ self
193
+ end
194
+
195
+ def rcov_option_list # :nodoc:
196
+ return "" unless rcov
197
+ ENV['RCOV_OPTS'] || rcov_opts.join(" ") || ""
198
+ end
199
+
200
+ def spec_option_list # :nodoc:
201
+ STDERR.puts "RSPECOPTS is DEPRECATED and will be removed in a future version. Use SPEC_OPTS instead." if ENV['RSPECOPTS']
202
+ ENV['SPEC_OPTS'] || ENV['RSPECOPTS'] || spec_opts.join(" ") || ""
203
+ end
204
+
205
+ def evaluate(o) # :nodoc:
206
+ case o
207
+ when Proc then o.call
208
+ else o
209
+ end
210
+ end
211
+
212
+ def spec_file_list # :nodoc:
213
+ if ENV['SPEC']
214
+ FileList[ ENV['SPEC'] ]
215
+ else
216
+ result = []
217
+ result += spec_files.to_a if spec_files
218
+ result += FileList[ pattern ].to_a if pattern
219
+ FileList[result]
220
+ end
221
+ end
222
+
223
+ end
224
+ end
225
+ end
@@ -0,0 +1,52 @@
1
+ module RCov
2
+ # A task that can verify that the RCov coverage doesn't
3
+ # drop below a certain threshold. It should be run after
4
+ # running Spec::Rake::SpecTask.
5
+ class VerifyTask < Rake::TaskLib
6
+ # Name of the task. Defaults to :verify_rcov
7
+ attr_accessor :name
8
+
9
+ # Path to the index.html file generated by RCov, which
10
+ # is the file containing the total coverage.
11
+ # Defaults to 'coverage/index.html'
12
+ attr_accessor :index_html
13
+
14
+ # Whether or not to output details. Defaults to true.
15
+ attr_accessor :verbose
16
+
17
+ # The threshold value (in percent) for coverage. If the
18
+ # actual coverage is not equal to this value, the task will raise an
19
+ # exception.
20
+ attr_accessor :threshold
21
+
22
+ # Require the threshold value be met exactly. This is the default.
23
+ attr_accessor :require_exact_threshold
24
+
25
+ def initialize(name=:verify_rcov)
26
+ @name = name
27
+ @index_html = 'coverage/index.html'
28
+ @verbose = true
29
+ @require_exact_threshold = true
30
+ yield self if block_given?
31
+ raise "Threshold must be set" if @threshold.nil?
32
+ define
33
+ end
34
+
35
+ def define
36
+ desc "Verify that rcov coverage is at least #{threshold}%"
37
+ task @name do
38
+ total_coverage = 0
39
+
40
+ File.open(index_html).each_line do |line|
41
+ if line =~ /<tt class='coverage_total'>\s*(\d+\.\d+)%\s*<\/tt>/
42
+ total_coverage = $1.to_f
43
+ break
44
+ end
45
+ end
46
+ puts "Coverage: #{total_coverage}% (threshold: #{threshold}%)" if verbose
47
+ raise "Coverage must be at least #{threshold}% but was #{total_coverage}%" if total_coverage < threshold
48
+ raise "Coverage has increased above the threshold of #{threshold}% to #{total_coverage}%. You should update your threshold value." if (total_coverage > threshold) and require_exact_threshold
49
+ end
50
+ end
51
+ end
52
+ end
data/lib/spec/ruby.rb ADDED
@@ -0,0 +1,9 @@
1
+ module Spec
2
+ module Ruby
3
+ class << self
4
+ def version
5
+ RUBY_VERSION
6
+ end
7
+ end
8
+ end
9
+ end
@@ -0,0 +1,58 @@
1
+ module Spec
2
+ module Runner
3
+ class BacktraceTweaker
4
+ def clean_up_double_slashes(line)
5
+ line.gsub!('//','/')
6
+ end
7
+ end
8
+
9
+ class NoisyBacktraceTweaker < BacktraceTweaker
10
+ def tweak_backtrace(error)
11
+ return if error.backtrace.nil?
12
+ tweaked = error.backtrace.collect do |line|
13
+ clean_up_double_slashes(line)
14
+ line
15
+ end
16
+ error.set_backtrace(tweaked)
17
+ end
18
+ end
19
+
20
+ # Tweaks raised Exceptions to mask noisy (unneeded) parts of the backtrace
21
+ class QuietBacktraceTweaker < BacktraceTweaker
22
+ unless defined?(IGNORE_PATTERNS)
23
+ root_dir = File.expand_path(File.join(__FILE__, '..', '..', '..', '..'))
24
+ spec_files = Dir["#{root_dir}/lib/*"].map do |path|
25
+ subpath = path[root_dir.length..-1]
26
+ /#{subpath}/
27
+ end
28
+ IGNORE_PATTERNS = spec_files + [
29
+ /\/lib\/ruby\//,
30
+ /bin\/spec:/,
31
+ /bin\/rcov:/,
32
+ /lib\/rspec-rails/,
33
+ /vendor\/rails/,
34
+ # TextMate's Ruby and RSpec plugins
35
+ /Ruby\.tmbundle\/Support\/tmruby.rb:/,
36
+ /RSpec\.tmbundle\/Support\/lib/,
37
+ /temp_textmate\./,
38
+ /mock_frameworks\/rspec/,
39
+ /spec_server/
40
+ ]
41
+ end
42
+
43
+ def tweak_backtrace(error)
44
+ return if error.backtrace.nil?
45
+ tweaked = error.backtrace.collect do |message|
46
+ clean_up_double_slashes(message)
47
+ kept_lines = message.split("\n").select do |line|
48
+ IGNORE_PATTERNS.each do |ignore|
49
+ break if line =~ ignore
50
+ end
51
+ end
52
+ kept_lines.empty?? nil : kept_lines.join("\n")
53
+ end
54
+ error.set_backtrace(tweaked.select {|line| line})
55
+ end
56
+ end
57
+ end
58
+ end
@@ -0,0 +1,14 @@
1
+ module Spec
2
+ module Runner
3
+ class ClassAndArgumentsParser
4
+ def self.parse(s)
5
+ if s =~ /([a-zA-Z_]+(?:::[a-zA-Z_]+)*):?(.*)/
6
+ arg = $2 == "" ? nil : $2
7
+ [$1, arg]
8
+ else
9
+ raise "Couldn't parse #{s.inspect}"
10
+ end
11
+ end
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,35 @@
1
+ require 'spec/runner/option_parser'
2
+ require 'rubygems'
3
+ require 'eventmachine'
4
+
5
+ module Spec
6
+ module Runner
7
+ class CommandLine
8
+
9
+ def self.run(tmp_options=Spec::Runner.options)
10
+ orig_options = Spec::Runner.options
11
+ Spec::Runner.use tmp_options
12
+ tmp_options.run_examples
13
+ ensure
14
+ Spec::Runner.use orig_options
15
+ end
16
+
17
+
18
+ def self.evented_run(tmp_options=Spec::Runner.options)
19
+ EM.run do
20
+ begin
21
+ original_run(tmp_options)
22
+ ensure
23
+ EM.add_timer(3) {EventMachine::stop}
24
+ end
25
+ end
26
+ end
27
+
28
+
29
+ class << self
30
+ alias :original_run :run
31
+ alias :run :evented_run
32
+ end
33
+ end
34
+ end
35
+ end