rspec-instructure 1.3.3
Sign up to get free protection for your applications and to get access to all the features.
- data/.autotest +5 -0
- data/.document +7 -0
- data/.gitignore +15 -0
- data/Gemfile +20 -0
- data/History.rdoc +1565 -0
- data/License.txt +22 -0
- data/README.rdoc +44 -0
- data/Rakefile +110 -0
- data/Ruby1.9.rdoc +31 -0
- data/TODO.txt +17 -0
- data/Upgrade.rdoc +260 -0
- data/bin/autospec +4 -0
- data/bin/spec +5 -0
- data/cucumber.yml +5 -0
- data/example_spec.rb +4 -0
- data/examples/failing/README.txt +11 -0
- data/examples/failing/diffing_spec.rb +36 -0
- data/examples/failing/failing_implicit_docstrings_example.rb +17 -0
- data/examples/failing/failure_in_after.rb +10 -0
- data/examples/failing/failure_in_before.rb +10 -0
- data/examples/failing/mocking_example.rb +38 -0
- data/examples/failing/mocking_with_flexmock.rb +26 -0
- data/examples/failing/mocking_with_mocha.rb +25 -0
- data/examples/failing/mocking_with_rr.rb +27 -0
- data/examples/failing/partial_mock_example.rb +18 -0
- data/examples/failing/pending_example.rb +7 -0
- data/examples/failing/predicate_example.rb +32 -0
- data/examples/failing/raising_example.rb +47 -0
- data/examples/failing/syntax_error_example.rb +7 -0
- data/examples/failing/team_spec.rb +41 -0
- data/examples/failing/timeout_behaviour.rb +5 -0
- data/examples/passing/custom_formatter.rb +11 -0
- data/examples/passing/custom_matchers.rb +54 -0
- data/examples/passing/dynamic_spec.rb +7 -0
- data/examples/passing/file_accessor.rb +18 -0
- data/examples/passing/file_accessor_spec.rb +37 -0
- data/examples/passing/filtered_formatter.rb +17 -0
- data/examples/passing/filtered_formatter_example.rb +31 -0
- data/examples/passing/greeter_spec.rb +30 -0
- data/examples/passing/helper_method_example.rb +12 -0
- data/examples/passing/implicit_docstrings_example.rb +16 -0
- data/examples/passing/io_processor.rb +8 -0
- data/examples/passing/io_processor_spec.rb +20 -0
- data/examples/passing/mocking_example.rb +25 -0
- data/examples/passing/multi_threaded_example_group_runner.rb +26 -0
- data/examples/passing/nested_classes_example.rb +35 -0
- data/examples/passing/options_example.rb +29 -0
- data/examples/passing/options_formatter.rb +20 -0
- data/examples/passing/partial_mock_example.rb +27 -0
- data/examples/passing/pending_example.rb +18 -0
- data/examples/passing/predicate_example.rb +25 -0
- data/examples/passing/shared_example_group_example.rb +43 -0
- data/examples/passing/shared_stack_examples.rb +36 -0
- data/examples/passing/simple_matcher_example.rb +29 -0
- data/examples/passing/stack.rb +36 -0
- data/examples/passing/stack_spec.rb +63 -0
- data/examples/passing/stack_spec_with_nested_example_groups.rb +66 -0
- data/examples/passing/stubbing_example.rb +67 -0
- data/examples/passing/yielding_example.rb +31 -0
- data/examples/ruby1.9.compatibility/access_to_constants_spec.rb +85 -0
- data/features-pending/cli/conditional_exclusion.feature +39 -0
- data/features-pending/heckle/heckle.feature +56 -0
- data/features/before_and_after_blocks/before_and_after_blocks.feature +167 -0
- data/features/command_line/line_number_option.feature +56 -0
- data/features/command_line/line_number_option_with_example_with_no_name.feature +22 -0
- data/features/example_groups/define_example_attribute.feature +41 -0
- data/features/example_groups/example_group_with_should_methods.feature +29 -0
- data/features/example_groups/implicit_docstrings.feature +59 -0
- data/features/example_groups/nested_groups.feature +32 -0
- data/features/expectations/customized_message.feature +54 -0
- data/features/expectations/expect_change.feature +65 -0
- data/features/expectations/expect_error.feature +44 -0
- data/features/extensions/custom_example_group.feature +19 -0
- data/features/formatters/custom_formatter.feature +30 -0
- data/features/formatters/nested_formatter.feature +32 -0
- data/features/interop/cucumber_stubs_dont_leak.feature +11 -0
- data/features/interop/examples_and_tests_together.feature +84 -0
- data/features/interop/rspec_output.feature +25 -0
- data/features/interop/test_but_not_test_unit.feature +26 -0
- data/features/interop/test_case_with_should_methods.feature +46 -0
- data/features/load_paths/add_lib_to_load_path.feature +20 -0
- data/features/load_paths/add_spec_to_load_path.feature +20 -0
- data/features/matchers/define_diffable_matcher.feature +26 -0
- data/features/matchers/define_matcher.feature +179 -0
- data/features/matchers/define_matcher_outside_rspec.feature +37 -0
- data/features/matchers/define_matcher_with_fluent_interface.feature +48 -0
- data/features/matchers/define_wrapped_matcher.feature +56 -0
- data/features/matchers/match_unless_raises.feature +60 -0
- data/features/matchers/match_unless_raises_unexpected_error.feature +39 -0
- data/features/mock_framework_integration/use_flexmock.feature +27 -0
- data/features/mock_framework_integration/use_mocha.feature +27 -0
- data/features/mock_framework_integration/use_rr.feature +27 -0
- data/features/mocks/block_local_expectations.feature +62 -0
- data/features/mocks/mix_stubs_and_mocks.feature +22 -0
- data/features/mocks/stub_implementation.feature +26 -0
- data/features/pending/pending_examples.feature +81 -0
- data/features/runner/specify_line_number.feature +32 -0
- data/features/spec_helper/spec_helper.feature +25 -0
- data/features/step_definitions/running_rspec_steps.rb +52 -0
- data/features/step_definitions/stubbing_steps.rb +16 -0
- data/features/subject/explicit_subject.feature +31 -0
- data/features/subject/implicit_subject.feature +43 -0
- data/features/support/env.rb +83 -0
- data/features/support/matchers/smart_match.rb +31 -0
- data/init.rb +9 -0
- data/lib/autotest/discover.rb +3 -0
- data/lib/autotest/rspec.rb +54 -0
- data/lib/spec.rb +8 -0
- data/lib/spec/adapters/mock_frameworks/flexmock.rb +24 -0
- data/lib/spec/adapters/mock_frameworks/mocha.rb +25 -0
- data/lib/spec/adapters/mock_frameworks/rr.rb +22 -0
- data/lib/spec/adapters/mock_frameworks/rspec.rb +21 -0
- data/lib/spec/autorun.rb +3 -0
- data/lib/spec/deprecation.rb +41 -0
- data/lib/spec/dsl.rb +1 -0
- data/lib/spec/dsl/main.rb +93 -0
- data/lib/spec/example.rb +164 -0
- data/lib/spec/example/args_and_options.rb +27 -0
- data/lib/spec/example/before_and_after_hooks.rb +93 -0
- data/lib/spec/example/errors.rb +25 -0
- data/lib/spec/example/example_group.rb +10 -0
- data/lib/spec/example/example_group_factory.rb +82 -0
- data/lib/spec/example/example_group_hierarchy.rb +53 -0
- data/lib/spec/example/example_group_methods.rb +287 -0
- data/lib/spec/example/example_group_proxy.rb +61 -0
- data/lib/spec/example/example_matcher.rb +43 -0
- data/lib/spec/example/example_methods.rb +152 -0
- data/lib/spec/example/example_proxy.rb +41 -0
- data/lib/spec/example/module_reopening_fix.rb +43 -0
- data/lib/spec/example/pending.rb +18 -0
- data/lib/spec/example/predicate_matchers.rb +46 -0
- data/lib/spec/example/shared_example_group.rb +59 -0
- data/lib/spec/example/subject.rb +114 -0
- data/lib/spec/expectations.rb +35 -0
- data/lib/spec/expectations/errors.rb +12 -0
- data/lib/spec/expectations/extensions.rb +1 -0
- data/lib/spec/expectations/extensions/kernel.rb +52 -0
- data/lib/spec/expectations/fail_with.rb +45 -0
- data/lib/spec/expectations/handler.rb +50 -0
- data/lib/spec/extensions/instance_exec.rb +31 -0
- data/lib/spec/interop/test.rb +44 -0
- data/lib/spec/interop/test/unit/autorunner.rb +6 -0
- data/lib/spec/interop/test/unit/testcase.rb +56 -0
- data/lib/spec/interop/test/unit/testresult.rb +6 -0
- data/lib/spec/interop/test/unit/testsuite_adapter.rb +36 -0
- data/lib/spec/interop/test/unit/ui/console/testrunner.rb +61 -0
- data/lib/spec/matchers.rb +214 -0
- data/lib/spec/matchers/be.rb +249 -0
- data/lib/spec/matchers/be_close.rb +32 -0
- data/lib/spec/matchers/be_instance_of.rb +26 -0
- data/lib/spec/matchers/be_kind_of.rb +26 -0
- data/lib/spec/matchers/change.rb +151 -0
- data/lib/spec/matchers/compatibility.rb +14 -0
- data/lib/spec/matchers/dsl.rb +20 -0
- data/lib/spec/matchers/eql.rb +42 -0
- data/lib/spec/matchers/equal.rb +53 -0
- data/lib/spec/matchers/errors.rb +5 -0
- data/lib/spec/matchers/exist.rb +16 -0
- data/lib/spec/matchers/generated_descriptions.rb +36 -0
- data/lib/spec/matchers/has.rb +35 -0
- data/lib/spec/matchers/have.rb +152 -0
- data/lib/spec/matchers/include.rb +44 -0
- data/lib/spec/matchers/match.rb +21 -0
- data/lib/spec/matchers/match_array.rb +71 -0
- data/lib/spec/matchers/matcher.rb +132 -0
- data/lib/spec/matchers/method_missing.rb +9 -0
- data/lib/spec/matchers/operator_matcher.rb +83 -0
- data/lib/spec/matchers/pretty.rb +37 -0
- data/lib/spec/matchers/raise_exception.rb +131 -0
- data/lib/spec/matchers/respond_to.rb +71 -0
- data/lib/spec/matchers/satisfy.rb +47 -0
- data/lib/spec/matchers/simple_matcher.rb +134 -0
- data/lib/spec/matchers/throw_symbol.rb +100 -0
- data/lib/spec/matchers/wrap_expectation.rb +55 -0
- data/lib/spec/mocks.rb +200 -0
- data/lib/spec/mocks/argument_expectation.rb +51 -0
- data/lib/spec/mocks/argument_matchers.rb +237 -0
- data/lib/spec/mocks/error_generator.rb +92 -0
- data/lib/spec/mocks/errors.rb +10 -0
- data/lib/spec/mocks/example_methods.rb +69 -0
- data/lib/spec/mocks/extensions.rb +1 -0
- data/lib/spec/mocks/extensions/object.rb +3 -0
- data/lib/spec/mocks/framework.rb +15 -0
- data/lib/spec/mocks/message_expectation.rb +344 -0
- data/lib/spec/mocks/methods.rb +94 -0
- data/lib/spec/mocks/mock.rb +71 -0
- data/lib/spec/mocks/order_group.rb +29 -0
- data/lib/spec/mocks/proxy.rb +254 -0
- data/lib/spec/mocks/space.rb +28 -0
- data/lib/spec/rake/spectask.rb +230 -0
- data/lib/spec/rake/verify_rcov.rb +52 -0
- data/lib/spec/ruby.rb +9 -0
- data/lib/spec/runner.rb +66 -0
- data/lib/spec/runner/backtrace_tweaker.rb +78 -0
- data/lib/spec/runner/class_and_arguments_parser.rb +14 -0
- data/lib/spec/runner/command_line.rb +15 -0
- data/lib/spec/runner/configuration.rb +202 -0
- data/lib/spec/runner/differs/default.rb +93 -0
- data/lib/spec/runner/differs/load-diff-lcs.rb +12 -0
- data/lib/spec/runner/drb_command_line.rb +32 -0
- data/lib/spec/runner/example_group_runner.rb +62 -0
- data/lib/spec/runner/extensions/kernel.rb +9 -0
- data/lib/spec/runner/formatter/base_formatter.rb +139 -0
- data/lib/spec/runner/formatter/base_text_formatter.rb +142 -0
- data/lib/spec/runner/formatter/failing_example_groups_formatter.rb +25 -0
- data/lib/spec/runner/formatter/failing_examples_formatter.rb +20 -0
- data/lib/spec/runner/formatter/html_formatter.rb +338 -0
- data/lib/spec/runner/formatter/nested_text_formatter.rb +50 -0
- data/lib/spec/runner/formatter/no_op_method_missing.rb +21 -0
- data/lib/spec/runner/formatter/profile_formatter.rb +47 -0
- data/lib/spec/runner/formatter/progress_bar_formatter.rb +33 -0
- data/lib/spec/runner/formatter/silent_formatter.rb +10 -0
- data/lib/spec/runner/formatter/snippet_extractor.rb +52 -0
- data/lib/spec/runner/formatter/specdoc_formatter.rb +33 -0
- data/lib/spec/runner/formatter/text_mate_formatter.rb +16 -0
- data/lib/spec/runner/heckle_runner.rb +77 -0
- data/lib/spec/runner/heckle_runner_unsupported.rb +10 -0
- data/lib/spec/runner/line_number_query.rb +78 -0
- data/lib/spec/runner/option_parser.rb +225 -0
- data/lib/spec/runner/options.rb +406 -0
- data/lib/spec/runner/reporter.rb +171 -0
- data/lib/spec/stubs/cucumber.rb +5 -0
- data/lib/spec/test/unit.rb +10 -0
- data/lib/spec/version.rb +14 -0
- data/resources/helpers/cmdline.rb +8 -0
- data/resources/rake/examples.rake +7 -0
- data/resources/rake/examples_with_rcov.rake +9 -0
- data/resources/rake/failing_examples_with_html.rake +9 -0
- data/resources/rake/verify_rcov.rake +7 -0
- data/rspec.gemspec +26 -0
- data/spec/README.jruby +15 -0
- data/spec/autotest/autotest_helper.rb +8 -0
- data/spec/autotest/autotest_matchers.rb +38 -0
- data/spec/autotest/discover_spec.rb +8 -0
- data/spec/autotest/failed_results_re_spec.rb +31 -0
- data/spec/autotest/rspec_spec.rb +126 -0
- data/spec/ruby_forker.rb +13 -0
- data/spec/spec.opts +6 -0
- data/spec/spec/dsl/main_spec.rb +103 -0
- data/spec/spec/example/example_group_class_definition_spec.rb +51 -0
- data/spec/spec/example/example_group_factory_spec.rb +180 -0
- data/spec/spec/example/example_group_methods_spec.rb +778 -0
- data/spec/spec/example/example_group_proxy_spec.rb +107 -0
- data/spec/spec/example/example_group_spec.rb +632 -0
- data/spec/spec/example/example_matcher_spec.rb +85 -0
- data/spec/spec/example/example_methods_spec.rb +162 -0
- data/spec/spec/example/example_proxy_spec.rb +57 -0
- data/spec/spec/example/helper_method_spec.rb +24 -0
- data/spec/spec/example/nested_example_group_spec.rb +71 -0
- data/spec/spec/example/pending_module_spec.rb +58 -0
- data/spec/spec/example/predicate_matcher_spec.rb +41 -0
- data/spec/spec/example/shared_example_group_spec.rb +257 -0
- data/spec/spec/example/subclassing_example_group_spec.rb +25 -0
- data/spec/spec/example/subject_spec.rb +110 -0
- data/spec/spec/expectations/differs/default_spec.rb +194 -0
- data/spec/spec/expectations/extensions/kernel_spec.rb +45 -0
- data/spec/spec/expectations/fail_with_spec.rb +96 -0
- data/spec/spec/expectations/handler_spec.rb +206 -0
- data/spec/spec/expectations/wrap_expectation_spec.rb +31 -0
- data/spec/spec/interop/test/unit/resources/spec_that_fails.rb +10 -0
- data/spec/spec/interop/test/unit/resources/spec_that_passes.rb +10 -0
- data/spec/spec/interop/test/unit/resources/spec_with_errors.rb +10 -0
- data/spec/spec/interop/test/unit/resources/spec_with_options_hash.rb +13 -0
- data/spec/spec/interop/test/unit/resources/test_case_that_fails.rb +10 -0
- data/spec/spec/interop/test/unit/resources/test_case_that_passes.rb +10 -0
- data/spec/spec/interop/test/unit/resources/test_case_with_errors.rb +10 -0
- data/spec/spec/interop/test/unit/resources/test_case_with_various_names.rb +22 -0
- data/spec/spec/interop/test/unit/resources/testsuite_adapter_spec_with_test_unit.rb +38 -0
- data/spec/spec/interop/test/unit/spec_spec.rb +48 -0
- data/spec/spec/interop/test/unit/test_unit_spec_helper.rb +18 -0
- data/spec/spec/interop/test/unit/testcase_spec.rb +50 -0
- data/spec/spec/interop/test/unit/testsuite_adapter_spec.rb +9 -0
- data/spec/spec/matchers/be_close_spec.rb +50 -0
- data/spec/spec/matchers/be_instance_of_spec.rb +36 -0
- data/spec/spec/matchers/be_kind_of_spec.rb +33 -0
- data/spec/spec/matchers/be_spec.rb +460 -0
- data/spec/spec/matchers/change_spec.rb +349 -0
- data/spec/spec/matchers/compatibility_spec.rb +28 -0
- data/spec/spec/matchers/description_generation_spec.rb +160 -0
- data/spec/spec/matchers/dsl_spec.rb +34 -0
- data/spec/spec/matchers/eql_spec.rb +33 -0
- data/spec/spec/matchers/equal_spec.rb +57 -0
- data/spec/spec/matchers/exist_spec.rb +65 -0
- data/spec/spec/matchers/has_spec.rb +190 -0
- data/spec/spec/matchers/have_spec.rb +381 -0
- data/spec/spec/matchers/include_spec.rb +88 -0
- data/spec/spec/matchers/match_array_spec.rb +115 -0
- data/spec/spec/matchers/match_spec.rb +57 -0
- data/spec/spec/matchers/matcher_spec.rb +289 -0
- data/spec/spec/matchers/matchers_spec.rb +2 -0
- data/spec/spec/matchers/operator_matcher_spec.rb +191 -0
- data/spec/spec/matchers/pretty_spec.rb +22 -0
- data/spec/spec/matchers/raise_exception_spec.rb +345 -0
- data/spec/spec/matchers/respond_to_spec.rb +116 -0
- data/spec/spec/matchers/satisfy_spec.rb +36 -0
- data/spec/spec/matchers/simple_matcher_spec.rb +100 -0
- data/spec/spec/matchers/throw_symbol_spec.rb +121 -0
- data/spec/spec/mocks/and_yield_spec.rb +117 -0
- data/spec/spec/mocks/any_number_of_times_spec.rb +36 -0
- data/spec/spec/mocks/argument_expectation_spec.rb +23 -0
- data/spec/spec/mocks/argument_matchers_spec.rb +19 -0
- data/spec/spec/mocks/at_least_spec.rb +97 -0
- data/spec/spec/mocks/at_most_spec.rb +93 -0
- data/spec/spec/mocks/bug_report_10260_spec.rb +8 -0
- data/spec/spec/mocks/bug_report_10263_spec.rb +27 -0
- data/spec/spec/mocks/bug_report_1049_spec.rb +30 -0
- data/spec/spec/mocks/bug_report_11545_spec.rb +32 -0
- data/spec/spec/mocks/bug_report_15719_spec.rb +30 -0
- data/spec/spec/mocks/bug_report_496_spec.rb +17 -0
- data/spec/spec/mocks/bug_report_600_spec.rb +22 -0
- data/spec/spec/mocks/bug_report_7611_spec.rb +19 -0
- data/spec/spec/mocks/bug_report_7805_spec.rb +22 -0
- data/spec/spec/mocks/bug_report_8165_spec.rb +31 -0
- data/spec/spec/mocks/bug_report_8302_spec.rb +26 -0
- data/spec/spec/mocks/bug_report_830_spec.rb +21 -0
- data/spec/spec/mocks/bug_report_957_spec.rb +22 -0
- data/spec/spec/mocks/double_spec.rb +12 -0
- data/spec/spec/mocks/failing_argument_matchers_spec.rb +95 -0
- data/spec/spec/mocks/hash_including_matcher_spec.rb +90 -0
- data/spec/spec/mocks/hash_not_including_matcher_spec.rb +67 -0
- data/spec/spec/mocks/mock_ordering_spec.rb +94 -0
- data/spec/spec/mocks/mock_space_spec.rb +54 -0
- data/spec/spec/mocks/mock_spec.rb +601 -0
- data/spec/spec/mocks/multiple_return_value_spec.rb +113 -0
- data/spec/spec/mocks/nil_expectation_warning_spec.rb +53 -0
- data/spec/spec/mocks/null_object_mock_spec.rb +54 -0
- data/spec/spec/mocks/once_counts_spec.rb +53 -0
- data/spec/spec/mocks/options_hash_spec.rb +35 -0
- data/spec/spec/mocks/partial_mock_spec.rb +164 -0
- data/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb +66 -0
- data/spec/spec/mocks/passing_argument_matchers_spec.rb +145 -0
- data/spec/spec/mocks/precise_counts_spec.rb +52 -0
- data/spec/spec/mocks/record_messages_spec.rb +26 -0
- data/spec/spec/mocks/stub_chain_spec.rb +42 -0
- data/spec/spec/mocks/stub_implementation_spec.rb +31 -0
- data/spec/spec/mocks/stub_spec.rb +203 -0
- data/spec/spec/mocks/stubbed_message_expectations_spec.rb +26 -0
- data/spec/spec/mocks/twice_counts_spec.rb +67 -0
- data/spec/spec/mocks/unstub_spec.rb +127 -0
- data/spec/spec/package/bin_spec_spec.rb +16 -0
- data/spec/spec/rake/spectask_spec.rb +150 -0
- data/spec/spec/runner/class_and_argument_parser_spec.rb +23 -0
- data/spec/spec/runner/command_line_spec.rb +162 -0
- data/spec/spec/runner/configuration_spec.rb +320 -0
- data/spec/spec/runner/drb_command_line_spec.rb +146 -0
- data/spec/spec/runner/empty_file.txt +0 -0
- data/spec/spec/runner/example_group_runner_spec.rb +26 -0
- data/spec/spec/runner/examples.txt +2 -0
- data/spec/spec/runner/failed.txt +3 -0
- data/spec/spec/runner/formatter/base_formatter_spec.rb +30 -0
- data/spec/spec/runner/formatter/base_text_formatter_spec.rb +113 -0
- data/spec/spec/runner/formatter/failing_example_groups_formatter_spec.rb +45 -0
- data/spec/spec/runner/formatter/failing_examples_formatter_spec.rb +33 -0
- data/spec/spec/runner/formatter/html_formatted-1.8.6-jruby.html +377 -0
- data/spec/spec/runner/formatter/html_formatted-1.8.6.html +377 -0
- data/spec/spec/runner/formatter/html_formatted-1.8.7.html +377 -0
- data/spec/spec/runner/formatter/html_formatted-1.9.1.html +377 -0
- data/spec/spec/runner/formatter/html_formatted-1.9.2.html +377 -0
- data/spec/spec/runner/formatter/html_formatter_spec.rb +118 -0
- data/spec/spec/runner/formatter/nested_text_formatter_spec.rb +329 -0
- data/spec/spec/runner/formatter/profile_formatter_spec.rb +70 -0
- data/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +149 -0
- data/spec/spec/runner/formatter/snippet_extractor_spec.rb +18 -0
- data/spec/spec/runner/formatter/specdoc_formatter_spec.rb +159 -0
- data/spec/spec/runner/formatter/text_mate_formatted-1.8.6-jruby.html +371 -0
- data/spec/spec/runner/formatter/text_mate_formatted-1.8.6.html +371 -0
- data/spec/spec/runner/formatter/text_mate_formatted-1.8.7.html +371 -0
- data/spec/spec/runner/formatter/text_mate_formatted-1.9.1.html +371 -0
- data/spec/spec/runner/formatter/text_mate_formatted-1.9.2.html +371 -0
- data/spec/spec/runner/formatter/text_mate_formatter_spec.rb +106 -0
- data/spec/spec/runner/heckle_runner_spec.rb +78 -0
- data/spec/spec/runner/heckler_spec.rb +20 -0
- data/spec/spec/runner/line_number_query/line_number_query_fixture.rb +70 -0
- data/spec/spec/runner/line_number_query_spec.rb +129 -0
- data/spec/spec/runner/noisy_backtrace_tweaker_spec.rb +51 -0
- data/spec/spec/runner/option_parser_spec.rb +552 -0
- data/spec/spec/runner/options_spec.rb +554 -0
- data/spec/spec/runner/output_one_time_fixture.rb +7 -0
- data/spec/spec/runner/output_one_time_fixture_runner.rb +7 -0
- data/spec/spec/runner/output_one_time_spec.rb +15 -0
- data/spec/spec/runner/quiet_backtrace_tweaker_spec.rb +123 -0
- data/spec/spec/runner/reporter_spec.rb +244 -0
- data/spec/spec/runner/resources/a_bar.rb +0 -0
- data/spec/spec/runner/resources/a_foo.rb +0 -0
- data/spec/spec/runner/resources/a_spec.rb +1 -0
- data/spec/spec/runner/resources/custom_example_group_runner.rb +14 -0
- data/spec/spec/runner/resources/utf8_encoded.rb +8 -0
- data/spec/spec/runner/spec.opts +2 -0
- data/spec/spec/runner/spec_drb.opts +2 -0
- data/spec/spec/runner/spec_spaced.opts +2 -0
- data/spec/spec/runner_spec.rb +13 -0
- data/spec/spec_helper.rb +113 -0
- data/spec/support/macros.rb +29 -0
- data/spec/support/spec_classes.rb +133 -0
- 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
|