pupu 0.0.2 → 0.0.3.pre
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +9 -0
- data/Gemfile +9 -0
- data/LICENSE +1 -1
- data/examples/merb/.gitignore +21 -0
- data/examples/merb/public/pupu/autocompleter/.gitignore +5 -0
- data/examples/merb/public/pupu/blueprint/.gitignore +5 -0
- data/examples/merb/public/pupu/flash/.gitignore +5 -0
- data/examples/merb/public/pupu/lighter/.gitignore +10 -0
- data/{vendor/media-path/spec/stubs/blog/public/js/moo.js → examples/merb/public/pupu/lighter/images/.gitignore} +0 -0
- data/examples/merb/public/pupu/mootools/.gitignore +5 -0
- data/examples/rango/media/pupu/autocompleter/.gitignore +5 -0
- data/examples/rango/media/pupu/blueprint/.gitignore +5 -0
- data/examples/rango/media/pupu/flash/.gitignore +5 -0
- data/examples/rango/media/pupu/lighter/.gitignore +10 -0
- data/{vendor/rspec/spec/spec/runner/empty_file.txt → examples/rango/media/pupu/lighter/images/.gitignore} +0 -0
- data/examples/rango/media/pupu/mootools/.gitignore +5 -0
- data/lib/pupu/adapters/rango.rb +3 -3
- data/pupu.gemspec +7 -16
- data/pupu.pre.gemspec +8 -0
- data/spec/data/public/pupu/autocompleter/.gitignore +5 -0
- data/stubs/pupu/content/.gitignore +9 -0
- data/stubs/pupu/content/config.rb.rbt +2 -0
- data/{vendor/rspec/spec/spec/runner/resources/a_bar.rb → stubs/pupu/content/images/.gitignore} +0 -0
- data/tasks.rb +37 -0
- metadata +82 -461
- data/Rakefile +0 -79
- data/examples/merb/public/pupu/lighter/metadata.yml +0 -5
- data/examples/rango/media/pupu/lighter/metadata.yml +0 -5
- data/pupu-0.0.1.gem +0 -0
- data/vendor/media-path/CHANGELOG +0 -3
- data/vendor/media-path/LICENSE +0 -20
- data/vendor/media-path/README.textile +0 -40
- data/vendor/media-path/Rakefile +0 -61
- data/vendor/media-path/TODO.txt +0 -6
- data/vendor/media-path/deps.rip +0 -5
- data/vendor/media-path/lib/media-path.rb +0 -269
- data/vendor/media-path/media-path.gemspec +0 -38
- data/vendor/media-path/script/spec +0 -14
- data/vendor/media-path/spec/media-path_spec.rb +0 -158
- data/vendor/media-path/spec/spec.opts +0 -5
- data/vendor/rspec/History.rdoc +0 -1510
- data/vendor/rspec/License.txt +0 -22
- data/vendor/rspec/Manifest.txt +0 -383
- data/vendor/rspec/README.rdoc +0 -55
- data/vendor/rspec/Rakefile +0 -145
- data/vendor/rspec/Ruby1.9.rdoc +0 -31
- data/vendor/rspec/TODO.txt +0 -17
- data/vendor/rspec/Upgrade.rdoc +0 -199
- data/vendor/rspec/bin/autospec +0 -4
- data/vendor/rspec/bin/spec +0 -5
- data/vendor/rspec/cucumber.yml +0 -5
- data/vendor/rspec/examples/failing/README.txt +0 -11
- data/vendor/rspec/examples/failing/diffing_spec.rb +0 -36
- data/vendor/rspec/examples/failing/failing_implicit_docstrings_example.rb +0 -17
- data/vendor/rspec/examples/failing/failure_in_after.rb +0 -10
- data/vendor/rspec/examples/failing/failure_in_before.rb +0 -10
- data/vendor/rspec/examples/failing/mocking_example.rb +0 -38
- data/vendor/rspec/examples/failing/mocking_with_flexmock.rb +0 -26
- data/vendor/rspec/examples/failing/mocking_with_mocha.rb +0 -25
- data/vendor/rspec/examples/failing/mocking_with_rr.rb +0 -27
- data/vendor/rspec/examples/failing/partial_mock_example.rb +0 -18
- data/vendor/rspec/examples/failing/pending_example.rb +0 -7
- data/vendor/rspec/examples/failing/predicate_example.rb +0 -32
- data/vendor/rspec/examples/failing/raising_example.rb +0 -47
- data/vendor/rspec/examples/failing/syntax_error_example.rb +0 -7
- data/vendor/rspec/examples/failing/team_spec.rb +0 -41
- data/vendor/rspec/examples/failing/timeout_behaviour.rb +0 -5
- data/vendor/rspec/examples/passing/custom_formatter.rb +0 -11
- data/vendor/rspec/examples/passing/custom_matchers.rb +0 -54
- data/vendor/rspec/examples/passing/dynamic_spec.rb +0 -7
- data/vendor/rspec/examples/passing/file_accessor.rb +0 -18
- data/vendor/rspec/examples/passing/file_accessor_spec.rb +0 -37
- data/vendor/rspec/examples/passing/filtered_formatter.rb +0 -17
- data/vendor/rspec/examples/passing/filtered_formatter_example.rb +0 -31
- data/vendor/rspec/examples/passing/greeter_spec.rb +0 -30
- data/vendor/rspec/examples/passing/helper_method_example.rb +0 -12
- data/vendor/rspec/examples/passing/implicit_docstrings_example.rb +0 -16
- data/vendor/rspec/examples/passing/io_processor.rb +0 -8
- data/vendor/rspec/examples/passing/io_processor_spec.rb +0 -20
- data/vendor/rspec/examples/passing/mocking_example.rb +0 -25
- data/vendor/rspec/examples/passing/multi_threaded_example_group_runner.rb +0 -26
- data/vendor/rspec/examples/passing/nested_classes_example.rb +0 -35
- data/vendor/rspec/examples/passing/options_example.rb +0 -29
- data/vendor/rspec/examples/passing/options_formatter.rb +0 -20
- data/vendor/rspec/examples/passing/partial_mock_example.rb +0 -27
- data/vendor/rspec/examples/passing/pending_example.rb +0 -18
- data/vendor/rspec/examples/passing/predicate_example.rb +0 -25
- data/vendor/rspec/examples/passing/shared_example_group_example.rb +0 -79
- data/vendor/rspec/examples/passing/shared_stack_examples.rb +0 -36
- data/vendor/rspec/examples/passing/simple_matcher_example.rb +0 -29
- data/vendor/rspec/examples/passing/stack.rb +0 -36
- data/vendor/rspec/examples/passing/stack_spec.rb +0 -63
- data/vendor/rspec/examples/passing/stack_spec_with_nested_example_groups.rb +0 -66
- data/vendor/rspec/examples/passing/stubbing_example.rb +0 -67
- data/vendor/rspec/examples/passing/yielding_example.rb +0 -31
- data/vendor/rspec/examples/ruby1.9.compatibility/access_to_constants_spec.rb +0 -85
- data/vendor/rspec/features/before_and_after_blocks/before_and_after_blocks.feature +0 -167
- data/vendor/rspec/features/command_line/line_number_option.feature +0 -56
- data/vendor/rspec/features/command_line/line_number_option_with_example_with_no_name.feature +0 -22
- data/vendor/rspec/features/example_groups/define_example_attribute.feature +0 -41
- data/vendor/rspec/features/example_groups/example_group_with_should_methods.feature +0 -29
- data/vendor/rspec/features/example_groups/implicit_docstrings.feature +0 -59
- data/vendor/rspec/features/example_groups/nested_groups.feature +0 -32
- data/vendor/rspec/features/expectations/customized_message.feature +0 -54
- data/vendor/rspec/features/expectations/expect_change.feature +0 -65
- data/vendor/rspec/features/expectations/expect_error.feature +0 -44
- data/vendor/rspec/features/extensions/custom_example_group.feature +0 -19
- data/vendor/rspec/features/formatters/custom_formatter.feature +0 -30
- data/vendor/rspec/features/interop/examples_and_tests_together.feature +0 -84
- data/vendor/rspec/features/interop/rspec_output.feature +0 -25
- data/vendor/rspec/features/interop/test_but_not_test_unit.feature +0 -26
- data/vendor/rspec/features/interop/test_case_with_should_methods.feature +0 -46
- data/vendor/rspec/features/load_paths/add_lib_to_load_path.feature +0 -20
- data/vendor/rspec/features/load_paths/add_spec_to_load_path.feature +0 -20
- data/vendor/rspec/features/matchers/define_diffable_matcher.feature +0 -26
- data/vendor/rspec/features/matchers/define_matcher.feature +0 -179
- data/vendor/rspec/features/matchers/define_matcher_outside_rspec.feature +0 -38
- data/vendor/rspec/features/matchers/define_matcher_with_fluent_interface.feature +0 -27
- data/vendor/rspec/features/matchers/define_wrapped_matcher.feature +0 -29
- data/vendor/rspec/features/matchers/match_unless_raises.feature +0 -60
- data/vendor/rspec/features/matchers/match_unless_raises_unexpected_error.feature +0 -39
- data/vendor/rspec/features/mock_framework_integration/use_flexmock.feature +0 -27
- data/vendor/rspec/features/mock_framework_integration/use_mocha.feature +0 -27
- data/vendor/rspec/features/mock_framework_integration/use_rr.feature +0 -27
- data/vendor/rspec/features/mocks/block_local_expectations.feature +0 -62
- data/vendor/rspec/features/mocks/mix_stubs_and_mocks.feature +0 -22
- data/vendor/rspec/features/mocks/stub_implementation.feature +0 -26
- data/vendor/rspec/features/pending/pending_examples.feature +0 -81
- data/vendor/rspec/features/runner/specify_line_number.feature +0 -32
- data/vendor/rspec/features/spec_helper/spec_helper.feature +0 -25
- data/vendor/rspec/features/step_definitions/running_rspec_steps.rb +0 -43
- data/vendor/rspec/features/subject/explicit_subject.feature +0 -31
- data/vendor/rspec/features/subject/implicit_subject.feature +0 -43
- data/vendor/rspec/features/support/env.rb +0 -82
- data/vendor/rspec/features/support/matchers/smart_match.rb +0 -12
- data/vendor/rspec/features-pending/cli/conditional_exclusion.feature +0 -39
- data/vendor/rspec/features-pending/heckle/heckle.feature +0 -56
- data/vendor/rspec/geminstaller.yml +0 -28
- data/vendor/rspec/init.rb +0 -9
- data/vendor/rspec/lib/autotest/discover.rb +0 -3
- data/vendor/rspec/lib/autotest/rspec.rb +0 -54
- data/vendor/rspec/lib/spec/adapters/mock_frameworks/flexmock.rb +0 -24
- data/vendor/rspec/lib/spec/adapters/mock_frameworks/mocha.rb +0 -25
- data/vendor/rspec/lib/spec/adapters/mock_frameworks/rr.rb +0 -22
- data/vendor/rspec/lib/spec/adapters/mock_frameworks/rspec.rb +0 -21
- data/vendor/rspec/lib/spec/autorun.rb +0 -3
- data/vendor/rspec/lib/spec/deprecation.rb +0 -40
- data/vendor/rspec/lib/spec/dsl/main.rb +0 -92
- data/vendor/rspec/lib/spec/dsl.rb +0 -1
- data/vendor/rspec/lib/spec/example/args_and_options.rb +0 -27
- data/vendor/rspec/lib/spec/example/before_and_after_hooks.rb +0 -93
- data/vendor/rspec/lib/spec/example/errors.rb +0 -25
- data/vendor/rspec/lib/spec/example/example_group.rb +0 -10
- data/vendor/rspec/lib/spec/example/example_group_factory.rb +0 -82
- data/vendor/rspec/lib/spec/example/example_group_hierarchy.rb +0 -53
- data/vendor/rspec/lib/spec/example/example_group_methods.rb +0 -282
- data/vendor/rspec/lib/spec/example/example_group_proxy.rb +0 -61
- data/vendor/rspec/lib/spec/example/example_matcher.rb +0 -43
- data/vendor/rspec/lib/spec/example/example_methods.rb +0 -148
- data/vendor/rspec/lib/spec/example/example_proxy.rb +0 -41
- data/vendor/rspec/lib/spec/example/module_reopening_fix.rb +0 -43
- data/vendor/rspec/lib/spec/example/pending.rb +0 -18
- data/vendor/rspec/lib/spec/example/predicate_matchers.rb +0 -46
- data/vendor/rspec/lib/spec/example/shared_example_group.rb +0 -59
- data/vendor/rspec/lib/spec/example/subject.rb +0 -108
- data/vendor/rspec/lib/spec/example.rb +0 -164
- data/vendor/rspec/lib/spec/expectations/errors.rb +0 -12
- data/vendor/rspec/lib/spec/expectations/extensions/kernel.rb +0 -52
- data/vendor/rspec/lib/spec/expectations/extensions.rb +0 -1
- data/vendor/rspec/lib/spec/expectations/fail_with.rb +0 -45
- data/vendor/rspec/lib/spec/expectations/handler.rb +0 -50
- data/vendor/rspec/lib/spec/expectations.rb +0 -35
- data/vendor/rspec/lib/spec/extensions/instance_exec.rb +0 -31
- data/vendor/rspec/lib/spec/interop/test/unit/autorunner.rb +0 -6
- data/vendor/rspec/lib/spec/interop/test/unit/testcase.rb +0 -56
- data/vendor/rspec/lib/spec/interop/test/unit/testresult.rb +0 -6
- data/vendor/rspec/lib/spec/interop/test/unit/testsuite_adapter.rb +0 -34
- data/vendor/rspec/lib/spec/interop/test/unit/ui/console/testrunner.rb +0 -61
- data/vendor/rspec/lib/spec/interop/test.rb +0 -44
- data/vendor/rspec/lib/spec/matchers/be.rb +0 -211
- data/vendor/rspec/lib/spec/matchers/be_close.rb +0 -32
- data/vendor/rspec/lib/spec/matchers/be_instance_of.rb +0 -26
- data/vendor/rspec/lib/spec/matchers/be_kind_of.rb +0 -26
- data/vendor/rspec/lib/spec/matchers/change.rb +0 -151
- data/vendor/rspec/lib/spec/matchers/compatibility.rb +0 -14
- data/vendor/rspec/lib/spec/matchers/dsl.rb +0 -20
- data/vendor/rspec/lib/spec/matchers/eql.rb +0 -42
- data/vendor/rspec/lib/spec/matchers/equal.rb +0 -53
- data/vendor/rspec/lib/spec/matchers/errors.rb +0 -5
- data/vendor/rspec/lib/spec/matchers/exist.rb +0 -16
- data/vendor/rspec/lib/spec/matchers/generated_descriptions.rb +0 -36
- data/vendor/rspec/lib/spec/matchers/has.rb +0 -35
- data/vendor/rspec/lib/spec/matchers/have.rb +0 -152
- data/vendor/rspec/lib/spec/matchers/include.rb +0 -44
- data/vendor/rspec/lib/spec/matchers/match.rb +0 -21
- data/vendor/rspec/lib/spec/matchers/match_array.rb +0 -71
- data/vendor/rspec/lib/spec/matchers/matcher.rb +0 -102
- data/vendor/rspec/lib/spec/matchers/method_missing.rb +0 -9
- data/vendor/rspec/lib/spec/matchers/operator_matcher.rb +0 -78
- data/vendor/rspec/lib/spec/matchers/pretty.rb +0 -37
- data/vendor/rspec/lib/spec/matchers/raise_error.rb +0 -129
- data/vendor/rspec/lib/spec/matchers/respond_to.rb +0 -71
- data/vendor/rspec/lib/spec/matchers/satisfy.rb +0 -47
- data/vendor/rspec/lib/spec/matchers/simple_matcher.rb +0 -133
- data/vendor/rspec/lib/spec/matchers/throw_symbol.rb +0 -104
- data/vendor/rspec/lib/spec/matchers/wrap_expectation.rb +0 -55
- data/vendor/rspec/lib/spec/matchers.rb +0 -195
- data/vendor/rspec/lib/spec/mocks/argument_expectation.rb +0 -51
- data/vendor/rspec/lib/spec/mocks/argument_matchers.rb +0 -237
- data/vendor/rspec/lib/spec/mocks/error_generator.rb +0 -92
- data/vendor/rspec/lib/spec/mocks/errors.rb +0 -10
- data/vendor/rspec/lib/spec/mocks/example_methods.rb +0 -69
- data/vendor/rspec/lib/spec/mocks/extensions/object.rb +0 -3
- data/vendor/rspec/lib/spec/mocks/extensions.rb +0 -1
- data/vendor/rspec/lib/spec/mocks/framework.rb +0 -15
- data/vendor/rspec/lib/spec/mocks/message_expectation.rb +0 -343
- data/vendor/rspec/lib/spec/mocks/methods.rb +0 -89
- data/vendor/rspec/lib/spec/mocks/mock.rb +0 -71
- data/vendor/rspec/lib/spec/mocks/order_group.rb +0 -29
- data/vendor/rspec/lib/spec/mocks/proxy.rb +0 -245
- data/vendor/rspec/lib/spec/mocks/space.rb +0 -28
- data/vendor/rspec/lib/spec/mocks.rb +0 -200
- data/vendor/rspec/lib/spec/rake/spectask.rb +0 -230
- data/vendor/rspec/lib/spec/rake/verify_rcov.rb +0 -52
- data/vendor/rspec/lib/spec/ruby.rb +0 -9
- data/vendor/rspec/lib/spec/runner/backtrace_tweaker.rb +0 -77
- data/vendor/rspec/lib/spec/runner/class_and_arguments_parser.rb +0 -14
- data/vendor/rspec/lib/spec/runner/command_line.rb +0 -15
- data/vendor/rspec/lib/spec/runner/configuration.rb +0 -194
- data/vendor/rspec/lib/spec/runner/differs/default.rb +0 -93
- data/vendor/rspec/lib/spec/runner/differs/load-diff-lcs.rb +0 -12
- data/vendor/rspec/lib/spec/runner/drb_command_line.rb +0 -26
- data/vendor/rspec/lib/spec/runner/example_group_runner.rb +0 -59
- data/vendor/rspec/lib/spec/runner/extensions/kernel.rb +0 -9
- data/vendor/rspec/lib/spec/runner/formatter/base_formatter.rb +0 -139
- data/vendor/rspec/lib/spec/runner/formatter/base_text_formatter.rb +0 -142
- data/vendor/rspec/lib/spec/runner/formatter/failing_example_groups_formatter.rb +0 -25
- data/vendor/rspec/lib/spec/runner/formatter/failing_examples_formatter.rb +0 -20
- data/vendor/rspec/lib/spec/runner/formatter/html_formatter.rb +0 -338
- data/vendor/rspec/lib/spec/runner/formatter/nested_text_formatter.rb +0 -47
- data/vendor/rspec/lib/spec/runner/formatter/no_op_method_missing.rb +0 -21
- data/vendor/rspec/lib/spec/runner/formatter/profile_formatter.rb +0 -47
- data/vendor/rspec/lib/spec/runner/formatter/progress_bar_formatter.rb +0 -33
- data/vendor/rspec/lib/spec/runner/formatter/silent_formatter.rb +0 -10
- data/vendor/rspec/lib/spec/runner/formatter/snippet_extractor.rb +0 -52
- data/vendor/rspec/lib/spec/runner/formatter/specdoc_formatter.rb +0 -33
- data/vendor/rspec/lib/spec/runner/formatter/text_mate_formatter.rb +0 -16
- data/vendor/rspec/lib/spec/runner/heckle_runner.rb +0 -72
- data/vendor/rspec/lib/spec/runner/heckle_runner_unsupported.rb +0 -10
- data/vendor/rspec/lib/spec/runner/line_number_query.rb +0 -78
- data/vendor/rspec/lib/spec/runner/option_parser.rb +0 -223
- data/vendor/rspec/lib/spec/runner/options.rb +0 -400
- data/vendor/rspec/lib/spec/runner/reporter.rb +0 -171
- data/vendor/rspec/lib/spec/runner.rb +0 -66
- data/vendor/rspec/lib/spec/stubs/cucumber.rb +0 -5
- data/vendor/rspec/lib/spec/test/unit.rb +0 -10
- data/vendor/rspec/lib/spec/version.rb +0 -14
- data/vendor/rspec/lib/spec.rb +0 -8
- data/vendor/rspec/resources/helpers/cmdline.rb +0 -8
- data/vendor/rspec/resources/rake/examples.rake +0 -7
- data/vendor/rspec/resources/rake/examples_with_rcov.rake +0 -9
- data/vendor/rspec/resources/rake/failing_examples_with_html.rake +0 -9
- data/vendor/rspec/resources/rake/verify_rcov.rake +0 -7
- data/vendor/rspec/spec/README.jruby +0 -15
- data/vendor/rspec/spec/autotest/autotest_helper.rb +0 -8
- data/vendor/rspec/spec/autotest/autotest_matchers.rb +0 -38
- data/vendor/rspec/spec/autotest/discover_spec.rb +0 -8
- data/vendor/rspec/spec/autotest/failed_results_re_spec.rb +0 -31
- data/vendor/rspec/spec/autotest/rspec_spec.rb +0 -126
- data/vendor/rspec/spec/ruby_forker.rb +0 -13
- data/vendor/rspec/spec/spec/dsl/main_spec.rb +0 -95
- data/vendor/rspec/spec/spec/example/example_group_class_definition_spec.rb +0 -51
- data/vendor/rspec/spec/spec/example/example_group_factory_spec.rb +0 -180
- data/vendor/rspec/spec/spec/example/example_group_methods_spec.rb +0 -759
- data/vendor/rspec/spec/spec/example/example_group_proxy_spec.rb +0 -107
- data/vendor/rspec/spec/spec/example/example_group_spec.rb +0 -643
- data/vendor/rspec/spec/spec/example/example_matcher_spec.rb +0 -86
- data/vendor/rspec/spec/spec/example/example_methods_spec.rb +0 -162
- data/vendor/rspec/spec/spec/example/example_proxy_spec.rb +0 -57
- data/vendor/rspec/spec/spec/example/helper_method_spec.rb +0 -24
- data/vendor/rspec/spec/spec/example/nested_example_group_spec.rb +0 -71
- data/vendor/rspec/spec/spec/example/pending_module_spec.rb +0 -58
- data/vendor/rspec/spec/spec/example/predicate_matcher_spec.rb +0 -41
- data/vendor/rspec/spec/spec/example/shared_example_group_spec.rb +0 -257
- data/vendor/rspec/spec/spec/example/subclassing_example_group_spec.rb +0 -25
- data/vendor/rspec/spec/spec/example/subject_spec.rb +0 -103
- data/vendor/rspec/spec/spec/expectations/differs/default_spec.rb +0 -194
- data/vendor/rspec/spec/spec/expectations/extensions/kernel_spec.rb +0 -45
- data/vendor/rspec/spec/spec/expectations/fail_with_spec.rb +0 -96
- data/vendor/rspec/spec/spec/expectations/handler_spec.rb +0 -206
- data/vendor/rspec/spec/spec/expectations/wrap_expectation_spec.rb +0 -30
- data/vendor/rspec/spec/spec/interop/test/unit/resources/spec_that_fails.rb +0 -10
- data/vendor/rspec/spec/spec/interop/test/unit/resources/spec_that_passes.rb +0 -10
- data/vendor/rspec/spec/spec/interop/test/unit/resources/spec_with_errors.rb +0 -10
- data/vendor/rspec/spec/spec/interop/test/unit/resources/spec_with_options_hash.rb +0 -13
- data/vendor/rspec/spec/spec/interop/test/unit/resources/test_case_that_fails.rb +0 -10
- data/vendor/rspec/spec/spec/interop/test/unit/resources/test_case_that_passes.rb +0 -10
- data/vendor/rspec/spec/spec/interop/test/unit/resources/test_case_with_errors.rb +0 -10
- data/vendor/rspec/spec/spec/interop/test/unit/resources/test_case_with_various_names.rb +0 -22
- data/vendor/rspec/spec/spec/interop/test/unit/resources/testsuite_adapter_spec_with_test_unit.rb +0 -38
- data/vendor/rspec/spec/spec/interop/test/unit/spec_spec.rb +0 -48
- data/vendor/rspec/spec/spec/interop/test/unit/test_unit_spec_helper.rb +0 -18
- data/vendor/rspec/spec/spec/interop/test/unit/testcase_spec.rb +0 -50
- data/vendor/rspec/spec/spec/interop/test/unit/testsuite_adapter_spec.rb +0 -9
- data/vendor/rspec/spec/spec/matchers/be_close_spec.rb +0 -50
- data/vendor/rspec/spec/spec/matchers/be_instance_of_spec.rb +0 -36
- data/vendor/rspec/spec/spec/matchers/be_kind_of_spec.rb +0 -33
- data/vendor/rspec/spec/spec/matchers/be_spec.rb +0 -419
- data/vendor/rspec/spec/spec/matchers/change_spec.rb +0 -349
- data/vendor/rspec/spec/spec/matchers/compatibility_spec.rb +0 -28
- data/vendor/rspec/spec/spec/matchers/description_generation_spec.rb +0 -160
- data/vendor/rspec/spec/spec/matchers/dsl_spec.rb +0 -34
- data/vendor/rspec/spec/spec/matchers/eql_spec.rb +0 -33
- data/vendor/rspec/spec/spec/matchers/equal_spec.rb +0 -57
- data/vendor/rspec/spec/spec/matchers/exist_spec.rb +0 -65
- data/vendor/rspec/spec/spec/matchers/has_spec.rb +0 -190
- data/vendor/rspec/spec/spec/matchers/have_spec.rb +0 -396
- data/vendor/rspec/spec/spec/matchers/include_spec.rb +0 -88
- data/vendor/rspec/spec/spec/matchers/match_array_spec.rb +0 -108
- data/vendor/rspec/spec/spec/matchers/match_spec.rb +0 -57
- data/vendor/rspec/spec/spec/matchers/matcher_methods_spec.rb +0 -63
- data/vendor/rspec/spec/spec/matchers/matcher_spec.rb +0 -273
- data/vendor/rspec/spec/spec/matchers/matchers_spec.rb +0 -2
- data/vendor/rspec/spec/spec/matchers/operator_matcher_spec.rb +0 -191
- data/vendor/rspec/spec/spec/matchers/raise_error_spec.rb +0 -333
- data/vendor/rspec/spec/spec/matchers/respond_to_spec.rb +0 -116
- data/vendor/rspec/spec/spec/matchers/satisfy_spec.rb +0 -36
- data/vendor/rspec/spec/spec/matchers/simple_matcher_spec.rb +0 -93
- data/vendor/rspec/spec/spec/matchers/throw_symbol_spec.rb +0 -96
- data/vendor/rspec/spec/spec/mocks/and_yield_spec.rb +0 -117
- data/vendor/rspec/spec/spec/mocks/any_number_of_times_spec.rb +0 -36
- data/vendor/rspec/spec/spec/mocks/argument_expectation_spec.rb +0 -23
- data/vendor/rspec/spec/spec/mocks/argument_matchers_spec.rb +0 -19
- data/vendor/rspec/spec/spec/mocks/at_least_spec.rb +0 -97
- data/vendor/rspec/spec/spec/mocks/at_most_spec.rb +0 -93
- data/vendor/rspec/spec/spec/mocks/bug_report_10260_spec.rb +0 -8
- data/vendor/rspec/spec/spec/mocks/bug_report_10263_spec.rb +0 -27
- data/vendor/rspec/spec/spec/mocks/bug_report_11545_spec.rb +0 -32
- data/vendor/rspec/spec/spec/mocks/bug_report_15719_spec.rb +0 -30
- data/vendor/rspec/spec/spec/mocks/bug_report_496_spec.rb +0 -19
- data/vendor/rspec/spec/spec/mocks/bug_report_600_spec.rb +0 -22
- data/vendor/rspec/spec/spec/mocks/bug_report_7611_spec.rb +0 -19
- data/vendor/rspec/spec/spec/mocks/bug_report_7805_spec.rb +0 -22
- data/vendor/rspec/spec/spec/mocks/bug_report_8165_spec.rb +0 -31
- data/vendor/rspec/spec/spec/mocks/bug_report_8302_spec.rb +0 -26
- data/vendor/rspec/spec/spec/mocks/bug_report_830_spec.rb +0 -21
- data/vendor/rspec/spec/spec/mocks/double_spec.rb +0 -12
- data/vendor/rspec/spec/spec/mocks/failing_argument_matchers_spec.rb +0 -95
- data/vendor/rspec/spec/spec/mocks/hash_including_matcher_spec.rb +0 -90
- data/vendor/rspec/spec/spec/mocks/hash_not_including_matcher_spec.rb +0 -67
- data/vendor/rspec/spec/spec/mocks/mock_ordering_spec.rb +0 -94
- data/vendor/rspec/spec/spec/mocks/mock_space_spec.rb +0 -54
- data/vendor/rspec/spec/spec/mocks/mock_spec.rb +0 -594
- data/vendor/rspec/spec/spec/mocks/multiple_return_value_spec.rb +0 -113
- data/vendor/rspec/spec/spec/mocks/nil_expectation_warning_spec.rb +0 -53
- data/vendor/rspec/spec/spec/mocks/null_object_mock_spec.rb +0 -54
- data/vendor/rspec/spec/spec/mocks/once_counts_spec.rb +0 -53
- data/vendor/rspec/spec/spec/mocks/options_hash_spec.rb +0 -35
- data/vendor/rspec/spec/spec/mocks/partial_mock_spec.rb +0 -164
- data/vendor/rspec/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb +0 -66
- data/vendor/rspec/spec/spec/mocks/passing_argument_matchers_spec.rb +0 -145
- data/vendor/rspec/spec/spec/mocks/precise_counts_spec.rb +0 -52
- data/vendor/rspec/spec/spec/mocks/record_messages_spec.rb +0 -26
- data/vendor/rspec/spec/spec/mocks/stub_chain_spec.rb +0 -42
- data/vendor/rspec/spec/spec/mocks/stub_implementation_spec.rb +0 -31
- data/vendor/rspec/spec/spec/mocks/stub_spec.rb +0 -203
- data/vendor/rspec/spec/spec/mocks/stubbed_message_expectations_spec.rb +0 -26
- data/vendor/rspec/spec/spec/mocks/twice_counts_spec.rb +0 -67
- data/vendor/rspec/spec/spec/mocks/unstub_spec.rb +0 -127
- data/vendor/rspec/spec/spec/package/bin_spec_spec.rb +0 -16
- data/vendor/rspec/spec/spec/rake/spectask_spec.rb +0 -150
- data/vendor/rspec/spec/spec/runner/class_and_argument_parser_spec.rb +0 -23
- data/vendor/rspec/spec/spec/runner/command_line_spec.rb +0 -141
- data/vendor/rspec/spec/spec/runner/configuration_spec.rb +0 -320
- data/vendor/rspec/spec/spec/runner/drb_command_line_spec.rb +0 -107
- data/vendor/rspec/spec/spec/runner/example_group_runner_spec.rb +0 -26
- data/vendor/rspec/spec/spec/runner/examples.txt +0 -2
- data/vendor/rspec/spec/spec/runner/failed.txt +0 -3
- data/vendor/rspec/spec/spec/runner/formatter/base_formatter_spec.rb +0 -30
- data/vendor/rspec/spec/spec/runner/formatter/base_text_formatter_spec.rb +0 -113
- data/vendor/rspec/spec/spec/runner/formatter/failing_example_groups_formatter_spec.rb +0 -45
- data/vendor/rspec/spec/spec/runner/formatter/failing_examples_formatter_spec.rb +0 -33
- data/vendor/rspec/spec/spec/runner/formatter/html_formatted-1.8.6-jruby.html +0 -377
- data/vendor/rspec/spec/spec/runner/formatter/html_formatted-1.8.6.html +0 -377
- data/vendor/rspec/spec/spec/runner/formatter/html_formatted-1.8.7.html +0 -377
- data/vendor/rspec/spec/spec/runner/formatter/html_formatted-1.9.1.html +0 -377
- data/vendor/rspec/spec/spec/runner/formatter/html_formatter_spec.rb +0 -118
- data/vendor/rspec/spec/spec/runner/formatter/nested_text_formatter_spec.rb +0 -305
- data/vendor/rspec/spec/spec/runner/formatter/profile_formatter_spec.rb +0 -70
- data/vendor/rspec/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +0 -149
- data/vendor/rspec/spec/spec/runner/formatter/snippet_extractor_spec.rb +0 -18
- data/vendor/rspec/spec/spec/runner/formatter/specdoc_formatter_spec.rb +0 -159
- data/vendor/rspec/spec/spec/runner/formatter/text_mate_formatted-1.8.6-jruby.html +0 -371
- data/vendor/rspec/spec/spec/runner/formatter/text_mate_formatted-1.8.6.html +0 -371
- data/vendor/rspec/spec/spec/runner/formatter/text_mate_formatted-1.8.7.html +0 -371
- data/vendor/rspec/spec/spec/runner/formatter/text_mate_formatted-1.9.1.html +0 -371
- data/vendor/rspec/spec/spec/runner/formatter/text_mate_formatter_spec.rb +0 -106
- data/vendor/rspec/spec/spec/runner/heckle_runner_spec.rb +0 -78
- data/vendor/rspec/spec/spec/runner/heckler_spec.rb +0 -20
- data/vendor/rspec/spec/spec/runner/line_number_query/line_number_query_fixture.rb +0 -70
- data/vendor/rspec/spec/spec/runner/line_number_query_spec.rb +0 -129
- data/vendor/rspec/spec/spec/runner/noisy_backtrace_tweaker_spec.rb +0 -51
- data/vendor/rspec/spec/spec/runner/option_parser_spec.rb +0 -545
- data/vendor/rspec/spec/spec/runner/options_spec.rb +0 -547
- data/vendor/rspec/spec/spec/runner/output_one_time_fixture.rb +0 -7
- data/vendor/rspec/spec/spec/runner/output_one_time_fixture_runner.rb +0 -7
- data/vendor/rspec/spec/spec/runner/output_one_time_spec.rb +0 -15
- data/vendor/rspec/spec/spec/runner/quiet_backtrace_tweaker_spec.rb +0 -123
- data/vendor/rspec/spec/spec/runner/reporter_spec.rb +0 -244
- data/vendor/rspec/spec/spec/runner/resources/a_foo.rb +0 -0
- data/vendor/rspec/spec/spec/runner/resources/a_spec.rb +0 -1
- data/vendor/rspec/spec/spec/runner/resources/custom_example_group_runner.rb +0 -14
- data/vendor/rspec/spec/spec/runner/resources/utf8_encoded.rb +0 -8
- data/vendor/rspec/spec/spec/runner/spec.opts +0 -2
- data/vendor/rspec/spec/spec/runner/spec_drb.opts +0 -2
- data/vendor/rspec/spec/spec/runner/spec_spaced.opts +0 -2
- data/vendor/rspec/spec/spec/runner_spec.rb +0 -13
- data/vendor/rspec/spec/spec.opts +0 -6
- data/vendor/rspec/spec/spec_helper.rb +0 -112
- data/vendor/rspec/spec/support/macros.rb +0 -29
- data/vendor/rspec/spec/support/spec_classes.rb +0 -133
@@ -1,14 +0,0 @@
|
|
1
|
-
Spec::Matchers.constants.each do |c|
|
2
|
-
if Class === (klass = Spec::Matchers.const_get(c))
|
3
|
-
if klass.public_instance_methods.any? {|m| ['failure_message_for_should',:failure_message_for_should].include?(m)}
|
4
|
-
klass.class_eval do
|
5
|
-
alias_method :failure_message, :failure_message_for_should
|
6
|
-
end
|
7
|
-
end
|
8
|
-
if klass.public_instance_methods.any? {|m| ['failure_message_for_should_not',:failure_message_for_should_not].include?(m)}
|
9
|
-
klass.class_eval do
|
10
|
-
alias_method :negative_failure_message, :failure_message_for_should_not
|
11
|
-
end
|
12
|
-
end
|
13
|
-
end
|
14
|
-
end
|
@@ -1,20 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
module DSL
|
4
|
-
# See Spec::Matchers
|
5
|
-
def define(name, &declarations)
|
6
|
-
define_method name do |*expected|
|
7
|
-
Spec::Matchers::Matcher.new name, *expected, &declarations
|
8
|
-
end
|
9
|
-
end
|
10
|
-
|
11
|
-
# Deprecated - use define
|
12
|
-
def create(name, &declarations)
|
13
|
-
Spec.deprecate("Spec::Matchers.create","Spec::Matchers.define")
|
14
|
-
define(name, &declarations)
|
15
|
-
end
|
16
|
-
end
|
17
|
-
end
|
18
|
-
end
|
19
|
-
|
20
|
-
Spec::Matchers.extend Spec::Matchers::DSL
|
@@ -1,42 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
# :call-seq:
|
4
|
-
# should eql(expected)
|
5
|
-
# should_not eql(expected)
|
6
|
-
#
|
7
|
-
# Passes if actual and expected are of equal value, but not necessarily the same object.
|
8
|
-
#
|
9
|
-
# See http://www.ruby-doc.org/core/classes/Object.html#M001057 for more information about equality in Ruby.
|
10
|
-
#
|
11
|
-
# == Examples
|
12
|
-
#
|
13
|
-
# 5.should eql(5)
|
14
|
-
# 5.should_not eql(3)
|
15
|
-
def eql(expected)
|
16
|
-
Matcher.new :eql, expected do |_expected_|
|
17
|
-
match do |actual|
|
18
|
-
actual.eql?(_expected_)
|
19
|
-
end
|
20
|
-
|
21
|
-
failure_message_for_should do |actual|
|
22
|
-
<<-MESSAGE
|
23
|
-
|
24
|
-
expected #{_expected_.inspect}
|
25
|
-
got #{actual.inspect}
|
26
|
-
|
27
|
-
(compared using eql?)
|
28
|
-
MESSAGE
|
29
|
-
end
|
30
|
-
|
31
|
-
failure_message_for_should_not do |actual|
|
32
|
-
<<-MESSAGE
|
33
|
-
|
34
|
-
expected #{actual.inspect} not to equal #{_expected_.inspect}
|
35
|
-
|
36
|
-
(compared using eql?)
|
37
|
-
MESSAGE
|
38
|
-
end
|
39
|
-
end
|
40
|
-
end
|
41
|
-
end
|
42
|
-
end
|
@@ -1,53 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
|
4
|
-
# :call-seq:
|
5
|
-
# should equal(expected)
|
6
|
-
# should_not equal(expected)
|
7
|
-
#
|
8
|
-
# Passes if actual and expected are the same object (object identity).
|
9
|
-
#
|
10
|
-
# See http://www.ruby-doc.org/core/classes/Object.html#M001057 for more information about equality in Ruby.
|
11
|
-
#
|
12
|
-
# == Examples
|
13
|
-
#
|
14
|
-
# 5.should equal(5) #Fixnums are equal
|
15
|
-
# "5".should_not equal("5") #Strings that look the same are not the same object
|
16
|
-
def equal(expected)
|
17
|
-
Matcher.new :equal, expected do |_expected_|
|
18
|
-
match do |actual|
|
19
|
-
actual.equal?(_expected_)
|
20
|
-
end
|
21
|
-
|
22
|
-
def inspect_object(o)
|
23
|
-
"#<#{o.class}:#{o.object_id}> => #{o.inspect}"
|
24
|
-
end
|
25
|
-
|
26
|
-
failure_message_for_should do |actual|
|
27
|
-
<<-MESSAGE
|
28
|
-
|
29
|
-
expected #{inspect_object(_expected_)}
|
30
|
-
got #{inspect_object(actual)}
|
31
|
-
|
32
|
-
Compared using equal?, which compares object identity,
|
33
|
-
but expected and actual are not the same object. Use
|
34
|
-
'actual.should == expected' if you don't care about
|
35
|
-
object identity in this example.
|
36
|
-
|
37
|
-
MESSAGE
|
38
|
-
end
|
39
|
-
|
40
|
-
failure_message_for_should_not do |actual|
|
41
|
-
<<-MESSAGE
|
42
|
-
|
43
|
-
expected not #{inspect_object(actual)}
|
44
|
-
got #{inspect_object(_expected_)}
|
45
|
-
|
46
|
-
Compared using equal?, which compares object identity.
|
47
|
-
|
48
|
-
MESSAGE
|
49
|
-
end
|
50
|
-
end
|
51
|
-
end
|
52
|
-
end
|
53
|
-
end
|
@@ -1,16 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
# :call-seq:
|
4
|
-
# should exist
|
5
|
-
# should_not exist
|
6
|
-
#
|
7
|
-
# Passes if actual.exist?
|
8
|
-
def exist(arg=nil)
|
9
|
-
Matcher.new :exist do
|
10
|
-
match do |actual|
|
11
|
-
arg ? actual.exist?(arg) : actual.exist?
|
12
|
-
end
|
13
|
-
end
|
14
|
-
end
|
15
|
-
end
|
16
|
-
end
|
@@ -1,36 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
class << self
|
4
|
-
attr_accessor :last_matcher, :last_should # :nodoc:
|
5
|
-
end
|
6
|
-
|
7
|
-
def self.clear_generated_description
|
8
|
-
self.last_matcher = nil
|
9
|
-
self.last_should = nil
|
10
|
-
end
|
11
|
-
|
12
|
-
def self.generated_description
|
13
|
-
return nil if last_should.nil?
|
14
|
-
"#{last_should.to_s.gsub('_',' ')} #{last_description}"
|
15
|
-
end
|
16
|
-
|
17
|
-
private
|
18
|
-
|
19
|
-
def self.last_description
|
20
|
-
last_matcher.respond_to?(:description) ? last_matcher.description : <<-MESSAGE
|
21
|
-
When you call a matcher in an example without a String, like this:
|
22
|
-
|
23
|
-
specify { object.should matcher }
|
24
|
-
|
25
|
-
or this:
|
26
|
-
|
27
|
-
it { should matcher }
|
28
|
-
|
29
|
-
RSpec expects the matcher to have a #description method. You should either
|
30
|
-
add a String to the example this matcher is being used in, or give it a
|
31
|
-
description method. Then you won't have to suffer this lengthy warning again.
|
32
|
-
MESSAGE
|
33
|
-
end
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
@@ -1,35 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
|
4
|
-
class Has
|
5
|
-
|
6
|
-
def initialize(expected, *args, &block)
|
7
|
-
@expected, @args, @block = expected, args, block
|
8
|
-
end
|
9
|
-
|
10
|
-
def matches?(actual)
|
11
|
-
actual.__send__(predicate(@expected), *@args, &@block)
|
12
|
-
end
|
13
|
-
|
14
|
-
def failure_message_for_should
|
15
|
-
"expected ##{predicate(@expected)}(#{@args[0].inspect}) to return true, got false"
|
16
|
-
end
|
17
|
-
|
18
|
-
def failure_message_for_should_not
|
19
|
-
"expected ##{predicate(@expected)}(#{@args[0].inspect}) to return false, got true"
|
20
|
-
end
|
21
|
-
|
22
|
-
def description
|
23
|
-
"have key #{@args[0].inspect}"
|
24
|
-
end
|
25
|
-
|
26
|
-
private
|
27
|
-
|
28
|
-
def predicate(sym)
|
29
|
-
"#{sym.to_s.sub("have_","has_")}?".to_sym
|
30
|
-
end
|
31
|
-
|
32
|
-
end
|
33
|
-
|
34
|
-
end
|
35
|
-
end
|
@@ -1,152 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
class Have #:nodoc:
|
4
|
-
def initialize(expected, relativity=:exactly)
|
5
|
-
@expected = (expected == :no ? 0 : expected)
|
6
|
-
@relativity = relativity
|
7
|
-
@actual = nil
|
8
|
-
@plural_collection_name = nil
|
9
|
-
end
|
10
|
-
|
11
|
-
def relativities
|
12
|
-
@relativities ||= {
|
13
|
-
:exactly => "",
|
14
|
-
:at_least => "at least ",
|
15
|
-
:at_most => "at most "
|
16
|
-
}
|
17
|
-
end
|
18
|
-
|
19
|
-
def matches?(collection_owner)
|
20
|
-
if collection_owner.respond_to?(@collection_name)
|
21
|
-
collection = collection_owner.__send__(@collection_name, *@args, &@block)
|
22
|
-
elsif (@plural_collection_name && collection_owner.respond_to?(@plural_collection_name))
|
23
|
-
collection = collection_owner.__send__(@plural_collection_name, *@args, &@block)
|
24
|
-
elsif (collection_owner.respond_to?(:length) || collection_owner.respond_to?(:size))
|
25
|
-
collection = collection_owner
|
26
|
-
else
|
27
|
-
collection_owner.__send__(@collection_name, *@args, &@block)
|
28
|
-
end
|
29
|
-
@actual = collection.size if collection.respond_to?(:size)
|
30
|
-
@actual = collection.length if collection.respond_to?(:length)
|
31
|
-
raise not_a_collection if @actual.nil?
|
32
|
-
return @actual >= @expected if @relativity == :at_least
|
33
|
-
return @actual <= @expected if @relativity == :at_most
|
34
|
-
return @actual == @expected
|
35
|
-
end
|
36
|
-
|
37
|
-
def not_a_collection
|
38
|
-
"expected #{@collection_name} to be a collection but it does not respond to #length or #size"
|
39
|
-
end
|
40
|
-
|
41
|
-
def failure_message_for_should
|
42
|
-
"expected #{relative_expectation} #{@collection_name}, got #{@actual}"
|
43
|
-
end
|
44
|
-
|
45
|
-
def failure_message_for_should_not
|
46
|
-
if @relativity == :exactly
|
47
|
-
return "expected target not to have #{@expected} #{@collection_name}, got #{@actual}"
|
48
|
-
elsif @relativity == :at_most
|
49
|
-
return <<-EOF
|
50
|
-
Isn't life confusing enough?
|
51
|
-
Instead of having to figure out the meaning of this:
|
52
|
-
should_not have_at_most(#{@expected}).#{@collection_name}
|
53
|
-
We recommend that you use this instead:
|
54
|
-
should have_at_least(#{@expected + 1}).#{@collection_name}
|
55
|
-
EOF
|
56
|
-
elsif @relativity == :at_least
|
57
|
-
return <<-EOF
|
58
|
-
Isn't life confusing enough?
|
59
|
-
Instead of having to figure out the meaning of this:
|
60
|
-
should_not have_at_least(#{@expected}).#{@collection_name}
|
61
|
-
We recommend that you use this instead:
|
62
|
-
should have_at_most(#{@expected - 1}).#{@collection_name}
|
63
|
-
EOF
|
64
|
-
end
|
65
|
-
end
|
66
|
-
|
67
|
-
def description
|
68
|
-
"have #{relative_expectation} #{@collection_name}"
|
69
|
-
end
|
70
|
-
|
71
|
-
def respond_to?(sym)
|
72
|
-
@expected.respond_to?(sym) || super
|
73
|
-
end
|
74
|
-
|
75
|
-
private
|
76
|
-
|
77
|
-
def method_missing(sym, *args, &block)
|
78
|
-
@collection_name = sym
|
79
|
-
if inflector = (defined?(ActiveSupport::Inflector) ? ActiveSupport::Inflector : (defined?(Inflector) ? Inflector : nil))
|
80
|
-
@plural_collection_name = inflector.pluralize(sym.to_s)
|
81
|
-
end
|
82
|
-
@args = args
|
83
|
-
@block = block
|
84
|
-
self
|
85
|
-
end
|
86
|
-
|
87
|
-
def relative_expectation
|
88
|
-
"#{relativities[@relativity]}#{@expected}"
|
89
|
-
end
|
90
|
-
end
|
91
|
-
|
92
|
-
# :call-seq:
|
93
|
-
# should have(number).named_collection__or__sugar
|
94
|
-
# should_not have(number).named_collection__or__sugar
|
95
|
-
#
|
96
|
-
# Passes if receiver is a collection with the submitted
|
97
|
-
# number of items OR if the receiver OWNS a collection
|
98
|
-
# with the submitted number of items.
|
99
|
-
#
|
100
|
-
# If the receiver OWNS the collection, you must use the name
|
101
|
-
# of the collection. So if a <tt>Team</tt> instance has a
|
102
|
-
# collection named <tt>#players</tt>, you must use that name
|
103
|
-
# to set the expectation.
|
104
|
-
#
|
105
|
-
# If the receiver IS the collection, you can use any name
|
106
|
-
# you like for <tt>named_collection</tt>. We'd recommend using
|
107
|
-
# either "elements", "members", or "items" as these are all
|
108
|
-
# standard ways of describing the things IN a collection.
|
109
|
-
#
|
110
|
-
# This also works for Strings, letting you set an expectation
|
111
|
-
# about its length
|
112
|
-
#
|
113
|
-
# == Examples
|
114
|
-
#
|
115
|
-
# # Passes if team.players.size == 11
|
116
|
-
# team.should have(11).players
|
117
|
-
#
|
118
|
-
# # Passes if [1,2,3].length == 3
|
119
|
-
# [1,2,3].should have(3).items #"items" is pure sugar
|
120
|
-
#
|
121
|
-
# # Passes if "this string".length == 11
|
122
|
-
# "this string".should have(11).characters #"characters" is pure sugar
|
123
|
-
def have(n)
|
124
|
-
Matchers::Have.new(n)
|
125
|
-
end
|
126
|
-
alias :have_exactly :have
|
127
|
-
|
128
|
-
# :call-seq:
|
129
|
-
# should have_at_least(number).items
|
130
|
-
#
|
131
|
-
# Exactly like have() with >=.
|
132
|
-
#
|
133
|
-
# == Warning
|
134
|
-
#
|
135
|
-
# +should_not+ +have_at_least+ is not supported
|
136
|
-
def have_at_least(n)
|
137
|
-
Matchers::Have.new(n, :at_least)
|
138
|
-
end
|
139
|
-
|
140
|
-
# :call-seq:
|
141
|
-
# should have_at_most(number).items
|
142
|
-
#
|
143
|
-
# Exactly like have() with <=.
|
144
|
-
#
|
145
|
-
# == Warning
|
146
|
-
#
|
147
|
-
# +should_not+ +have_at_most+ is not supported
|
148
|
-
def have_at_most(n)
|
149
|
-
Matchers::Have.new(n, :at_most)
|
150
|
-
end
|
151
|
-
end
|
152
|
-
end
|
@@ -1,44 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
# :call-seq:
|
4
|
-
# should include(expected)
|
5
|
-
# should_not include(expected)
|
6
|
-
#
|
7
|
-
# Passes if actual includes expected. This works for
|
8
|
-
# collections and Strings. You can also pass in multiple args
|
9
|
-
# and it will only pass if all args are found in collection.
|
10
|
-
#
|
11
|
-
# == Examples
|
12
|
-
#
|
13
|
-
# [1,2,3].should include(3)
|
14
|
-
# [1,2,3].should include(2,3) #would pass
|
15
|
-
# [1,2,3].should include(2,3,4) #would fail
|
16
|
-
# [1,2,3].should_not include(4)
|
17
|
-
# "spread".should include("read")
|
18
|
-
# "spread".should_not include("red")
|
19
|
-
def include(*expected)
|
20
|
-
Matcher.new :include, *expected do |*_expected_|
|
21
|
-
match do |actual|
|
22
|
-
helper(actual, *_expected_)
|
23
|
-
end
|
24
|
-
|
25
|
-
def helper(actual, *_expected_)
|
26
|
-
_expected_.each do |expected|
|
27
|
-
if actual.is_a?(Hash)
|
28
|
-
if expected.is_a?(Hash)
|
29
|
-
expected.each_pair do |k,v|
|
30
|
-
return false unless actual[k] == v
|
31
|
-
end
|
32
|
-
else
|
33
|
-
return false unless actual.has_key?(expected)
|
34
|
-
end
|
35
|
-
else
|
36
|
-
return false unless actual.include?(expected)
|
37
|
-
end
|
38
|
-
end
|
39
|
-
true
|
40
|
-
end
|
41
|
-
end
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
@@ -1,21 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
# :call-seq:
|
4
|
-
# should match(pattern)
|
5
|
-
# should_not match(pattern)
|
6
|
-
#
|
7
|
-
# Given a Regexp or String, passes if actual.match(pattern)
|
8
|
-
#
|
9
|
-
# == Examples
|
10
|
-
#
|
11
|
-
# email.should match(/^([^\s]+)((?:[-a-z0-9]+\.)+[a-z]{2,})$/i)
|
12
|
-
# email.should match("@example.com")
|
13
|
-
def match(expected)
|
14
|
-
Matcher.new :match, expected do |_expected_|
|
15
|
-
match do |actual|
|
16
|
-
actual.match(_expected_)
|
17
|
-
end
|
18
|
-
end
|
19
|
-
end
|
20
|
-
end
|
21
|
-
end
|
@@ -1,71 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
|
4
|
-
class MatchArray #:nodoc:
|
5
|
-
include Spec::Matchers::Pretty
|
6
|
-
|
7
|
-
def initialize(expected)
|
8
|
-
@expected = expected
|
9
|
-
end
|
10
|
-
|
11
|
-
def matches?(actual)
|
12
|
-
@actual = actual
|
13
|
-
@extra_items = difference_between_arrays(@actual, @expected)
|
14
|
-
@missing_items = difference_between_arrays(@expected, @actual)
|
15
|
-
@extra_items.empty? & @missing_items.empty?
|
16
|
-
end
|
17
|
-
|
18
|
-
def failure_message_for_should
|
19
|
-
message = "expected collection contained: #{safe_sort(@expected).inspect}\n"
|
20
|
-
message += "actual collection contained: #{safe_sort(@actual).inspect}\n"
|
21
|
-
message += "the missing elements were: #{safe_sort(@missing_items).inspect}\n" unless @missing_items.empty?
|
22
|
-
message += "the extra elements were: #{safe_sort(@extra_items).inspect}\n" unless @extra_items.empty?
|
23
|
-
message
|
24
|
-
end
|
25
|
-
|
26
|
-
def failure_message_for_should_not
|
27
|
-
"Matcher does not support should_not"
|
28
|
-
end
|
29
|
-
|
30
|
-
def description
|
31
|
-
"contain exactly #{_pretty_print(@expected)}"
|
32
|
-
end
|
33
|
-
|
34
|
-
private
|
35
|
-
|
36
|
-
def safe_sort(array)
|
37
|
-
array.all?{|item| item.respond_to?(:<=>)} ? array.sort : array
|
38
|
-
end
|
39
|
-
|
40
|
-
def difference_between_arrays(array_1, array_2)
|
41
|
-
difference = array_1.dup
|
42
|
-
array_2.each do |element|
|
43
|
-
if index = difference.index(element)
|
44
|
-
difference.delete_at(index)
|
45
|
-
end
|
46
|
-
end
|
47
|
-
difference
|
48
|
-
end
|
49
|
-
|
50
|
-
|
51
|
-
end
|
52
|
-
|
53
|
-
# :call-seq:
|
54
|
-
# should =~ expected
|
55
|
-
#
|
56
|
-
# Passes if actual contains all of the expected regardless of order.
|
57
|
-
# This works for collections. Pass in multiple args and it will only
|
58
|
-
# pass if all args are found in collection.
|
59
|
-
#
|
60
|
-
# NOTE: there is no should_not version of array.should =~ other_array
|
61
|
-
#
|
62
|
-
# == Examples
|
63
|
-
#
|
64
|
-
# [1,2,3].should =~ [1,2,3] # => would pass
|
65
|
-
# [1,2,3].should =~ [2,3,1] # => would pass
|
66
|
-
# [1,2,3,4].should =~ [1,2,3] # => would fail
|
67
|
-
# [1,2,2,3].should =~ [1,2,3] # => would fail
|
68
|
-
# [1,2,3].should =~ [1,2,3,4] # => would fail
|
69
|
-
OperatorMatcher.register(Array, '=~', Spec::Matchers::MatchArray)
|
70
|
-
end
|
71
|
-
end
|
@@ -1,102 +0,0 @@
|
|
1
|
-
module Spec
|
2
|
-
module Matchers
|
3
|
-
class Matcher
|
4
|
-
include Spec::Matchers::InstanceExec
|
5
|
-
include Spec::Matchers::Pretty
|
6
|
-
include Spec::Matchers
|
7
|
-
|
8
|
-
attr_reader :expected, :actual
|
9
|
-
|
10
|
-
def initialize(name, *expected, &declarations)
|
11
|
-
@name = name
|
12
|
-
@expected = expected
|
13
|
-
@actual = nil
|
14
|
-
@diffable = false
|
15
|
-
@error_to_watch_for = nil
|
16
|
-
@messages = {
|
17
|
-
:description => lambda {"#{name_to_sentence}#{expected_to_sentence}"},
|
18
|
-
:failure_message_for_should => lambda {|actual| "expected #{actual.inspect} to #{name_to_sentence}#{expected_to_sentence}"},
|
19
|
-
:failure_message_for_should_not => lambda {|actual| "expected #{actual.inspect} not to #{name_to_sentence}#{expected_to_sentence}"}
|
20
|
-
}
|
21
|
-
making_declared_methods_public do
|
22
|
-
instance_exec(*@expected, &declarations)
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
def matches?(actual)
|
27
|
-
if @error_to_watch_for
|
28
|
-
begin
|
29
|
-
instance_exec(@actual = actual, &@match_block)
|
30
|
-
true
|
31
|
-
rescue @error_to_watch_for
|
32
|
-
false
|
33
|
-
end
|
34
|
-
else
|
35
|
-
instance_exec(@actual = actual, &@match_block)
|
36
|
-
end
|
37
|
-
end
|
38
|
-
|
39
|
-
def description(&block)
|
40
|
-
cache_or_call_cached(:description, &block)
|
41
|
-
end
|
42
|
-
|
43
|
-
def failure_message_for_should(&block)
|
44
|
-
cache_or_call_cached(:failure_message_for_should, actual, &block)
|
45
|
-
end
|
46
|
-
|
47
|
-
def failure_message_for_should_not(&block)
|
48
|
-
cache_or_call_cached(:failure_message_for_should_not, actual, &block)
|
49
|
-
end
|
50
|
-
|
51
|
-
def match(&block)
|
52
|
-
@match_block = block
|
53
|
-
end
|
54
|
-
|
55
|
-
def match_unless_raises(error=StandardError, &block)
|
56
|
-
@error_to_watch_for = error
|
57
|
-
match(&block)
|
58
|
-
end
|
59
|
-
|
60
|
-
def diffable?
|
61
|
-
@diffable
|
62
|
-
end
|
63
|
-
|
64
|
-
def diffable
|
65
|
-
@diffable = true
|
66
|
-
end
|
67
|
-
|
68
|
-
private
|
69
|
-
|
70
|
-
def making_declared_methods_public # :nodoc:
|
71
|
-
# Our home-grown instance_exec in ruby 1.8.6 results in any methods
|
72
|
-
# declared in the block eval'd by instance_exec in the block to which we
|
73
|
-
# are yielding here are scoped private. This is NOT the case for Ruby
|
74
|
-
# 1.8.7 or 1.9.
|
75
|
-
#
|
76
|
-
# Also, due some crazy scoping that I don't understand, these methods
|
77
|
-
# are actually available in the specs (something about the matcher being
|
78
|
-
# defined in the scope of Spec::Matchers or within an example), so not
|
79
|
-
# doing the following will not cause specs to fail, but they *will*
|
80
|
-
# cause features to fail and that will make users unhappy. So don't.
|
81
|
-
orig_private_methods = private_methods
|
82
|
-
yield
|
83
|
-
st = (class << self; self; end)
|
84
|
-
(private_methods - orig_private_methods).each {|m| st.__send__ :public, m}
|
85
|
-
end
|
86
|
-
|
87
|
-
def cache_or_call_cached(key, actual=nil, &block)
|
88
|
-
block ? @messages[key] = block :
|
89
|
-
actual.nil? ? @messages[key].call : @messages[key].call(actual)
|
90
|
-
end
|
91
|
-
|
92
|
-
def name_to_sentence
|
93
|
-
split_words(@name)
|
94
|
-
end
|
95
|
-
|
96
|
-
def expected_to_sentence
|
97
|
-
to_sentence(@expected)
|
98
|
-
end
|
99
|
-
|
100
|
-
end
|
101
|
-
end
|
102
|
-
end
|