opal-rspec 0.4.3 → 0.5.0.beta1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/CHANGELOG.md +9 -3
- data/Gemfile +6 -5
- data/README.md +73 -13
- data/Rakefile +108 -12
- data/lib/opal/rspec/version.rb +1 -1
- data/lib/opal/rspec.rb +35 -12
- data/opal/opal/rspec/async/async_example.rb +87 -0
- data/opal/opal/rspec/async/example_group.rb +94 -0
- data/opal/opal/rspec/async/hooks.rb +46 -0
- data/opal/opal/rspec/async/legacy.rb +50 -0
- data/opal/opal/rspec/async.rb +4 -289
- data/opal/opal/rspec/browser_formatter.rb +55 -18
- data/opal/opal/rspec/fixes/caller_filter.rb +6 -0
- data/opal/opal/rspec/fixes/example.rb +20 -0
- data/opal/opal/rspec/fixes/example_groups.rb +32 -0
- data/opal/opal/rspec/fixes/expectations.rb +21 -0
- data/opal/opal/rspec/fixes/formatter.rb +62 -0
- data/opal/opal/rspec/fixes/kernel.rb +35 -0
- data/opal/opal/rspec/fixes/matchers.rb +15 -0
- data/opal/opal/rspec/fixes/mocks.rb +13 -0
- data/opal/opal/rspec/fixes/reporter.rb +12 -0
- data/opal/opal/rspec/fixes.rb +11 -115
- data/opal/opal/rspec/pre_require_fixes.rb +4 -0
- data/opal/opal/rspec/requires.rb +103 -35
- data/opal/opal/rspec/runner.rb +19 -15
- data/opal/opal/rspec/text_formatter.rb +24 -10
- data/opal/opal/rspec.rb +4 -9
- data/opal-rspec.gemspec +5 -2
- data/{vendor_lib → rspec/lib}/rspec/version.rb +1 -1
- data/{vendor_lib → rspec/lib}/rspec.rb +0 -0
- data/rspec-core/benchmarks/call_v_yield.rb +81 -0
- data/rspec-core/benchmarks/check_inclusion.rb +125 -0
- data/rspec-core/benchmarks/define_method_v_attr_reader_v_def.rb +81 -0
- data/rspec-core/benchmarks/eager_vs_lazy_metadata/define_examples.rb +22 -0
- data/rspec-core/benchmarks/eager_vs_lazy_metadata.rb +126 -0
- data/rspec-core/benchmarks/filter_object.rb +35 -0
- data/rspec-core/benchmarks/index_v_take_while.rb +47 -0
- data/rspec-core/benchmarks/map_then_flatten_vs_flat_map_benchmarks.rb +94 -0
- data/rspec-core/benchmarks/require_relative_v_require.rb +75 -0
- data/rspec-core/benchmarks/respond_to_v_defined.rb +72 -0
- data/rspec-core/benchmarks/several_regexps_v_one_big_one.rb +86 -0
- data/rspec-core/benchmarks/sort_by_v_shuffle.rb +83 -0
- data/rspec-core/benchmarks/to_proc_v_not_to_proc.rb +539 -0
- data/rspec-core/features/step_definitions/additional_cli_steps.rb +126 -0
- data/rspec-core/features/step_definitions/core_standalone_steps.rb +12 -0
- data/rspec-core/features/support/env.rb +21 -0
- data/rspec-core/features/support/require_expect_syntax_in_aruba_specs.rb +29 -0
- data/rspec-core/features/support/rubinius.rb +6 -0
- data/{vendor_lib → rspec-core/lib}/rspec/autorun.rb +0 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/backport_random.rb +40 -6
- data/rspec-core/lib/rspec/core/backtrace_formatter.rb +66 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/configuration.rb +561 -250
- data/rspec-core/lib/rspec/core/configuration_options.rb +173 -0
- data/rspec-core/lib/rspec/core/drb.rb +111 -0
- data/rspec-core/lib/rspec/core/dsl.rb +93 -0
- data/rspec-core/lib/rspec/core/example.rb +502 -0
- data/rspec-core/lib/rspec/core/example_group.rb +606 -0
- data/rspec-core/lib/rspec/core/filter_manager.rb +259 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/flat_map.rb +1 -0
- data/rspec-core/lib/rspec/core/formatters/base_formatter.rb +67 -0
- data/rspec-core/lib/rspec/core/formatters/base_text_formatter.rb +76 -0
- data/rspec-core/lib/rspec/core/formatters/console_codes.rb +64 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/formatters/deprecation_formatter.rb +65 -36
- data/rspec-core/lib/rspec/core/formatters/documentation_formatter.rb +68 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/formatters/helpers.rb +18 -13
- data/{vendor_lib → rspec-core/lib}/rspec/core/formatters/html_formatter.rb +69 -75
- data/{vendor_lib → rspec-core/lib}/rspec/core/formatters/html_printer.rb +17 -22
- data/rspec-core/lib/rspec/core/formatters/json_formatter.rb +94 -0
- data/rspec-core/lib/rspec/core/formatters/profile_formatter.rb +65 -0
- data/rspec-core/lib/rspec/core/formatters/progress_formatter.rb +28 -0
- data/rspec-core/lib/rspec/core/formatters/protocol.rb +163 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/formatters/snippet_extractor.rb +15 -12
- data/rspec-core/lib/rspec/core/formatters.rb +240 -0
- data/rspec-core/lib/rspec/core/hooks.rb +591 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/memoized_helpers.rb +82 -41
- data/rspec-core/lib/rspec/core/metadata.rb +437 -0
- data/rspec-core/lib/rspec/core/metadata_filter.rb +95 -0
- data/rspec-core/lib/rspec/core/minitest_assertions_adapter.rb +28 -0
- data/rspec-core/lib/rspec/core/mocking_adapters/flexmock.rb +31 -0
- data/{vendor_lib/rspec/core/mocking/with_mocha.rb → rspec-core/lib/rspec/core/mocking_adapters/mocha.rb} +21 -16
- data/rspec-core/lib/rspec/core/mocking_adapters/null.rb +14 -0
- data/rspec-core/lib/rspec/core/mocking_adapters/rr.rb +31 -0
- data/rspec-core/lib/rspec/core/mocking_adapters/rspec.rb +32 -0
- data/rspec-core/lib/rspec/core/notifications.rb +542 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/option_parser.rb +53 -65
- data/{vendor_lib → rspec-core/lib}/rspec/core/ordering.rb +11 -10
- data/rspec-core/lib/rspec/core/pending.rb +163 -0
- data/rspec-core/lib/rspec/core/project_initializer/spec/spec_helper.rb +89 -0
- data/rspec-core/lib/rspec/core/project_initializer.rb +48 -0
- data/rspec-core/lib/rspec/core/rake_task.rb +187 -0
- data/rspec-core/lib/rspec/core/reporter.rb +149 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/ruby_project.rb +3 -2
- data/rspec-core/lib/rspec/core/runner.rb +158 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/shared_context.rb +7 -5
- data/rspec-core/lib/rspec/core/shared_example_group.rb +182 -0
- data/rspec-core/lib/rspec/core/test_unit_assertions_adapter.rb +30 -0
- data/rspec-core/lib/rspec/core/version.rb +9 -0
- data/rspec-core/lib/rspec/core/warnings.rb +40 -0
- data/{vendor_lib → rspec-core/lib}/rspec/core/world.rb +78 -26
- data/{vendor_lib → rspec-core/lib}/rspec/core.rb +64 -98
- data/rspec-core/spec/command_line/order_spec.rb +213 -0
- data/rspec-core/spec/rspec/core/backtrace_formatter_spec.rb +306 -0
- data/rspec-core/spec/rspec/core/configuration_options_spec.rb +425 -0
- data/rspec-core/spec/rspec/core/configuration_spec.rb +1963 -0
- data/rspec-core/spec/rspec/core/drb_spec.rb +278 -0
- data/rspec-core/spec/rspec/core/dsl_spec.rb +85 -0
- data/rspec-core/spec/rspec/core/example_execution_result_spec.rb +142 -0
- data/rspec-core/spec/rspec/core/example_group_constants_spec.rb +16 -0
- data/rspec-core/spec/rspec/core/example_group_spec.rb +1621 -0
- data/rspec-core/spec/rspec/core/example_spec.rb +662 -0
- data/rspec-core/spec/rspec/core/failed_example_notification_spec.rb +25 -0
- data/rspec-core/spec/rspec/core/filter_manager_spec.rb +299 -0
- data/rspec-core/spec/rspec/core/formatters/base_text_formatter_spec.rb +182 -0
- data/rspec-core/spec/rspec/core/formatters/console_codes_spec.rb +65 -0
- data/rspec-core/spec/rspec/core/formatters/deprecation_formatter_spec.rb +225 -0
- data/rspec-core/spec/rspec/core/formatters/documentation_formatter_spec.rb +111 -0
- data/rspec-core/spec/rspec/core/formatters/helpers_spec.rb +104 -0
- data/rspec-core/spec/rspec/core/formatters/html_formatter_spec.rb +111 -0
- data/rspec-core/spec/rspec/core/formatters/json_formatter_spec.rb +183 -0
- data/rspec-core/spec/rspec/core/formatters/profile_formatter_spec.rb +99 -0
- data/rspec-core/spec/rspec/core/formatters/progress_formatter_spec.rb +55 -0
- data/rspec-core/spec/rspec/core/formatters/snippet_extractor_spec.rb +26 -0
- data/rspec-core/spec/rspec/core/formatters_spec.rb +160 -0
- data/rspec-core/spec/rspec/core/hooks_filtering_spec.rb +227 -0
- data/rspec-core/spec/rspec/core/hooks_spec.rb +447 -0
- data/rspec-core/spec/rspec/core/memoized_helpers_spec.rb +537 -0
- data/rspec-core/spec/rspec/core/metadata_filter_spec.rb +181 -0
- data/rspec-core/spec/rspec/core/metadata_spec.rb +642 -0
- data/rspec-core/spec/rspec/core/notifications_spec.rb +92 -0
- data/rspec-core/spec/rspec/core/option_parser_spec.rb +270 -0
- data/rspec-core/spec/rspec/core/ordering_spec.rb +102 -0
- data/rspec-core/spec/rspec/core/pending_example_spec.rb +221 -0
- data/rspec-core/spec/rspec/core/pending_spec.rb +8 -0
- data/rspec-core/spec/rspec/core/project_initializer_spec.rb +123 -0
- data/rspec-core/spec/rspec/core/rake_task_spec.rb +351 -0
- data/rspec-core/spec/rspec/core/random_spec.rb +47 -0
- data/rspec-core/spec/rspec/core/reporter_spec.rb +198 -0
- data/rspec-core/spec/rspec/core/resources/a_bar.rb +0 -0
- data/rspec-core/spec/rspec/core/resources/a_foo.rb +0 -0
- data/rspec-core/spec/rspec/core/resources/a_spec.rb +1 -0
- data/rspec-core/spec/rspec/core/resources/acceptance/bar.rb +0 -0
- data/rspec-core/spec/rspec/core/resources/acceptance/foo_spec.rb +0 -0
- data/rspec-core/spec/rspec/core/resources/custom_example_group_runner.rb +14 -0
- data/rspec-core/spec/rspec/core/resources/formatter_specs.rb +58 -0
- data/rspec-core/spec/rspec/core/resources/utf8_encoded.rb +9 -0
- data/rspec-core/spec/rspec/core/rspec_matchers_spec.rb +45 -0
- data/rspec-core/spec/rspec/core/ruby_project_spec.rb +26 -0
- data/rspec-core/spec/rspec/core/runner_spec.rb +309 -0
- data/rspec-core/spec/rspec/core/shared_context_spec.rb +102 -0
- data/rspec-core/spec/rspec/core/shared_example_group_spec.rb +268 -0
- data/rspec-core/spec/rspec/core/warnings_spec.rb +72 -0
- data/rspec-core/spec/rspec/core/world_spec.rb +142 -0
- data/rspec-core/spec/rspec/core_spec.rb +103 -0
- data/rspec-core/spec/spec_helper.rb +89 -0
- data/rspec-core/spec/support/config_options_helper.rb +13 -0
- data/rspec-core/spec/support/fake_minitest/minitest/minitest_assertions.rb +4 -0
- data/rspec-core/spec/support/fake_minitest/minitest.rb +0 -0
- data/rspec-core/spec/support/fake_minitest/test/unit/assertions.rb +6 -0
- data/rspec-core/spec/support/formatter_support.rb +263 -0
- data/rspec-core/spec/support/helper_methods.rb +26 -0
- data/rspec-core/spec/support/isolated_home_directory.rb +16 -0
- data/rspec-core/spec/support/matchers.rb +103 -0
- data/rspec-core/spec/support/mathn_integration_support.rb +12 -0
- data/rspec-core/spec/support/sandboxing.rb +50 -0
- data/rspec-core/spec/support/shared_example_groups.rb +43 -0
- data/rspec-core/spec/support/spec_files.rb +44 -0
- data/rspec-expectations/benchmarks/2.x_vs_3.x_matcher_dsl_implementation.rb +253 -0
- data/rspec-expectations/benchmarks/autoload_v_require.rb +25 -0
- data/rspec-expectations/benchmarks/cloning_matchers.rb +19 -0
- data/rspec-expectations/benchmarks/default_messages_as_methods_v_blocks.rb +27 -0
- data/rspec-expectations/benchmarks/example_spec.rb +9 -0
- data/rspec-expectations/benchmarks/include_v_superclass.rb +39 -0
- data/rspec-expectations/benchmarks/match_array/failing_with_distinct_items.rb +147 -0
- data/rspec-expectations/benchmarks/match_array/failing_with_duplicate_items.rb +122 -0
- data/rspec-expectations/benchmarks/match_array/passing_with_distinct_items.rb +154 -0
- data/rspec-expectations/benchmarks/match_array/passing_with_duplicate_items.rb +132 -0
- data/rspec-expectations/benchmarks/match_array/rubyprof/passing_with_distinct_items.rb +9 -0
- data/rspec-expectations/benchmarks/matcher_dsl_vs_classes.rb +180 -0
- data/rspec-expectations/benchmarks/method_to_proc.rb +72 -0
- data/rspec-expectations/benchmarks/set_vs_array_include.rb +68 -0
- data/rspec-expectations/features/step_definitions/additional_cli_steps.rb +22 -0
- data/rspec-expectations/features/support/disallow_certain_apis.rb +34 -0
- data/rspec-expectations/features/support/env.rb +21 -0
- data/rspec-expectations/features/support/rubinius.rb +6 -0
- data/{vendor_lib/rspec/matchers → rspec-expectations/lib/rspec/expectations}/configuration.rb +50 -16
- data/rspec-expectations/lib/rspec/expectations/expectation_target.rb +119 -0
- data/rspec-expectations/lib/rspec/expectations/fail_with.rb +34 -0
- data/rspec-expectations/lib/rspec/expectations/handler.rb +167 -0
- data/rspec-expectations/lib/rspec/expectations/minitest_integration.rb +17 -0
- data/rspec-expectations/lib/rspec/expectations/syntax.rb +132 -0
- data/{vendor_lib → rspec-expectations/lib}/rspec/expectations/version.rb +1 -1
- data/rspec-expectations/lib/rspec/expectations.rb +68 -0
- data/rspec-expectations/lib/rspec/matchers/aliased_matcher.rb +116 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/all.rb +85 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/base_matcher.rb +132 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/be.rb +277 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/be_between.rb +77 -0
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/built_in/be_instance_of.rb +11 -4
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/built_in/be_kind_of.rb +5 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/be_within.rb +72 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/change.rb +337 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/compound.rb +258 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/contain_exactly.rb +249 -0
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/built_in/cover.rb +3 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/eq.rb +75 -0
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/built_in/eql.rb +17 -6
- data/rspec-expectations/lib/rspec/matchers/built_in/equal.rb +81 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/exist.rb +86 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/has.rb +101 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/have_attributes.rb +84 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/include.rb +105 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/match.rb +29 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/operators.rb +119 -0
- data/rspec-expectations/lib/rspec/matchers/built_in/output.rb +152 -0
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/built_in/raise_error.rb +66 -46
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/built_in/respond_to.rb +43 -26
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/built_in/satisfy.rb +13 -4
- data/rspec-expectations/lib/rspec/matchers/built_in/start_and_end_with.rb +82 -0
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/built_in/throw_symbol.rb +51 -13
- data/rspec-expectations/lib/rspec/matchers/built_in/yield.rb +420 -0
- data/rspec-expectations/lib/rspec/matchers/built_in.rb +52 -0
- data/rspec-expectations/lib/rspec/matchers/composable.rb +183 -0
- data/{vendor_lib/rspec/matchers/matcher.rb → rspec-expectations/lib/rspec/matchers/dsl.rb} +120 -30
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers/generated_descriptions.rb +13 -6
- data/rspec-expectations/lib/rspec/matchers/matcher_delegator.rb +33 -0
- data/rspec-expectations/lib/rspec/matchers/matcher_protocol.rb +99 -0
- data/rspec-expectations/lib/rspec/matchers/pretty.rb +77 -0
- data/{vendor_lib → rspec-expectations/lib}/rspec/matchers.rb +408 -74
- data/rspec-expectations/spec/rspec/expectations/configuration_spec.rb +226 -0
- data/rspec-expectations/spec/rspec/expectations/expectation_target_spec.rb +147 -0
- data/rspec-expectations/spec/rspec/expectations/extensions/kernel_spec.rb +69 -0
- data/rspec-expectations/spec/rspec/expectations/fail_with_spec.rb +73 -0
- data/rspec-expectations/spec/rspec/expectations/handler_spec.rb +200 -0
- data/rspec-expectations/spec/rspec/expectations/minitest_integration_spec.rb +25 -0
- data/rspec-expectations/spec/rspec/expectations/syntax_spec.rb +93 -0
- data/rspec-expectations/spec/rspec/expectations_spec.rb +15 -0
- data/rspec-expectations/spec/rspec/matchers/aliased_matcher_spec.rb +113 -0
- data/rspec-expectations/spec/rspec/matchers/aliases_spec.rb +455 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/all_spec.rb +212 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/base_matcher_spec.rb +140 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/be_between_spec.rb +157 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/be_instance_of_spec.rb +61 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/be_kind_of_spec.rb +39 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/be_spec.rb +685 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/be_within_spec.rb +139 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/change_spec.rb +829 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/compound_spec.rb +537 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/contain_exactly_spec.rb +556 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/cover_spec.rb +67 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/eq_spec.rb +176 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/eql_spec.rb +39 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/equal_spec.rb +130 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/exist_spec.rb +139 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/has_spec.rb +179 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/have_attributes_spec.rb +177 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/include_spec.rb +587 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/match_spec.rb +100 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/operators_spec.rb +250 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/output_spec.rb +168 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/raise_error_spec.rb +446 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/respond_to_spec.rb +290 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/satisfy_spec.rb +42 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/start_and_end_with_spec.rb +347 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/throw_symbol_spec.rb +133 -0
- data/rspec-expectations/spec/rspec/matchers/built_in/yield_spec.rb +643 -0
- data/rspec-expectations/spec/rspec/matchers/composable_spec.rb +77 -0
- data/rspec-expectations/spec/rspec/matchers/define_negated_matcher_spec.rb +199 -0
- data/rspec-expectations/spec/rspec/matchers/description_generation_spec.rb +189 -0
- data/rspec-expectations/spec/rspec/matchers/dsl_spec.rb +1036 -0
- data/rspec-expectations/spec/rspec/matchers/legacy_spec.rb +104 -0
- data/rspec-expectations/spec/rspec/matchers_spec.rb +108 -0
- data/rspec-expectations/spec/spec_helper.rb +94 -0
- data/rspec-expectations/spec/support/matchers.rb +54 -0
- data/rspec-expectations/spec/support/shared_examples.rb +101 -0
- data/rspec-mocks/benchmarks/double_creation.rb +66 -0
- data/rspec-mocks/benchmarks/each_value_v_values_each.rb +58 -0
- data/rspec-mocks/benchmarks/find_original_method_early.rb +64 -0
- data/rspec-mocks/benchmarks/method_defined_at_any_visibility.rb +101 -0
- data/rspec-mocks/benchmarks/thread_safety.rb +24 -0
- data/rspec-mocks/benchmarks/transfer_nested_constants.rb +77 -0
- data/rspec-mocks/features/step_definitions/additional_cli_steps.rb +21 -0
- data/rspec-mocks/features/support/disallow_certain_apis.rb +24 -0
- data/rspec-mocks/features/support/env.rb +22 -0
- data/rspec-mocks/features/support/rubinius.rb +6 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/any_instance/chain.rb +19 -2
- data/rspec-mocks/lib/rspec/mocks/any_instance/expect_chain_chain.rb +35 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/any_instance/expectation_chain.rb +12 -11
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/any_instance/message_chains.rb +15 -5
- data/rspec-mocks/lib/rspec/mocks/any_instance/proxy.rb +116 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/any_instance/recorder.rb +105 -38
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/any_instance/stub_chain.rb +9 -9
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/any_instance/stub_chain_chain.rb +5 -1
- data/rspec-mocks/lib/rspec/mocks/any_instance.rb +10 -0
- data/rspec-mocks/lib/rspec/mocks/argument_list_matcher.rb +72 -0
- data/rspec-mocks/lib/rspec/mocks/argument_matchers.rb +282 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/configuration.rb +60 -14
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/error_generator.rb +93 -43
- data/rspec-mocks/lib/rspec/mocks/example_methods.rb +379 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/instance_method_stasher.rb +30 -7
- data/rspec-mocks/lib/rspec/mocks/marshal_extension.rb +41 -0
- data/rspec-mocks/lib/rspec/mocks/matchers/expectation_customization.rb +20 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/matchers/have_received.rb +36 -14
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/matchers/receive.rb +24 -30
- data/rspec-mocks/lib/rspec/mocks/matchers/receive_message_chain.rb +66 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/matchers/receive_messages.rb +9 -10
- data/rspec-mocks/lib/rspec/mocks/message_chain.rb +91 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/message_expectation.rb +156 -105
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/method_double.rb +81 -30
- data/rspec-mocks/lib/rspec/mocks/method_reference.rb +155 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/mutate_const.rb +84 -166
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/object_reference.rb +19 -18
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/order_group.rb +4 -5
- data/rspec-mocks/lib/rspec/mocks/proxy.rb +431 -0
- data/rspec-mocks/lib/rspec/mocks/space.rb +221 -0
- data/rspec-mocks/lib/rspec/mocks/standalone.rb +3 -0
- data/rspec-mocks/lib/rspec/mocks/syntax.rb +329 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/targets.rb +20 -13
- data/rspec-mocks/lib/rspec/mocks/test_double.rb +135 -0
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/verifying_double.rb +69 -19
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/verifying_message_expecation.rb +23 -21
- data/{vendor_lib → rspec-mocks/lib}/rspec/mocks/verifying_proxy.rb +58 -38
- data/rspec-mocks/lib/rspec/mocks/version.rb +9 -0
- data/rspec-mocks/lib/rspec/mocks.rb +126 -0
- data/rspec-mocks/spec/rspec/mocks/and_call_original_spec.rb +267 -0
- data/rspec-mocks/spec/rspec/mocks/and_return_spec.rb +21 -0
- data/rspec-mocks/spec/rspec/mocks/and_wrap_original_spec.rb +63 -0
- data/rspec-mocks/spec/rspec/mocks/and_yield_spec.rb +161 -0
- data/rspec-mocks/spec/rspec/mocks/any_instance/message_chains_spec.rb +39 -0
- data/rspec-mocks/spec/rspec/mocks/any_instance_spec.rb +1242 -0
- data/rspec-mocks/spec/rspec/mocks/argument_matchers_spec.rb +336 -0
- data/rspec-mocks/spec/rspec/mocks/array_including_matcher_spec.rb +39 -0
- data/rspec-mocks/spec/rspec/mocks/at_least_spec.rb +147 -0
- data/rspec-mocks/spec/rspec/mocks/at_most_spec.rb +113 -0
- data/rspec-mocks/spec/rspec/mocks/before_all_spec.rb +75 -0
- data/rspec-mocks/spec/rspec/mocks/block_return_value_spec.rb +68 -0
- data/rspec-mocks/spec/rspec/mocks/combining_implementation_instructions_spec.rb +196 -0
- data/rspec-mocks/spec/rspec/mocks/configuration_spec.rb +175 -0
- data/rspec-mocks/spec/rspec/mocks/double_spec.rb +830 -0
- data/rspec-mocks/spec/rspec/mocks/example_methods_spec.rb +11 -0
- data/rspec-mocks/spec/rspec/mocks/expiration_spec.rb +90 -0
- data/rspec-mocks/spec/rspec/mocks/hash_excluding_matcher_spec.rb +65 -0
- data/rspec-mocks/spec/rspec/mocks/hash_including_matcher_spec.rb +92 -0
- data/rspec-mocks/spec/rspec/mocks/instance_method_stasher_spec.rb +72 -0
- data/rspec-mocks/spec/rspec/mocks/marshal_extension_spec.rb +67 -0
- data/rspec-mocks/spec/rspec/mocks/matchers/have_received_spec.rb +513 -0
- data/rspec-mocks/spec/rspec/mocks/matchers/receive_message_chain_spec.rb +227 -0
- data/rspec-mocks/spec/rspec/mocks/matchers/receive_messages_spec.rb +148 -0
- data/rspec-mocks/spec/rspec/mocks/matchers/receive_spec.rb +525 -0
- data/rspec-mocks/spec/rspec/mocks/methods_spec.rb +24 -0
- data/rspec-mocks/spec/rspec/mocks/mock_expectation_error_spec.rb +20 -0
- data/rspec-mocks/spec/rspec/mocks/mock_ordering_spec.rb +112 -0
- data/rspec-mocks/spec/rspec/mocks/multiple_return_value_spec.rb +130 -0
- data/rspec-mocks/spec/rspec/mocks/mutate_const_spec.rb +561 -0
- data/rspec-mocks/spec/rspec/mocks/nil_expectation_warning_spec.rb +52 -0
- data/rspec-mocks/spec/rspec/mocks/null_object_double_spec.rb +135 -0
- data/rspec-mocks/spec/rspec/mocks/once_counts_spec.rb +50 -0
- data/rspec-mocks/spec/rspec/mocks/order_group_spec.rb +26 -0
- data/rspec-mocks/spec/rspec/mocks/partial_double_spec.rb +379 -0
- data/rspec-mocks/spec/rspec/mocks/partial_double_using_mocks_directly_spec.rb +83 -0
- data/rspec-mocks/spec/rspec/mocks/precise_counts_spec.rb +66 -0
- data/rspec-mocks/spec/rspec/mocks/serialization_spec.rb +89 -0
- data/rspec-mocks/spec/rspec/mocks/should_syntax_spec.rb +539 -0
- data/rspec-mocks/spec/rspec/mocks/space_spec.rb +242 -0
- data/rspec-mocks/spec/rspec/mocks/spy_spec.rb +127 -0
- data/rspec-mocks/spec/rspec/mocks/stash_spec.rb +43 -0
- data/rspec-mocks/spec/rspec/mocks/stub_chain_spec.rb +166 -0
- data/rspec-mocks/spec/rspec/mocks/stub_implementation_spec.rb +98 -0
- data/rspec-mocks/spec/rspec/mocks/stub_spec.rb +520 -0
- data/rspec-mocks/spec/rspec/mocks/stubbed_message_expectations_spec.rb +56 -0
- data/rspec-mocks/spec/rspec/mocks/syntax_agnostic_message_matchers_spec.rb +99 -0
- data/rspec-mocks/spec/rspec/mocks/syntax_spec.rb +7 -0
- data/rspec-mocks/spec/rspec/mocks/test_double_spec.rb +53 -0
- data/rspec-mocks/spec/rspec/mocks/thrice_counts_spec.rb +72 -0
- data/rspec-mocks/spec/rspec/mocks/to_ary_spec.rb +52 -0
- data/rspec-mocks/spec/rspec/mocks/twice_counts_spec.rb +64 -0
- data/rspec-mocks/spec/rspec/mocks/verifying_doubles/class_double_with_class_loaded_spec.rb +118 -0
- data/rspec-mocks/spec/rspec/mocks/verifying_doubles/class_double_with_class_not_loaded_spec.rb +58 -0
- data/rspec-mocks/spec/rspec/mocks/verifying_doubles/construction_spec.rb +54 -0
- data/rspec-mocks/spec/rspec/mocks/verifying_doubles/expected_arg_verification_spec.rb +81 -0
- data/rspec-mocks/spec/rspec/mocks/verifying_doubles/instance_double_with_class_loaded_spec.rb +195 -0
- data/rspec-mocks/spec/rspec/mocks/verifying_doubles/instance_double_with_class_not_loaded_spec.rb +57 -0
- data/rspec-mocks/spec/rspec/mocks/verifying_doubles/method_visibility_spec.rb +129 -0
- data/rspec-mocks/spec/rspec/mocks/verifying_doubles/object_double_spec.rb +68 -0
- data/rspec-mocks/spec/rspec/mocks_spec.rb +199 -0
- data/rspec-mocks/spec/spec_helper.rb +131 -0
- data/rspec-mocks/spec/support/before_all_shared_example_group.rb +16 -0
- data/rspec-mocks/spec/support/doubled_classes.rb +74 -0
- data/rspec-mocks/spec/support/matchers.rb +15 -0
- data/rspec-support/benchmarks/caller.rb +81 -0
- data/{vendor_lib → rspec-support/lib}/rspec/support/caller_filter.rb +11 -4
- data/rspec-support/lib/rspec/support/differ.rb +214 -0
- data/rspec-support/lib/rspec/support/directory_maker.rb +61 -0
- data/rspec-support/lib/rspec/support/encoded_string.rb +69 -0
- data/rspec-support/lib/rspec/support/fuzzy_matcher.rb +48 -0
- data/rspec-support/lib/rspec/support/hunk_generator.rb +47 -0
- data/rspec-support/lib/rspec/support/matcher_definition.rb +31 -0
- data/rspec-support/lib/rspec/support/method_signature_verifier.rb +272 -0
- data/rspec-support/lib/rspec/support/os.rb +18 -0
- data/rspec-support/lib/rspec/support/recursive_const_methods.rb +76 -0
- data/rspec-support/lib/rspec/support/ruby_features.rb +45 -0
- data/rspec-support/lib/rspec/support/spec/deprecation_helpers.rb +60 -0
- data/rspec-support/lib/rspec/support/spec/formatting_support.rb +9 -0
- data/{vendor_lib → rspec-support/lib}/rspec/support/spec/in_sub_process.rb +5 -2
- data/rspec-support/lib/rspec/support/spec/prevent_load_time_warnings.rb +44 -0
- data/rspec-support/lib/rspec/support/spec/shell_out.rb +69 -0
- data/{vendor_lib → rspec-support/lib}/rspec/support/spec/stderr_splitter.rb +7 -5
- data/rspec-support/lib/rspec/support/spec/with_isolated_directory.rb +9 -0
- data/rspec-support/lib/rspec/support/spec/with_isolated_stderr.rb +13 -0
- data/rspec-support/lib/rspec/support/spec.rb +72 -0
- data/{vendor_lib → rspec-support/lib}/rspec/support/version.rb +1 -1
- data/rspec-support/lib/rspec/support/version_checker.rb +53 -0
- data/rspec-support/lib/rspec/support/warnings.rb +39 -0
- data/rspec-support/lib/rspec/support.rb +76 -0
- data/rspec-support/spec/rspec/support/caller_filter_spec.rb +66 -0
- data/rspec-support/spec/rspec/support/differ_spec.rb +322 -0
- data/rspec-support/spec/rspec/support/directory_maker_spec.rb +58 -0
- data/rspec-support/spec/rspec/support/encoded_string_spec.rb +86 -0
- data/rspec-support/spec/rspec/support/fuzzy_matcher_spec.rb +179 -0
- data/rspec-support/spec/rspec/support/method_signature_verifier_spec.rb +357 -0
- data/rspec-support/spec/rspec/support/os_spec.rb +36 -0
- data/rspec-support/spec/rspec/support/recursive_const_methods_spec.rb +49 -0
- data/rspec-support/spec/rspec/support/spec/in_sub_process_spec.rb +36 -0
- data/rspec-support/spec/rspec/support/spec/prevent_load_time_warnings_spec.rb +10 -0
- data/rspec-support/spec/rspec/support/spec/shell_out_spec.rb +44 -0
- data/rspec-support/spec/rspec/support/spec/stderr_splitter_spec.rb +60 -0
- data/rspec-support/spec/rspec/support/spec/with_isolated_std_err_spec.rb +21 -0
- data/rspec-support/spec/rspec/support/version_checker_spec.rb +29 -0
- data/rspec-support/spec/rspec/support/warnings_spec.rb +66 -0
- data/rspec-support/spec/rspec/support_spec.rb +119 -0
- data/rspec-support/spec/spec_helper.rb +2 -0
- data/spec/after_hooks_spec.rb +140 -0
- data/spec/around_hooks_spec.rb +223 -0
- data/spec/async_spec.rb +147 -1
- data/spec/before_hooks_spec.rb +183 -0
- data/spec/example_spec.rb +11 -0
- data/spec/matchers_spec.rb +4 -0
- data/spec/skip_pending_spec.rb +43 -0
- data/spec/subject_spec.rb +87 -0
- data/util/create_requires.rb +45 -0
- metadata +443 -147
- data/spec/named_subject_spec.rb +0 -11
- data/vendor_lib/rspec/core/backtrace_formatter.rb +0 -65
- data/vendor_lib/rspec/core/command_line.rb +0 -36
- data/vendor_lib/rspec/core/configuration_options.rb +0 -143
- data/vendor_lib/rspec/core/drb_command_line.rb +0 -26
- data/vendor_lib/rspec/core/drb_options.rb +0 -87
- data/vendor_lib/rspec/core/dsl.rb +0 -26
- data/vendor_lib/rspec/core/example.rb +0 -312
- data/vendor_lib/rspec/core/example_group.rb +0 -540
- data/vendor_lib/rspec/core/filter_manager.rb +0 -224
- data/vendor_lib/rspec/core/formatters/base_formatter.rb +0 -291
- data/vendor_lib/rspec/core/formatters/base_text_formatter.rb +0 -307
- data/vendor_lib/rspec/core/formatters/documentation_formatter.rb +0 -67
- data/vendor_lib/rspec/core/formatters/json_formatter.rb +0 -99
- data/vendor_lib/rspec/core/formatters/progress_formatter.rb +0 -32
- data/vendor_lib/rspec/core/formatters.rb +0 -54
- data/vendor_lib/rspec/core/hooks.rb +0 -535
- data/vendor_lib/rspec/core/metadata.rb +0 -313
- data/vendor_lib/rspec/core/mocking/with_absolutely_nothing.rb +0 -11
- data/vendor_lib/rspec/core/mocking/with_flexmock.rb +0 -27
- data/vendor_lib/rspec/core/mocking/with_rr.rb +0 -27
- data/vendor_lib/rspec/core/mocking/with_rspec.rb +0 -27
- data/vendor_lib/rspec/core/pending.rb +0 -110
- data/vendor_lib/rspec/core/project_initializer.rb +0 -88
- data/vendor_lib/rspec/core/rake_task.rb +0 -128
- data/vendor_lib/rspec/core/reporter.rb +0 -132
- data/vendor_lib/rspec/core/runner.rb +0 -97
- data/vendor_lib/rspec/core/shared_example_group/collection.rb +0 -27
- data/vendor_lib/rspec/core/shared_example_group.rb +0 -146
- data/vendor_lib/rspec/core/version.rb +0 -7
- data/vendor_lib/rspec/core/warnings.rb +0 -22
- data/vendor_lib/rspec/expectations/differ.rb +0 -154
- data/vendor_lib/rspec/expectations/errors.rb +0 -9
- data/vendor_lib/rspec/expectations/expectation_target.rb +0 -87
- data/vendor_lib/rspec/expectations/extensions/object.rb +0 -29
- data/vendor_lib/rspec/expectations/extensions.rb +0 -1
- data/vendor_lib/rspec/expectations/fail_with.rb +0 -79
- data/vendor_lib/rspec/expectations/handler.rb +0 -68
- data/vendor_lib/rspec/expectations/syntax.rb +0 -182
- data/vendor_lib/rspec/expectations.rb +0 -75
- data/vendor_lib/rspec/matchers/built_in/base_matcher.rb +0 -68
- data/vendor_lib/rspec/matchers/built_in/be.rb +0 -213
- data/vendor_lib/rspec/matchers/built_in/be_within.rb +0 -55
- data/vendor_lib/rspec/matchers/built_in/change.rb +0 -141
- data/vendor_lib/rspec/matchers/built_in/eq.rb +0 -22
- data/vendor_lib/rspec/matchers/built_in/equal.rb +0 -48
- data/vendor_lib/rspec/matchers/built_in/exist.rb +0 -26
- data/vendor_lib/rspec/matchers/built_in/has.rb +0 -48
- data/vendor_lib/rspec/matchers/built_in/include.rb +0 -61
- data/vendor_lib/rspec/matchers/built_in/match.rb +0 -17
- data/vendor_lib/rspec/matchers/built_in/match_array.rb +0 -51
- data/vendor_lib/rspec/matchers/built_in/start_and_end_with.rb +0 -48
- data/vendor_lib/rspec/matchers/built_in/yield.rb +0 -297
- data/vendor_lib/rspec/matchers/built_in.rb +0 -39
- data/vendor_lib/rspec/matchers/compatibility.rb +0 -14
- data/vendor_lib/rspec/matchers/dsl.rb +0 -23
- data/vendor_lib/rspec/matchers/method_missing.rb +0 -12
- data/vendor_lib/rspec/matchers/operator_matcher.rb +0 -99
- data/vendor_lib/rspec/matchers/pretty.rb +0 -70
- data/vendor_lib/rspec/matchers/test_unit_integration.rb +0 -11
- data/vendor_lib/rspec/mocks/argument_list_matcher.rb +0 -104
- data/vendor_lib/rspec/mocks/argument_matchers.rb +0 -264
- data/vendor_lib/rspec/mocks/arity_calculator.rb +0 -66
- data/vendor_lib/rspec/mocks/errors.rb +0 -12
- data/vendor_lib/rspec/mocks/example_methods.rb +0 -201
- data/vendor_lib/rspec/mocks/extensions/marshal.rb +0 -17
- data/vendor_lib/rspec/mocks/framework.rb +0 -36
- data/vendor_lib/rspec/mocks/method_reference.rb +0 -95
- data/vendor_lib/rspec/mocks/mock.rb +0 -7
- data/vendor_lib/rspec/mocks/proxy.rb +0 -269
- data/vendor_lib/rspec/mocks/proxy_for_nil.rb +0 -37
- data/vendor_lib/rspec/mocks/space.rb +0 -95
- data/vendor_lib/rspec/mocks/standalone.rb +0 -3
- data/vendor_lib/rspec/mocks/stub_chain.rb +0 -51
- data/vendor_lib/rspec/mocks/syntax.rb +0 -374
- data/vendor_lib/rspec/mocks/test_double.rb +0 -109
- data/vendor_lib/rspec/mocks/version.rb +0 -7
- data/vendor_lib/rspec/mocks.rb +0 -100
- data/vendor_lib/rspec/support/spec/deprecation_helpers.rb +0 -29
- data/vendor_lib/rspec/support/spec.rb +0 -14
- data/vendor_lib/rspec/support/warnings.rb +0 -41
- data/vendor_lib/rspec/support.rb +0 -6
- data/vendor_lib/rspec-expectations.rb +0 -1
@@ -0,0 +1,259 @@
|
|
1
|
+
module RSpec
|
2
|
+
module Core
|
3
|
+
# @private
|
4
|
+
# Manages the filtering of examples and groups by matching tags declared on
|
5
|
+
# the command line or options files, or filters declared via
|
6
|
+
# `RSpec.configure`, with hash key/values submitted within example group
|
7
|
+
# and/or example declarations. For example, given this declaration:
|
8
|
+
#
|
9
|
+
# describe Thing, :awesome => true do
|
10
|
+
# it "does something" do
|
11
|
+
# # ...
|
12
|
+
# end
|
13
|
+
# end
|
14
|
+
#
|
15
|
+
# That group (or any other with `:awesome => true`) would be filtered in
|
16
|
+
# with any of the following commands:
|
17
|
+
#
|
18
|
+
# rspec --tag awesome:true
|
19
|
+
# rspec --tag awesome
|
20
|
+
# rspec -t awesome:true
|
21
|
+
# rspec -t awesome
|
22
|
+
#
|
23
|
+
# Prefixing the tag names with `~` negates the tags, thus excluding this group with
|
24
|
+
# any of:
|
25
|
+
#
|
26
|
+
# rspec --tag ~awesome:true
|
27
|
+
# rspec --tag ~awesome
|
28
|
+
# rspec -t ~awesome:true
|
29
|
+
# rspec -t ~awesome
|
30
|
+
#
|
31
|
+
# ## Options files and command line overrides
|
32
|
+
#
|
33
|
+
# Tag declarations can be stored in `.rspec`, `~/.rspec`, or a custom
|
34
|
+
# options file. This is useful for storing defaults. For example, let's
|
35
|
+
# say you've got some slow specs that you want to suppress most of the
|
36
|
+
# time. You can tag them like this:
|
37
|
+
#
|
38
|
+
# describe Something, :slow => true do
|
39
|
+
#
|
40
|
+
# And then store this in `.rspec`:
|
41
|
+
#
|
42
|
+
# --tag ~slow:true
|
43
|
+
#
|
44
|
+
# Now when you run `rspec`, that group will be excluded.
|
45
|
+
#
|
46
|
+
# ## Overriding
|
47
|
+
#
|
48
|
+
# Of course, you probably want to run them sometimes, so you can override
|
49
|
+
# this tag on the command line like this:
|
50
|
+
#
|
51
|
+
# rspec --tag slow:true
|
52
|
+
#
|
53
|
+
# ## RSpec.configure
|
54
|
+
#
|
55
|
+
# You can also store default tags with `RSpec.configure`. We use `tag` on
|
56
|
+
# the command line (and in options files like `.rspec`), but for historical
|
57
|
+
# reasons we use the term `filter` in `RSpec.configure:
|
58
|
+
#
|
59
|
+
# RSpec.configure do |c|
|
60
|
+
# c.filter_run_including :foo => :bar
|
61
|
+
# c.filter_run_excluding :foo => :bar
|
62
|
+
# end
|
63
|
+
#
|
64
|
+
# These declarations can also be overridden from the command line.
|
65
|
+
#
|
66
|
+
# @see RSpec.configure
|
67
|
+
# @see Configuration#filter_run_including
|
68
|
+
# @see Configuration#filter_run_excluding
|
69
|
+
class FilterManager
|
70
|
+
attr_reader :exclusions, :inclusions
|
71
|
+
|
72
|
+
def initialize
|
73
|
+
@exclusions, @inclusions = FilterRules.build
|
74
|
+
end
|
75
|
+
|
76
|
+
# @api private
|
77
|
+
#
|
78
|
+
# @param file_path [String]
|
79
|
+
# @param line_numbers [Array]
|
80
|
+
def add_location(file_path, line_numbers)
|
81
|
+
# locations is a hash of expanded paths to arrays of line
|
82
|
+
# numbers to match against. e.g.
|
83
|
+
# { "path/to/file.rb" => [37, 42] }
|
84
|
+
locations = inclusions.delete(:locations) || Hash.new { |h, k| h[k] = [] }
|
85
|
+
locations[File.expand_path(file_path)].push(*line_numbers)
|
86
|
+
inclusions.add_location(locations)
|
87
|
+
end
|
88
|
+
|
89
|
+
def empty?
|
90
|
+
inclusions.empty? && exclusions.empty?
|
91
|
+
end
|
92
|
+
|
93
|
+
def prune(examples)
|
94
|
+
if inclusions.standalone?
|
95
|
+
base_exclusions = ExclusionRules.new
|
96
|
+
examples.select { |e| !base_exclusions.include_example?(e) && include?(e) }
|
97
|
+
else
|
98
|
+
examples.select { |e| !exclude?(e) && include?(e) }
|
99
|
+
end
|
100
|
+
end
|
101
|
+
|
102
|
+
def exclude(*args)
|
103
|
+
exclusions.add(args.last)
|
104
|
+
end
|
105
|
+
|
106
|
+
def exclude_only(*args)
|
107
|
+
exclusions.use_only(args.last)
|
108
|
+
end
|
109
|
+
|
110
|
+
def exclude_with_low_priority(*args)
|
111
|
+
exclusions.add_with_low_priority(args.last)
|
112
|
+
end
|
113
|
+
|
114
|
+
def exclude?(example)
|
115
|
+
exclusions.include_example?(example)
|
116
|
+
end
|
117
|
+
|
118
|
+
def include(*args)
|
119
|
+
inclusions.add(args.last)
|
120
|
+
end
|
121
|
+
|
122
|
+
def include_only(*args)
|
123
|
+
inclusions.use_only(args.last)
|
124
|
+
end
|
125
|
+
|
126
|
+
def include_with_low_priority(*args)
|
127
|
+
inclusions.add_with_low_priority(args.last)
|
128
|
+
end
|
129
|
+
|
130
|
+
def include?(example)
|
131
|
+
inclusions.include_example?(example)
|
132
|
+
end
|
133
|
+
end
|
134
|
+
|
135
|
+
# @private
|
136
|
+
class FilterRules
|
137
|
+
PROC_HEX_NUMBER = /0x[0-9a-f]+@/
|
138
|
+
PROJECT_DIR = File.expand_path('.')
|
139
|
+
|
140
|
+
attr_accessor :opposite
|
141
|
+
attr_reader :rules
|
142
|
+
|
143
|
+
def self.build
|
144
|
+
exclusions = ExclusionRules.new
|
145
|
+
inclusions = InclusionRules.new
|
146
|
+
exclusions.opposite = inclusions
|
147
|
+
inclusions.opposite = exclusions
|
148
|
+
[exclusions, inclusions]
|
149
|
+
end
|
150
|
+
|
151
|
+
def initialize(*args, &block)
|
152
|
+
@rules = Hash.new(*args, &block)
|
153
|
+
end
|
154
|
+
|
155
|
+
def add(updated)
|
156
|
+
@rules.merge!(updated).each_key { |k| opposite.delete(k) }
|
157
|
+
end
|
158
|
+
|
159
|
+
def add_with_low_priority(updated)
|
160
|
+
updated = updated.merge(@rules)
|
161
|
+
opposite.each_pair { |k, v| updated.delete(k) if updated[k] == v }
|
162
|
+
@rules.replace(updated)
|
163
|
+
end
|
164
|
+
|
165
|
+
def use_only(updated)
|
166
|
+
updated.each_key { |k| opposite.delete(k) }
|
167
|
+
@rules.replace(updated)
|
168
|
+
end
|
169
|
+
|
170
|
+
def clear
|
171
|
+
@rules.clear
|
172
|
+
end
|
173
|
+
|
174
|
+
def delete(key)
|
175
|
+
@rules.delete(key)
|
176
|
+
end
|
177
|
+
|
178
|
+
def fetch(*args, &block)
|
179
|
+
@rules.fetch(*args, &block)
|
180
|
+
end
|
181
|
+
|
182
|
+
def [](key)
|
183
|
+
@rules[key]
|
184
|
+
end
|
185
|
+
|
186
|
+
def empty?
|
187
|
+
rules.empty?
|
188
|
+
end
|
189
|
+
|
190
|
+
def each_pair(&block)
|
191
|
+
@rules.each_pair(&block)
|
192
|
+
end
|
193
|
+
|
194
|
+
def description
|
195
|
+
rules.inspect.gsub(PROC_HEX_NUMBER, '').gsub(PROJECT_DIR, '.').gsub(' (lambda)', '')
|
196
|
+
end
|
197
|
+
end
|
198
|
+
|
199
|
+
# @private
|
200
|
+
class InclusionRules < FilterRules
|
201
|
+
STANDALONE_FILTERS = [:locations, :full_description]
|
202
|
+
|
203
|
+
def add_location(locations)
|
204
|
+
replace_filters(:locations => locations)
|
205
|
+
end
|
206
|
+
|
207
|
+
def add(*args)
|
208
|
+
apply_standalone_filter(*args) || super
|
209
|
+
end
|
210
|
+
|
211
|
+
def add_with_low_priority(*args)
|
212
|
+
apply_standalone_filter(*args) || super
|
213
|
+
end
|
214
|
+
|
215
|
+
def use(*args)
|
216
|
+
apply_standalone_filter(*args) || super
|
217
|
+
end
|
218
|
+
|
219
|
+
def include_example?(example)
|
220
|
+
@rules.empty? ? true : example.any_apply?(@rules)
|
221
|
+
end
|
222
|
+
|
223
|
+
def standalone?
|
224
|
+
is_standalone_filter?(@rules)
|
225
|
+
end
|
226
|
+
|
227
|
+
private
|
228
|
+
|
229
|
+
def apply_standalone_filter(updated)
|
230
|
+
return true if standalone?
|
231
|
+
return nil unless is_standalone_filter?(updated)
|
232
|
+
|
233
|
+
replace_filters(updated)
|
234
|
+
true
|
235
|
+
end
|
236
|
+
|
237
|
+
def replace_filters(new_rules)
|
238
|
+
@rules.replace(new_rules)
|
239
|
+
opposite.clear
|
240
|
+
end
|
241
|
+
|
242
|
+
def is_standalone_filter?(rules)
|
243
|
+
STANDALONE_FILTERS.any? { |key| rules.key?(key) }
|
244
|
+
end
|
245
|
+
end
|
246
|
+
|
247
|
+
# @private
|
248
|
+
class ExclusionRules < FilterRules
|
249
|
+
CONDITIONAL_FILTERS = {
|
250
|
+
:if => lambda { |value| !value },
|
251
|
+
:unless => lambda { |value| value }
|
252
|
+
}.freeze
|
253
|
+
|
254
|
+
def include_example?(example)
|
255
|
+
example.any_apply?(@rules) || example.any_apply?(CONDITIONAL_FILTERS)
|
256
|
+
end
|
257
|
+
end
|
258
|
+
end
|
259
|
+
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
RSpec::Support.require_rspec_core "formatters/helpers"
|
2
|
+
require 'stringio'
|
3
|
+
|
4
|
+
module RSpec
|
5
|
+
module Core
|
6
|
+
module Formatters
|
7
|
+
# RSpec's built-in formatters are all subclasses of RSpec::Core::Formatters::BaseTextFormatter.
|
8
|
+
#
|
9
|
+
# @see RSpec::Core::Formatters::BaseTextFormatter
|
10
|
+
# @see RSpec::Core::Reporter
|
11
|
+
# @see RSpec::Core::Formatters::Protocol
|
12
|
+
class BaseFormatter
|
13
|
+
# all formatters inheriting from this formatter will receive these notifications
|
14
|
+
Formatters.register self, :start, :example_group_started, :close
|
15
|
+
attr_accessor :example_group
|
16
|
+
attr_reader :output
|
17
|
+
|
18
|
+
# @api public
|
19
|
+
# @param output [IO] the formatter output
|
20
|
+
# @see RSpec::Core::Formatters::Protocol#initialize
|
21
|
+
def initialize(output)
|
22
|
+
@output = output || StringIO.new
|
23
|
+
@example_group = nil
|
24
|
+
end
|
25
|
+
|
26
|
+
# @api public
|
27
|
+
#
|
28
|
+
# @param notification [StartNotification]
|
29
|
+
# @see RSpec::Core::Formatters::Protocol#start
|
30
|
+
def start(notification)
|
31
|
+
start_sync_output
|
32
|
+
@example_count = notification.count
|
33
|
+
end
|
34
|
+
|
35
|
+
# @api public
|
36
|
+
#
|
37
|
+
# @param notification [GroupNotification] containing example_group subclass of `RSpec::Core::ExampleGroup`
|
38
|
+
# @see RSpec::Core::Formatters::Protocol#example_group_started
|
39
|
+
def example_group_started(notification)
|
40
|
+
@example_group = notification.group
|
41
|
+
end
|
42
|
+
|
43
|
+
# @api public
|
44
|
+
#
|
45
|
+
# @param notification [NullNotification]
|
46
|
+
# @see RSpec::Core::Formatters::Protocol#close
|
47
|
+
def close(_notification)
|
48
|
+
restore_sync_output
|
49
|
+
end
|
50
|
+
|
51
|
+
private
|
52
|
+
|
53
|
+
def start_sync_output
|
54
|
+
@old_sync, output.sync = output.sync, true if output_supports_sync
|
55
|
+
end
|
56
|
+
|
57
|
+
def restore_sync_output
|
58
|
+
output.sync = @old_sync if output_supports_sync && !output.closed?
|
59
|
+
end
|
60
|
+
|
61
|
+
def output_supports_sync
|
62
|
+
output.respond_to?(:sync=)
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
@@ -0,0 +1,76 @@
|
|
1
|
+
RSpec::Support.require_rspec_core "formatters/base_formatter"
|
2
|
+
RSpec::Support.require_rspec_core "formatters/console_codes"
|
3
|
+
|
4
|
+
module RSpec
|
5
|
+
module Core
|
6
|
+
module Formatters
|
7
|
+
# Base for all of RSpec's built-in formatters. See RSpec::Core::Formatters::BaseFormatter
|
8
|
+
# to learn more about all of the methods called by the reporter.
|
9
|
+
#
|
10
|
+
# @see RSpec::Core::Formatters::BaseFormatter
|
11
|
+
# @see RSpec::Core::Reporter
|
12
|
+
class BaseTextFormatter < BaseFormatter
|
13
|
+
Formatters.register self,
|
14
|
+
:message, :dump_summary, :dump_failures, :dump_pending, :seed
|
15
|
+
|
16
|
+
# @method message
|
17
|
+
# @api public
|
18
|
+
#
|
19
|
+
# Used by the reporter to send messages to the output stream.
|
20
|
+
#
|
21
|
+
# @param notification [MessageNotification] containing message
|
22
|
+
def message(notification)
|
23
|
+
output.puts notification.message
|
24
|
+
end
|
25
|
+
|
26
|
+
# @method dump_failures
|
27
|
+
# @api public
|
28
|
+
#
|
29
|
+
# Dumps detailed information about each example failure.
|
30
|
+
#
|
31
|
+
# @param notification [NullNotification]
|
32
|
+
def dump_failures(notification)
|
33
|
+
return if notification.failure_notifications.empty?
|
34
|
+
output.puts notification.fully_formatted_failed_examples
|
35
|
+
end
|
36
|
+
|
37
|
+
# @method dump_summary
|
38
|
+
# @api public
|
39
|
+
#
|
40
|
+
# This method is invoked after the dumping of examples and failures. Each parameter
|
41
|
+
# is assigned to a corresponding attribute.
|
42
|
+
#
|
43
|
+
# @param summary [SummaryNotification] containing duration, example_count,
|
44
|
+
# failure_count and pending_count
|
45
|
+
def dump_summary(summary)
|
46
|
+
output.puts summary.fully_formatted
|
47
|
+
end
|
48
|
+
|
49
|
+
# @private
|
50
|
+
def dump_pending(notification)
|
51
|
+
return if notification.pending_examples.empty?
|
52
|
+
output.puts notification.fully_formatted_pending_examples
|
53
|
+
end
|
54
|
+
|
55
|
+
# @private
|
56
|
+
def seed(notification)
|
57
|
+
return unless notification.seed_used?
|
58
|
+
output.puts notification.fully_formatted
|
59
|
+
end
|
60
|
+
|
61
|
+
# @api public
|
62
|
+
#
|
63
|
+
# Invoked at the very end, `close` allows the formatter to clean
|
64
|
+
# up resources, e.g. open streams, etc.
|
65
|
+
#
|
66
|
+
# @param notification [NullNotification]
|
67
|
+
def close(_notification)
|
68
|
+
return unless IO === output
|
69
|
+
return if output.closed? || output == $stdout
|
70
|
+
|
71
|
+
output.close
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
@@ -0,0 +1,64 @@
|
|
1
|
+
module RSpec
|
2
|
+
module Core
|
3
|
+
module Formatters
|
4
|
+
# ConsoleCodes provides helpers for formatting console output
|
5
|
+
# with ANSI codes, e.g. color's and bold.
|
6
|
+
module ConsoleCodes
|
7
|
+
# @private
|
8
|
+
VT100_CODES =
|
9
|
+
{
|
10
|
+
:black => 30,
|
11
|
+
:red => 31,
|
12
|
+
:green => 32,
|
13
|
+
:yellow => 33,
|
14
|
+
:blue => 34,
|
15
|
+
:magenta => 35,
|
16
|
+
:cyan => 36,
|
17
|
+
:white => 37,
|
18
|
+
:bold => 1,
|
19
|
+
}
|
20
|
+
# @private
|
21
|
+
VT100_CODE_VALUES = VT100_CODES.invert
|
22
|
+
|
23
|
+
module_function
|
24
|
+
|
25
|
+
# Fetches the correct code for the supplied symbol, or checks
|
26
|
+
# that a code is valid. Defaults to white (37).
|
27
|
+
#
|
28
|
+
# @param code_or_symbol [Symbol, Fixnum] Symbol or code to check
|
29
|
+
# @return [Fixnum] a console code
|
30
|
+
def console_code_for(code_or_symbol)
|
31
|
+
if RSpec.configuration.respond_to?(:"#{code_or_symbol}_color")
|
32
|
+
console_code_for configuration_color(code_or_symbol)
|
33
|
+
elsif VT100_CODE_VALUES.key?(code_or_symbol)
|
34
|
+
code_or_symbol
|
35
|
+
else
|
36
|
+
VT100_CODES.fetch(code_or_symbol) do
|
37
|
+
console_code_for(:white)
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
# Wraps a piece of text in ANSI codes with the supplied code. Will
|
43
|
+
# only apply the control code if `RSpec.configuration.color_enabled?`
|
44
|
+
# returns true.
|
45
|
+
#
|
46
|
+
# @param text [String] the text to wrap
|
47
|
+
# @param code_or_symbol [Symbol, Fixnum] the desired control code
|
48
|
+
# @return [String] the wrapped text
|
49
|
+
def wrap(text, code_or_symbol)
|
50
|
+
if RSpec.configuration.color_enabled?
|
51
|
+
"\e[#{console_code_for(code_or_symbol)}m#{text}\e[0m"
|
52
|
+
else
|
53
|
+
text
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
# @private
|
58
|
+
def configuration_color(code)
|
59
|
+
RSpec.configuration.__send__(:"#{code}_color")
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
@@ -1,10 +1,13 @@
|
|
1
|
-
|
1
|
+
RSpec::Support.require_rspec_core "formatters/helpers"
|
2
2
|
require 'set'
|
3
3
|
|
4
4
|
module RSpec
|
5
5
|
module Core
|
6
6
|
module Formatters
|
7
|
+
# @private
|
7
8
|
class DeprecationFormatter
|
9
|
+
Formatters.register self, :deprecation, :deprecation_summary
|
10
|
+
|
8
11
|
attr_reader :count, :deprecation_stream, :summary_stream
|
9
12
|
|
10
13
|
def initialize(deprecation_stream, summary_stream)
|
@@ -13,30 +16,33 @@ module RSpec
|
|
13
16
|
@seen_deprecations = Set.new
|
14
17
|
@count = 0
|
15
18
|
end
|
19
|
+
alias :output :deprecation_stream
|
16
20
|
|
17
21
|
def printer
|
18
22
|
@printer ||= case deprecation_stream
|
19
|
-
when File
|
23
|
+
when File
|
24
|
+
ImmediatePrinter.new(FileStream.new(deprecation_stream), summary_stream, self)
|
25
|
+
when RaiseErrorStream
|
20
26
|
ImmediatePrinter.new(deprecation_stream, summary_stream, self)
|
21
27
|
else
|
22
28
|
DelayedPrinter.new(deprecation_stream, summary_stream, self)
|
23
29
|
end
|
24
30
|
end
|
25
31
|
|
26
|
-
def deprecation(
|
27
|
-
return if @seen_deprecations.include?
|
32
|
+
def deprecation(notification)
|
33
|
+
return if @seen_deprecations.include? notification
|
28
34
|
|
29
35
|
@count += 1
|
30
|
-
printer.print_deprecation_message
|
31
|
-
@seen_deprecations <<
|
36
|
+
printer.print_deprecation_message notification
|
37
|
+
@seen_deprecations << notification
|
32
38
|
end
|
33
39
|
|
34
|
-
def deprecation_summary
|
40
|
+
def deprecation_summary(_notification)
|
35
41
|
printer.deprecation_summary
|
36
42
|
end
|
37
43
|
|
38
44
|
def deprecation_message_for(data)
|
39
|
-
if data
|
45
|
+
if data.message
|
40
46
|
SpecifiedDeprecationMessage.new(data)
|
41
47
|
else
|
42
48
|
GeneratedDeprecationMessage.new(data)
|
@@ -51,63 +57,65 @@ module RSpec
|
|
51
57
|
|deprecation warnings into errors, giving you the full backtrace.
|
52
58
|
EOS
|
53
59
|
|
60
|
+
DEPRECATION_STREAM_NOTICE = "Pass `--deprecation-out` or set " \
|
61
|
+
"`config.deprecation_stream` to a file for full output."
|
62
|
+
|
54
63
|
SpecifiedDeprecationMessage = Struct.new(:type) do
|
55
64
|
def initialize(data)
|
56
|
-
@message = data
|
65
|
+
@message = data.message
|
57
66
|
super deprecation_type_for(data)
|
58
67
|
end
|
59
68
|
|
60
69
|
def to_s
|
61
|
-
@message
|
70
|
+
output_formatted @message
|
62
71
|
end
|
63
72
|
|
64
73
|
def too_many_warnings_message
|
65
|
-
msg = "Too many similar deprecation messages reported, disregarding further reports."
|
66
|
-
msg <<
|
74
|
+
msg = "Too many similar deprecation messages reported, disregarding further reports. "
|
75
|
+
msg << DEPRECATION_STREAM_NOTICE
|
67
76
|
msg
|
68
77
|
end
|
69
78
|
|
70
79
|
private
|
71
80
|
|
81
|
+
def output_formatted(str)
|
82
|
+
return str unless str.lines.count > 1
|
83
|
+
separator = "#{'-' * 80}"
|
84
|
+
"#{separator}\n#{str.chomp}\n#{separator}"
|
85
|
+
end
|
86
|
+
|
72
87
|
def deprecation_type_for(data)
|
73
|
-
data
|
88
|
+
data.message.gsub(/(\w+\/)+\w+\.rb:\d+/, '')
|
74
89
|
end
|
75
90
|
end
|
76
91
|
|
77
92
|
GeneratedDeprecationMessage = Struct.new(:type) do
|
78
93
|
def initialize(data)
|
79
94
|
@data = data
|
80
|
-
super data
|
95
|
+
super data.deprecated
|
81
96
|
end
|
82
97
|
|
83
98
|
def to_s
|
84
|
-
msg = "#{@data
|
85
|
-
msg << " Use #{@data
|
86
|
-
msg << " Called from #{@data
|
99
|
+
msg = "#{@data.deprecated} is deprecated."
|
100
|
+
msg << " Use #{@data.replacement} instead." if @data.replacement
|
101
|
+
msg << " Called from #{@data.call_site}." if @data.call_site
|
87
102
|
msg
|
88
103
|
end
|
89
104
|
|
90
105
|
def too_many_warnings_message
|
91
|
-
msg = "Too many uses of deprecated '#{type}'."
|
92
|
-
msg <<
|
106
|
+
msg = "Too many uses of deprecated '#{type}'. "
|
107
|
+
msg << DEPRECATION_STREAM_NOTICE
|
93
108
|
msg
|
94
109
|
end
|
95
110
|
end
|
96
111
|
|
112
|
+
# @private
|
97
113
|
class ImmediatePrinter
|
98
|
-
include ::RSpec::Core::Formatters::Helpers
|
99
|
-
|
100
114
|
attr_reader :deprecation_stream, :summary_stream, :deprecation_formatter
|
101
115
|
|
102
116
|
def initialize(deprecation_stream, summary_stream, deprecation_formatter)
|
103
117
|
@deprecation_stream = deprecation_stream
|
104
118
|
|
105
|
-
# In one of my test suites, I got lots of duplicate output in the
|
106
|
-
# deprecation file (e.g. 200 of the same deprecation, even though
|
107
|
-
# the `puts` below was only called 6 times). Setting `sync = true`
|
108
|
-
# fixes this (but we really have no idea why!).
|
109
|
-
@deprecation_stream.sync = true
|
110
|
-
|
111
119
|
@summary_stream = summary_stream
|
112
120
|
@deprecation_formatter = deprecation_formatter
|
113
121
|
end
|
@@ -118,18 +126,15 @@ module RSpec
|
|
118
126
|
end
|
119
127
|
|
120
128
|
def deprecation_summary
|
121
|
-
if deprecation_formatter.count
|
122
|
-
|
123
|
-
deprecation_stream.puts RAISE_ERROR_CONFIG_NOTICE
|
124
|
-
end
|
129
|
+
return if deprecation_formatter.count.zero?
|
130
|
+
deprecation_stream.summarize(summary_stream, deprecation_formatter.count)
|
125
131
|
end
|
126
132
|
end
|
127
133
|
|
134
|
+
# @private
|
128
135
|
class DelayedPrinter
|
129
136
|
TOO_MANY_USES_LIMIT = 4
|
130
137
|
|
131
|
-
include ::RSpec::Core::Formatters::Helpers
|
132
|
-
|
133
138
|
attr_reader :deprecation_stream, :summary_stream, :deprecation_formatter
|
134
139
|
|
135
140
|
def initialize(deprecation_stream, summary_stream, deprecation_formatter)
|
@@ -161,7 +166,7 @@ module RSpec
|
|
161
166
|
print_deferred_deprecation_warnings
|
162
167
|
deprecation_stream.puts RAISE_ERROR_CONFIG_NOTICE
|
163
168
|
|
164
|
-
summary_stream.puts "\n#{pluralize(deprecation_formatter.count, 'deprecation warning')} total"
|
169
|
+
summary_stream.puts "\n#{Helpers.pluralize(deprecation_formatter.count, 'deprecation warning')} total"
|
165
170
|
end
|
166
171
|
|
167
172
|
def print_deferred_deprecation_warnings
|
@@ -174,20 +179,44 @@ module RSpec
|
|
174
179
|
end
|
175
180
|
end
|
176
181
|
|
182
|
+
# @private
|
177
183
|
# Not really a stream, but is usable in place of one.
|
178
184
|
class RaiseErrorStream
|
179
185
|
def puts(message)
|
180
186
|
raise DeprecationError, message
|
181
187
|
end
|
182
188
|
|
183
|
-
def
|
184
|
-
#
|
189
|
+
def summarize(summary_stream, deprecation_count)
|
190
|
+
summary_stream.puts "\n#{Helpers.pluralize(deprecation_count, 'deprecation')} found."
|
185
191
|
end
|
186
192
|
end
|
187
193
|
|
194
|
+
# @private
|
195
|
+
# Wraps a File object and provides file-specific operations.
|
196
|
+
class FileStream
|
197
|
+
def initialize(file)
|
198
|
+
@file = file
|
199
|
+
|
200
|
+
# In one of my test suites, I got lots of duplicate output in the
|
201
|
+
# deprecation file (e.g. 200 of the same deprecation, even though
|
202
|
+
# the `puts` below was only called 6 times). Setting `sync = true`
|
203
|
+
# fixes this (but we really have no idea why!).
|
204
|
+
@file.sync = true
|
205
|
+
end
|
206
|
+
|
207
|
+
def puts(*args)
|
208
|
+
@file.puts(*args)
|
209
|
+
end
|
210
|
+
|
211
|
+
def summarize(summary_stream, deprecation_count)
|
212
|
+
summary_stream.puts "\n#{Helpers.pluralize(deprecation_count, 'deprecation')} logged to #{@file.path}"
|
213
|
+
puts RAISE_ERROR_CONFIG_NOTICE
|
214
|
+
end
|
215
|
+
end
|
188
216
|
end
|
189
217
|
end
|
190
218
|
|
219
|
+
# Deprecation Error
|
191
220
|
DeprecationError = Class.new(StandardError)
|
192
221
|
end
|
193
222
|
end
|