cucumber 1.3.20 → 2.0.0.beta.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.coveralls.yml +1 -0
- data/.rspec +1 -1
- data/.travis.yml +1 -2
- data/CONTRIBUTING.md +9 -0
- data/Gemfile +9 -2
- data/History.md +26 -17
- data/LICENSE +2 -2
- data/README.md +4 -4
- data/Rakefile +12 -0
- data/bin/cucumber +1 -5
- data/bin/cuke +60 -0
- data/cucumber.gemspec +10 -15
- data/cucumber.yml +14 -26
- data/examples/i18n/ar/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/bg/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/ca/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/cs/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/da/features/{step_definitons → step_definitions}/lommeregner_steps.rb +0 -0
- data/examples/i18n/de/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/{ramaze → i18n/el}/Rakefile +1 -1
- data/examples/i18n/el/features/addition.feature +17 -0
- data/examples/i18n/el/features/division.feature +10 -0
- data/examples/i18n/el/features/step_definitions/calculator_steps.rb +24 -0
- data/examples/i18n/el/lib/calculator.rb +14 -0
- data/examples/i18n/en/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/eo/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/es/features/{step_definitons → step_definitions}/calculador_steps.rb +0 -0
- data/examples/i18n/fi/features/{step_definitons → step_definitions}/laskin_steps.rb +0 -0
- data/examples/i18n/fr/Rakefile +3 -1
- data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +2 -2
- data/examples/i18n/he/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/hi/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/hu/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/id/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/it/features/{step_definitons → step_definitions}/calcolatrice_steps.rb +0 -0
- data/examples/i18n/ja/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/ko/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/lt/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/lv/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/no/features/{step_definitons → step_definitions}/kalkulator_steps.rb +0 -0
- data/examples/i18n/pl/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/ro/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/ru/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/sk/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/sr-Cyrl/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/sr-Latn/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/sv/features/{step_definitons → step_definitions}/kalkulator_steps.rb +0 -0
- data/examples/i18n/tr/features/{step_definitons → step_definitions}/hesap_makinesi_adimlari.rb +0 -0
- data/examples/i18n/uk/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/uz/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/examples/i18n/zh-CN/features/{step_definitons → step_definitions}/calculator_steps.rb +4 -4
- data/examples/i18n/zh-TW/features/{step_definitons → step_definitions}/calculator_steps.rb +0 -0
- data/{legacy_features → features/docs}/api/list_step_defs_as_json.feature +14 -14
- data/{legacy_features → features/docs}/api/run_cli_main_with_existing_runtime.feature +5 -10
- data/features/{backtraces.feature → docs/cli/backtraces.feature} +2 -2
- data/features/docs/cli/dry_run.feature +25 -0
- data/features/docs/cli/exclude_files.feature +19 -0
- data/features/docs/cli/execute_with_tag_filter.feature +117 -0
- data/features/docs/cli/randomize.feature +46 -0
- data/features/docs/cli/require.feature +27 -0
- data/features/docs/cli/run_scenarios_matching_name.feature +104 -0
- data/features/docs/cli/run_specific_scenarios.feature +113 -0
- data/features/docs/cli/showing_differences.feature +43 -0
- data/features/docs/cli/specifying_multiple_formatters.feature +44 -0
- data/features/docs/cli/strict_mode.feature +41 -0
- data/features/{nested_steps.feature → docs/defining_steps/nested_steps.feature} +3 -5
- data/features/{nested_steps_i18n.feature → docs/defining_steps/nested_steps_i18n.feature} +0 -2
- data/features/{nested_steps_with_second_arg.feature → docs/defining_steps/nested_steps_with_second_arg.feature} +0 -0
- data/features/{step_definitions.feature → docs/defining_steps/one_line_step_definitions.feature} +3 -3
- data/features/docs/defining_steps/printing_messages.feature +147 -0
- data/features/docs/defining_steps/skip_scenario.feature +33 -0
- data/features/docs/defining_steps/snippets.feature +41 -0
- data/{legacy_features → features/docs/defining_steps}/table_diffing.feature +15 -15
- data/features/{transforms.feature → docs/defining_steps/transforms.feature} +2 -2
- data/{legacy_features/exception_in_after_block.feature → features/docs/exception_in_after_hook.feature} +25 -26
- data/{legacy_features/exception_in_after_step_block.feature → features/docs/exception_in_after_step_hook.feature} +21 -24
- data/{legacy_features/exception_in_before_block.feature → features/docs/exception_in_before_hook.feature} +18 -20
- data/features/{custom_formatter.feature → docs/extending_cucumber/custom_formatter.feature} +3 -8
- data/features/{formatter_callbacks.feature → docs/extending_cucumber/formatter_callbacks.feature} +185 -4
- data/{legacy_features/listener_debugger_formatter.feature → features/docs/formatters/debug_formatter.feature} +13 -15
- data/features/{formatter_step_file_colon_line.feature → docs/formatters/formatter_step_file_colon_line.feature} +2 -4
- data/features/{html_formatter.feature → docs/formatters/html_formatter.feature} +10 -14
- data/features/{json_formatter.feature → docs/formatters/json_formatter.feature} +109 -247
- data/features/docs/formatters/junit_formatter.feature +275 -0
- data/features/{pretty_formatter.feature → docs/formatters/pretty_formatter.feature} +1 -1
- data/features/{progress_formatter.feature → docs/formatters/progress_formatter.feature} +1 -1
- data/features/docs/formatters/rerun_formatter.feature +135 -0
- data/features/docs/formatters/usage_formatter.feature +102 -0
- data/features/docs/getting_started.feature +27 -0
- data/features/{background.feature → docs/gherkin/background.feature} +149 -91
- data/features/{doc_strings.feature → docs/gherkin/doc_strings.feature} +1 -0
- data/features/docs/gherkin/expand_option_for_outlines.feature +46 -0
- data/features/docs/gherkin/language_from_header.feature +32 -0
- data/features/docs/gherkin/outlines.feature +154 -0
- data/features/docs/gherkin/unicode_table.feature +32 -0
- data/features/docs/gherkin/using_descriptions.feature +88 -0
- data/features/docs/gherkin/using_star_notation.feature +37 -0
- data/features/{iso-8859-1.feature → docs/iso-8859-1.feature} +0 -0
- data/{legacy_features → features/docs}/post_configuration_hook.feature +17 -18
- data/{legacy_features → features/docs}/profiles.feature +30 -36
- data/{legacy_features → features/docs}/rake_task.feature +30 -41
- data/features/{raketask.feature → docs/raketask.feature} +6 -13
- data/features/docs/report_called_undefined_steps.feature +57 -0
- data/{legacy_features → features/docs}/wire_protocol.feature +36 -31
- data/{legacy_features → features/docs}/wire_protocol_erb.feature +5 -6
- data/{legacy_features → features/docs}/wire_protocol_table_diffing.feature +14 -12
- data/{legacy_features → features/docs}/wire_protocol_tags.feature +6 -7
- data/{legacy_features → features/docs}/wire_protocol_timeouts.feature +6 -6
- data/{legacy_features → features/docs}/work_in_progress.feature +52 -54
- data/{legacy_features → features/docs/writing_support_code}/around_hooks.feature +25 -28
- data/features/docs/writing_support_code/before_hook.feature +61 -0
- data/features/docs/writing_support_code/hook_order.feature +61 -0
- data/features/{load_path.feature → docs/writing_support_code/load_path.feature} +3 -0
- data/features/docs/writing_support_code/state.feature +32 -0
- data/features/{tagged_hooks.feature → docs/writing_support_code/tagged_hooks.feature} +11 -13
- data/features/lib/step_definitions/aruba_steps.rb +22 -0
- data/features/lib/step_definitions/cucumber_steps.rb +50 -0
- data/features/{step_definitions → lib/step_definitions}/iso-8859-1_steps.rb +3 -15
- data/features/lib/step_definitions/json_steps.rb +7 -0
- data/features/lib/step_definitions/junit_steps.rb +13 -0
- data/features/lib/step_definitions/language_steps.rb +4 -5
- data/features/lib/step_definitions/profile_steps.rb +15 -0
- data/features/lib/step_definitions/ruby_steps.rb +3 -0
- data/{legacy_features → features/lib}/step_definitions/wire_steps.rb +16 -9
- data/features/lib/support/env.rb +21 -0
- data/{legacy_features → features/lib}/support/fake_wire_server.rb +0 -0
- data/features/{support → lib/support}/feature_factory.rb +1 -1
- data/features/lib/support/normalise_output.rb +33 -0
- data/gem_tasks/cov.rake +5 -0
- data/gem_tasks/cucumber.rake +1 -10
- data/gem_tasks/rspec.rake +0 -2
- data/gem_tasks/yard.rake +4 -1
- data/lib/cucumber.rb +1 -3
- data/lib/cucumber/cli/configuration.rb +30 -25
- data/lib/cucumber/cli/main.rb +13 -25
- data/lib/cucumber/cli/options.rb +15 -57
- data/lib/cucumber/configuration.rb +4 -0
- data/lib/cucumber/constantize.rb +7 -6
- data/lib/cucumber/core_ext/instance_exec.rb +7 -38
- data/lib/cucumber/core_ext/proc.rb +1 -1
- data/lib/cucumber/errors.rb +3 -1
- data/lib/cucumber/file_specs.rb +35 -0
- data/lib/cucumber/formatter/console.rb +32 -21
- data/lib/cucumber/formatter/debug.rb +5 -0
- data/lib/cucumber/formatter/gherkin_formatter_adapter.rb +8 -38
- data/lib/cucumber/formatter/html.rb +29 -21
- data/lib/cucumber/formatter/junit.rb +10 -7
- data/lib/cucumber/formatter/pretty.rb +2 -8
- data/lib/cucumber/formatter/rerun.rb +2 -3
- data/lib/cucumber/formatter/unicode.rb +8 -21
- data/lib/cucumber/formatter/usage.rb +65 -2
- data/lib/cucumber/language_support/language_methods.rb +1 -1
- data/lib/cucumber/mappings.rb +212 -0
- data/lib/cucumber/multiline_argument.rb +115 -0
- data/lib/cucumber/platform.rb +21 -22
- data/lib/cucumber/rake/task.rb +3 -54
- data/lib/cucumber/rb_support/rb_language.rb +2 -5
- data/lib/cucumber/rb_support/rb_world.rb +14 -19
- data/lib/cucumber/rb_support/snippet.rb +60 -19
- data/lib/cucumber/reports/legacy_formatter.rb +1279 -0
- data/lib/cucumber/runtime.rb +176 -26
- data/lib/cucumber/runtime/for_programming_languages.rb +10 -4
- data/lib/cucumber/runtime/gated_receiver.rb +21 -0
- data/lib/cucumber/runtime/support_code.rb +9 -7
- data/lib/cucumber/runtime/tag_limits.rb +15 -0
- data/lib/cucumber/runtime/tag_limits/filter.rb +31 -0
- data/lib/cucumber/runtime/tag_limits/test_case_index.rb +29 -0
- data/lib/cucumber/runtime/tag_limits/verifier.rb +57 -0
- data/lib/cucumber/runtime/user_interface.rb +4 -0
- data/lib/cucumber/step_match.rb +3 -3
- data/lib/cucumber/term/ansicolor.rb +1 -9
- data/lib/cucumber/wire_support/wire_language.rb +23 -9
- data/lib/cucumber/wire_support/wire_packet.rb +1 -1
- data/lib/cucumber/wire_support/wire_protocol/requests.rb +13 -5
- data/lib/cucumber/wire_support/wire_step_definition.rb +1 -8
- data/spec/cucumber/cli/configuration_spec.rb +151 -150
- data/spec/cucumber/cli/main_spec.rb +36 -99
- data/spec/cucumber/cli/options_spec.rb +238 -272
- data/spec/cucumber/cli/profile_loader_spec.rb +9 -8
- data/spec/cucumber/configuration_spec.rb +3 -3
- data/spec/cucumber/constantize_spec.rb +2 -1
- data/spec/cucumber/core_ext/proc_spec.rb +32 -43
- data/spec/cucumber/file_specs_spec.rb +41 -0
- data/spec/cucumber/formatter/ansicolor_spec.rb +11 -10
- data/spec/cucumber/formatter/debug_spec.rb +569 -0
- data/spec/cucumber/formatter/duration_spec.rb +6 -6
- data/spec/cucumber/formatter/html_spec.rb +53 -62
- data/spec/cucumber/formatter/interceptor_spec.rb +38 -31
- data/spec/cucumber/formatter/junit_spec.rb +34 -28
- data/spec/cucumber/formatter/pretty_spec.rb +238 -52
- data/spec/cucumber/formatter/progress_spec.rb +2 -2
- data/spec/cucumber/formatter/spec_helper.rb +23 -17
- data/spec/cucumber/rake/forked_spec.rb +13 -22
- data/spec/cucumber/rb_support/rb_language_spec.rb +76 -67
- data/spec/cucumber/rb_support/rb_step_definition_spec.rb +63 -42
- data/spec/cucumber/rb_support/rb_transform_spec.rb +4 -3
- data/spec/cucumber/rb_support/regexp_argument_matcher_spec.rb +6 -4
- data/spec/cucumber/rb_support/snippet_spec.rb +42 -33
- data/spec/cucumber/reports/legacy_formatter_spec.rb +1750 -0
- data/spec/cucumber/runtime/for_programming_languages_spec.rb +11 -10
- data/spec/cucumber/runtime/gated_receiver_spec.rb +47 -0
- data/spec/cucumber/runtime/results_spec.rb +33 -26
- data/spec/cucumber/runtime/support_code_spec.rb +29 -29
- data/spec/cucumber/runtime/tag_limits/filter_spec.rb +59 -0
- data/spec/cucumber/runtime/tag_limits/test_case_index_spec.rb +38 -0
- data/spec/cucumber/runtime/tag_limits/verifier_spec.rb +57 -0
- data/spec/cucumber/runtime_spec.rb +39 -34
- data/spec/cucumber/step_match_spec.rb +30 -20
- data/spec/cucumber/wire_support/configuration_spec.rb +8 -5
- data/spec/cucumber/wire_support/connection_spec.rb +12 -8
- data/spec/cucumber/wire_support/wire_exception_spec.rb +14 -8
- data/spec/cucumber/wire_support/wire_language_spec.rb +8 -9
- data/spec/cucumber/wire_support/wire_packet_spec.rb +17 -13
- data/spec/cucumber/world/pending_spec.rb +36 -36
- data/spec/simplecov_setup.rb +18 -0
- data/spec/spec_helper.rb +3 -9
- metadata +298 -507
- data/.gitattributes +0 -1
- data/.ruby-version +0 -1
- data/examples/python/README.textile +0 -8
- data/examples/python/Rakefile +0 -4
- data/examples/python/features/fibonacci.feature +0 -19
- data/examples/python/features/step_definitions/fib_steps.py +0 -11
- data/examples/python/lib/fib.py +0 -7
- data/examples/ramaze/README.textile +0 -7
- data/examples/ramaze/app.rb +0 -21
- data/examples/ramaze/features/add.feature +0 -11
- data/examples/ramaze/features/step_definitions/add_steps.rb +0 -15
- data/examples/ramaze/features/support/env.rb +0 -32
- data/examples/ramaze/layout/default.html.erb +0 -8
- data/examples/ramaze/view/index.html.erb +0 -5
- data/examples/ruby2python/README.textile +0 -8
- data/examples/ruby2python/Rakefile +0 -4
- data/examples/ruby2python/features/fibonacci.feature +0 -19
- data/examples/ruby2python/features/step_definitions/fib_steps.rb +0 -7
- data/examples/ruby2python/features/support/env.rb +0 -21
- data/examples/ruby2python/lib/fib.py +0 -7
- data/examples/v8/Rakefile +0 -6
- data/examples/v8/features/fibonacci.feature +0 -43
- data/examples/v8/features/step_definitions/fib_steps.js +0 -49
- data/examples/v8/features/support/env.js +0 -14
- data/examples/v8/lib/fibonacci.js +0 -19
- data/features/.cucumber/stepdefs.json +0 -722
- data/features/assertions.feature +0 -73
- data/features/autoformat_profile_output.feature +0 -23
- data/features/before_hook.feature +0 -43
- data/features/bootstrap.feature +0 -26
- data/features/drb_server_integration.feature +0 -63
- data/features/execute_with_tag_filter.feature +0 -63
- data/features/parsing.feature +0 -18
- data/features/rerun_formatter.feature +0 -99
- data/features/run_specific_scenarios.feature +0 -47
- data/features/stats_formatters.feature +0 -73
- data/features/step_definitions/cucumber-features/cucumber_ruby_mappings.rb +0 -197
- data/features/step_definitions/cucumber_steps.rb +0 -57
- data/features/step_definitions/drb_steps.rb +0 -3
- data/features/support/env.rb +0 -57
- data/fixtures/json/features/background.feature +0 -7
- data/fixtures/json/features/embed.feature +0 -4
- data/fixtures/json/features/one_passing_one_failing.feature +0 -11
- data/fixtures/json/features/step_definitions/steps.rb +0 -32
- data/fixtures/json/features/tables.feature +0 -13
- data/fixtures/junit/features/one_passing_one_failing.feature +0 -8
- data/fixtures/junit/features/pending.feature +0 -7
- data/fixtures/junit/features/scenario_outline.feature +0 -9
- data/fixtures/junit/features/some_subdirectory/one_passing_one_failing.feature +0 -8
- data/fixtures/junit/features/step_definitions/steps.rb +0 -11
- data/fixtures/self_test/README.textile +0 -6
- data/fixtures/self_test/Rakefile +0 -6
- data/fixtures/self_test/features/call_undefined_step_from_step_def.feature +0 -7
- data/fixtures/self_test/features/failing_expectation.feature +0 -4
- data/fixtures/self_test/features/lots_of_undefined.feature +0 -8
- data/fixtures/self_test/features/multiline_name.feature +0 -27
- data/fixtures/self_test/features/outline_sample.feature +0 -15
- data/fixtures/self_test/features/sample.feature +0 -21
- data/fixtures/self_test/features/search_sample.feature +0 -32
- data/fixtures/self_test/features/step_definitions/sample_steps.rb +0 -84
- data/fixtures/self_test/features/support/bubble_256x256.png +0 -0
- data/fixtures/self_test/features/support/env.rb +0 -26
- data/fixtures/self_test/features/tags_sample.feature +0 -17
- data/fixtures/self_test/features/tons_of_cukes.feature +0 -52
- data/fixtures/self_test/features/undefined_multiline_args.feature +0 -12
- data/fixtures/self_test/list-of-features.txt +0 -1
- data/fixtures/steps_library/features/step_definitions/steps_lib1.rb +0 -8
- data/fixtures/steps_library/features/step_definitions/steps_lib2.rb +0 -8
- data/fixtures/tickets/Rakefile +0 -20
- data/fixtures/tickets/features.html +0 -138
- data/fixtures/tickets/features/172.feature +0 -28
- data/fixtures/tickets/features/177/1.feature +0 -28
- data/fixtures/tickets/features/177/2.feature +0 -20
- data/fixtures/tickets/features/177/3.feature +0 -18
- data/fixtures/tickets/features/180.feature +0 -7
- data/fixtures/tickets/features/229/tagged_hooks.feature +0 -8
- data/fixtures/tickets/features/229/tagged_hooks.rb +0 -14
- data/fixtures/tickets/features/236.feature +0 -13
- data/fixtures/tickets/features/241.feature +0 -12
- data/fixtures/tickets/features/246.feature +0 -4
- data/fixtures/tickets/features/248.feature +0 -11
- data/fixtures/tickets/features/270/back.feature +0 -14
- data/fixtures/tickets/features/270/back.steps.rb +0 -14
- data/fixtures/tickets/features/272/hooks.feature +0 -26
- data/fixtures/tickets/features/272/hooks_steps.rb +0 -53
- data/fixtures/tickets/features/279/py_string_indent.feature +0 -25
- data/fixtures/tickets/features/279/py_string_indent.steps.rb +0 -12
- data/fixtures/tickets/features/279/wrong.feature_ +0 -11
- data/fixtures/tickets/features/301/filter_background_tagged_hooks.feature +0 -6
- data/fixtures/tickets/features/301/filter_background_tagged_hooks_steps.rb +0 -12
- data/fixtures/tickets/features/306/only_background.feature +0 -4
- data/fixtures/tickets/features/around_timeout.feature +0 -6
- data/fixtures/tickets/features/gherkin_67.feature +0 -12
- data/fixtures/tickets/features/gherkin_68.feature +0 -4
- data/fixtures/tickets/features/half_manual.feature +0 -11
- data/fixtures/tickets/features/lib/eatting_machine.rb +0 -18
- data/fixtures/tickets/features/lib/pantry.rb +0 -20
- data/fixtures/tickets/features/scenario_outline.feature +0 -95
- data/fixtures/tickets/features/step_definitons/246_steps.rb +0 -3
- data/fixtures/tickets/features/step_definitons/248_steps.rb +0 -15
- data/fixtures/tickets/features/step_definitons/around_timeout_steps.rb +0 -9
- data/fixtures/tickets/features/step_definitons/half_manual_steps.rb +0 -11
- data/fixtures/tickets/features/step_definitons/scenario_outline_steps.rb +0 -42
- data/fixtures/tickets/features/step_definitons/tickets_steps.rb +0 -88
- data/fixtures/tickets/features/table_diffing.feature +0 -13
- data/fixtures/tickets/features/tickets.feature +0 -28
- data/legacy_features/README.md +0 -14
- data/legacy_features/announce.feature +0 -152
- data/legacy_features/bug_371.feature +0 -32
- data/legacy_features/bug_464.feature +0 -16
- data/legacy_features/bug_475.feature +0 -42
- data/legacy_features/bug_585_tab_indentation.feature +0 -22
- data/legacy_features/bug_600.feature +0 -73
- data/legacy_features/cucumber_cli.feature +0 -584
- data/legacy_features/cucumber_cli_outlines.feature +0 -117
- data/legacy_features/default_snippets.feature +0 -43
- data/legacy_features/diffing.feature +0 -25
- data/legacy_features/drb_server_integration.feature +0 -174
- data/legacy_features/exclude_files.feature +0 -20
- data/legacy_features/expand.feature +0 -60
- data/legacy_features/junit_formatter.feature +0 -214
- data/legacy_features/language_from_header.feature +0 -30
- data/legacy_features/multiline_names.feature +0 -44
- data/legacy_features/report_called_undefined_steps.feature +0 -35
- data/legacy_features/rerun_formatter.feature +0 -52
- data/legacy_features/simplest.feature +0 -11
- data/legacy_features/snippet.feature +0 -23
- data/legacy_features/snippets_when_using_star_keyword.feature +0 -38
- data/legacy_features/step_definitions/cucumber_steps.rb +0 -179
- data/legacy_features/step_definitions/extra_steps.rb +0 -2
- data/legacy_features/step_definitions/simplest_steps.rb +0 -3
- data/legacy_features/support/env.rb +0 -161
- data/legacy_features/support/env.rb.simplest +0 -7
- data/legacy_features/table_mapping.feature +0 -34
- data/legacy_features/transform.feature +0 -245
- data/legacy_features/unicode_table.feature +0 -35
- data/lib/README.rdoc +0 -12
- data/lib/cucumber/ast.rb +0 -30
- data/lib/cucumber/ast/background.rb +0 -116
- data/lib/cucumber/ast/comment.rb +0 -31
- data/lib/cucumber/ast/doc_string.rb +0 -61
- data/lib/cucumber/ast/empty_background.rb +0 -33
- data/lib/cucumber/ast/examples.rb +0 -49
- data/lib/cucumber/ast/feature.rb +0 -99
- data/lib/cucumber/ast/features.rb +0 -38
- data/lib/cucumber/ast/has_steps.rb +0 -74
- data/lib/cucumber/ast/location.rb +0 -41
- data/lib/cucumber/ast/multiline_argument.rb +0 -30
- data/lib/cucumber/ast/names.rb +0 -13
- data/lib/cucumber/ast/outline_table.rb +0 -194
- data/lib/cucumber/ast/scenario.rb +0 -103
- data/lib/cucumber/ast/scenario_outline.rb +0 -146
- data/lib/cucumber/ast/step.rb +0 -122
- data/lib/cucumber/ast/step_collection.rb +0 -92
- data/lib/cucumber/ast/step_invocation.rb +0 -196
- data/lib/cucumber/ast/table.rb +0 -738
- data/lib/cucumber/ast/tags.rb +0 -28
- data/lib/cucumber/ast/tree_walker.rb +0 -191
- data/lib/cucumber/ast/visitor.rb +0 -11
- data/lib/cucumber/broadcaster.rb +0 -13
- data/lib/cucumber/cli/drb_client.rb +0 -43
- data/lib/cucumber/feature_file.rb +0 -101
- data/lib/cucumber/formatter/ordered_xml_markup.rb +0 -24
- data/lib/cucumber/js_support/js_dsl.js +0 -57
- data/lib/cucumber/js_support/js_language.rb +0 -185
- data/lib/cucumber/js_support/js_snippets.rb +0 -27
- data/lib/cucumber/parser.rb +0 -2
- data/lib/cucumber/parser/gherkin_builder.rb +0 -284
- data/lib/cucumber/py_support/py_dsl.py +0 -10
- data/lib/cucumber/py_support/py_language.py +0 -10
- data/lib/cucumber/py_support/py_language.rb +0 -80
- data/lib/cucumber/step_mother.rb +0 -10
- data/spec/cucumber/ast/background_spec.rb +0 -122
- data/spec/cucumber/ast/doc_string_spec.rb +0 -40
- data/spec/cucumber/ast/feature_factory.rb +0 -72
- data/spec/cucumber/ast/feature_spec.rb +0 -63
- data/spec/cucumber/ast/features_spec.rb +0 -51
- data/spec/cucumber/ast/outline_table_spec.rb +0 -21
- data/spec/cucumber/ast/scenario_outline_spec.rb +0 -74
- data/spec/cucumber/ast/step_spec.rb +0 -68
- data/spec/cucumber/ast/table_spec.rb +0 -594
- data/spec/cucumber/ast/tree_walker_spec.rb +0 -19
- data/spec/cucumber/broadcaster_spec.rb +0 -15
- data/spec/cucumber/cli/drb_client_spec.rb +0 -76
- data/spec/cucumber/rake/rcov_spec.rb +0 -71
- data/spec/cucumber/wire_support/wire_step_definition_spec.rb +0 -20
@@ -7,25 +7,26 @@ module Cucumber
|
|
7
7
|
subject { Runtime::SupportCode.new(user_interface,{}) }
|
8
8
|
let(:runtime_facade) { Runtime::ForProgrammingLanguages.new(subject, user_interface) }
|
9
9
|
|
10
|
-
it '
|
10
|
+
it 'produces Ast::DocString by #doc_string with default content-type' do
|
11
11
|
str = runtime_facade.doc_string('DOC')
|
12
|
-
|
13
|
-
str.
|
12
|
+
|
13
|
+
expect(str).to be_kind_of(Core::Ast::DocString)
|
14
|
+
expect(str.content_type).to eq('')
|
14
15
|
end
|
15
16
|
|
16
|
-
it '
|
17
|
+
it 'produces Ast::DocString by #doc_string with ruby content-type' do
|
17
18
|
str = runtime_facade.doc_string('DOC','ruby')
|
18
|
-
|
19
|
-
str.
|
19
|
+
|
20
|
+
expect(str).to be_kind_of(Core::Ast::DocString)
|
21
|
+
expect(str.content_type).to eq('ruby')
|
20
22
|
end
|
21
23
|
|
22
|
-
it '
|
23
|
-
runtime_facade.table(%{
|
24
|
+
it 'produces Ast::Table by #table' do
|
25
|
+
expect(runtime_facade.table(%{
|
24
26
|
| account | description | amount |
|
25
27
|
| INT-100 | Taxi | 114 |
|
26
28
|
| CUC-101 | Peeler | 22 |
|
27
|
-
}).
|
29
|
+
})).to be_kind_of(Core::Ast::DataTable)
|
28
30
|
end
|
29
|
-
|
30
31
|
end
|
31
32
|
end
|
@@ -0,0 +1,47 @@
|
|
1
|
+
require "cucumber/runtime/gated_receiver"
|
2
|
+
|
3
|
+
describe Cucumber::Runtime::GatedReceiver do
|
4
|
+
subject(:gated_receiver) { Cucumber::Runtime::GatedReceiver.new(receiver) }
|
5
|
+
|
6
|
+
let(:receiver) { double(:receiver) }
|
7
|
+
let(:test_cases){ [double(:test_case), double(:test_case)] }
|
8
|
+
|
9
|
+
describe "#test_case" do
|
10
|
+
it "does not immediately describe the test case to the receiver" do
|
11
|
+
test_cases.each do |test_case|
|
12
|
+
expect(test_case).to_not receive(:describe_to).with(receiver)
|
13
|
+
end
|
14
|
+
|
15
|
+
test_cases.each do |test_case|
|
16
|
+
gated_receiver.test_case(test_case)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
describe "#done" do
|
22
|
+
before do
|
23
|
+
test_cases.each do |test_case|
|
24
|
+
gated_receiver.test_case(test_case)
|
25
|
+
end
|
26
|
+
|
27
|
+
test_cases.each do |test_case|
|
28
|
+
allow(test_case).to receive(:describe_to).with(receiver)
|
29
|
+
end
|
30
|
+
|
31
|
+
allow(receiver).to receive(:done)
|
32
|
+
end
|
33
|
+
|
34
|
+
it "describes all test cases to the receiver" do
|
35
|
+
test_cases.each do |test_case|
|
36
|
+
expect(test_case).to receive(:describe_to).with(receiver)
|
37
|
+
end
|
38
|
+
|
39
|
+
gated_receiver.done
|
40
|
+
end
|
41
|
+
|
42
|
+
it "calls done on the receiver" do
|
43
|
+
expect(receiver).to receive(:done)
|
44
|
+
gated_receiver.done
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
@@ -3,77 +3,84 @@ require 'spec_helper'
|
|
3
3
|
module Cucumber
|
4
4
|
describe Runtime::Results do
|
5
5
|
|
6
|
-
let(:configuration)
|
6
|
+
let(:configuration) {double 'Configuration', :strict? => false}
|
7
7
|
let(:passed_scenario) {double 'Scenario', :status => :passed}
|
8
8
|
let(:failed_scenario) {double 'Scenario', :status => :failed}
|
9
|
-
let(:passed_step)
|
10
|
-
let(:failed_step)
|
11
|
-
let(:pending_step)
|
12
|
-
let(:undefined_step)
|
9
|
+
let(:passed_step) {double 'Step', :status => :passed}
|
10
|
+
let(:failed_step) {double 'Step', :status => :failed}
|
11
|
+
let(:pending_step) {double 'Step', :status => :pending}
|
12
|
+
let(:undefined_step) {double 'Step', :status => :undefined}
|
13
13
|
|
14
14
|
subject {described_class.new(configuration)}
|
15
15
|
|
16
16
|
describe '#failure?' do
|
17
17
|
context 'feature is not work in progress' do
|
18
18
|
before do
|
19
|
-
configuration.
|
19
|
+
allow(configuration).to receive(:wip?) { false }
|
20
20
|
end
|
21
21
|
|
22
|
-
it '
|
22
|
+
it 'returns true if a scenario failed' do
|
23
23
|
subject.scenario_visited(passed_scenario)
|
24
24
|
subject.scenario_visited(failed_scenario)
|
25
|
-
|
25
|
+
|
26
|
+
expect(subject).to be_failure
|
26
27
|
end
|
27
28
|
|
28
|
-
it '
|
29
|
+
it 'returns true if a step failed' do
|
29
30
|
subject.step_visited(failed_step)
|
30
|
-
|
31
|
+
|
32
|
+
expect(subject).to be_failure
|
31
33
|
end
|
32
34
|
|
33
|
-
it '
|
34
|
-
subject.
|
35
|
+
it 'returns false if there are no scenarios' do
|
36
|
+
expect(subject).not_to be_failure
|
35
37
|
end
|
36
38
|
|
37
|
-
it '
|
39
|
+
it 'returns false if all scenarios passed' do
|
38
40
|
subject.scenario_visited(passed_scenario)
|
39
41
|
subject.scenario_visited(passed_scenario)
|
40
|
-
|
42
|
+
|
43
|
+
expect(subject).not_to be_failure
|
41
44
|
end
|
42
45
|
|
43
46
|
context 'configuration is strict' do
|
44
47
|
before do
|
45
|
-
configuration.
|
48
|
+
allow(configuration).to receive(:strict?) { true }
|
46
49
|
end
|
47
50
|
|
48
|
-
it '
|
51
|
+
it 'returns true if a step is pending' do
|
49
52
|
subject.step_visited(pending_step)
|
50
|
-
|
53
|
+
|
54
|
+
expect(subject).to be_failure
|
51
55
|
end
|
52
56
|
|
53
|
-
it '
|
57
|
+
it 'returns true if a step is undefined' do
|
54
58
|
subject.step_visited(undefined_step)
|
55
|
-
|
59
|
+
|
60
|
+
expect(subject).to be_failure
|
56
61
|
end
|
57
62
|
end
|
58
63
|
end
|
59
64
|
|
60
65
|
context 'feature is work in progress' do
|
61
66
|
before do
|
62
|
-
configuration.
|
67
|
+
allow(configuration).to receive(:wip?) { true }
|
63
68
|
end
|
64
69
|
|
65
|
-
it '
|
70
|
+
it 'returns true if a scenario passed' do
|
66
71
|
subject.scenario_visited(passed_scenario)
|
67
|
-
|
72
|
+
|
73
|
+
expect(subject).to be_failure
|
68
74
|
end
|
69
75
|
|
70
|
-
it '
|
71
|
-
subject.
|
76
|
+
it 'returns false if there are no scenarios' do
|
77
|
+
expect(subject).not_to be_failure
|
72
78
|
end
|
73
79
|
|
74
|
-
it '
|
80
|
+
it 'returns false if all scenarios fail' do
|
75
81
|
subject.scenario_visited(failed_scenario)
|
76
|
-
|
82
|
+
|
83
|
+
expect(subject).not_to be_failure
|
77
84
|
end
|
78
85
|
end
|
79
86
|
end
|
@@ -4,34 +4,35 @@ module Cucumber
|
|
4
4
|
describe Runtime::SupportCode do
|
5
5
|
let(:user_interface) { double('user interface') }
|
6
6
|
subject { Runtime::SupportCode.new(user_interface, options) }
|
7
|
-
let(:options)
|
7
|
+
let(:options) { {} }
|
8
8
|
let(:dsl) do
|
9
9
|
@rb = subject.load_programming_language('rb')
|
10
10
|
Object.new.extend(RbSupport::RbDsl)
|
11
11
|
end
|
12
12
|
|
13
|
-
it "
|
13
|
+
it "formats step names" do
|
14
14
|
dsl.Given(/it (.*) in (.*)/) { |what, month| }
|
15
15
|
dsl.Given(/nope something else/) { |what, month| }
|
16
16
|
|
17
17
|
format = subject.step_match("it snows in april").format_args("[%s]")
|
18
|
-
|
18
|
+
|
19
|
+
expect(format).to eq "it [snows] in [april]"
|
19
20
|
end
|
20
21
|
|
21
|
-
it "
|
22
|
+
it "caches step match results" do
|
22
23
|
dsl.Given(/it (.*) in (.*)/) { |what, month| }
|
23
24
|
|
24
25
|
step_match = subject.step_match("it snows in april")
|
25
26
|
|
26
|
-
@rb.
|
27
|
+
expect(@rb).not_to receive(:step_matches)
|
27
28
|
second_step_match = subject.step_match("it snows in april")
|
28
29
|
|
29
|
-
step_match.
|
30
|
+
expect(step_match).to equal(second_step_match)
|
30
31
|
end
|
31
32
|
|
32
33
|
describe "resolving step defintion matches" do
|
33
34
|
|
34
|
-
it "
|
35
|
+
it "raises Ambiguous error with guess hint when multiple step definitions match" do
|
35
36
|
expected_error = %{Ambiguous match of "Three blind mice":
|
36
37
|
|
37
38
|
spec/cucumber/runtime/support_code_spec.rb:\\d+:in `/Three (.*) mice/'
|
@@ -42,15 +43,15 @@ You can run again with --guess to make Cucumber be more smart about it
|
|
42
43
|
dsl.Given(/Three (.*) mice/) {|disability|}
|
43
44
|
dsl.Given(/Three blind (.*)/) {|animal|}
|
44
45
|
|
45
|
-
|
46
|
+
expect(-> {
|
46
47
|
subject.step_match("Three blind mice")
|
47
|
-
|
48
|
+
}).to raise_error(Ambiguous, /#{expected_error}/)
|
48
49
|
end
|
49
50
|
|
50
51
|
describe "when --guess is used" do
|
51
52
|
let(:options) { {:guess => true} }
|
52
53
|
|
53
|
-
it "
|
54
|
+
it "does not show --guess hint" do
|
54
55
|
expected_error = %{Ambiguous match of "Three cute mice":
|
55
56
|
|
56
57
|
spec/cucumber/runtime/support_code_spec.rb:\\d+:in `/Three (.*) mice/'
|
@@ -60,64 +61,63 @@ spec/cucumber/runtime/support_code_spec.rb:\\d+:in `/Three cute (.*)/'
|
|
60
61
|
dsl.Given(/Three (.*) mice/) {|disability|}
|
61
62
|
dsl.Given(/Three cute (.*)/) {|animal|}
|
62
63
|
|
63
|
-
|
64
|
+
expect(-> {
|
64
65
|
subject.step_match("Three cute mice")
|
65
|
-
|
66
|
+
}).to raise_error(Ambiguous, /#{expected_error}/)
|
66
67
|
end
|
67
68
|
|
68
|
-
it "
|
69
|
+
it "does not raise Ambiguous error when multiple step definitions match" do
|
69
70
|
dsl.Given(/Three (.*) mice/) {|disability|}
|
70
71
|
dsl.Given(/Three (.*)/) {|animal|}
|
71
72
|
|
72
|
-
|
73
|
+
expect(-> {
|
73
74
|
subject.step_match("Three blind mice")
|
74
|
-
|
75
|
+
}).not_to raise_error
|
75
76
|
end
|
76
77
|
|
77
|
-
it "
|
78
|
+
it "does not raise NoMethodError when guessing from multiple step definitions with nil fields" do
|
78
79
|
dsl.Given(/Three (.*) mice( cannot find food)?/) {|disability, is_disastrous|}
|
79
80
|
dsl.Given(/Three (.*)?/) {|animal|}
|
80
81
|
|
81
|
-
|
82
|
+
expect(-> {
|
82
83
|
subject.step_match("Three blind mice")
|
83
|
-
|
84
|
+
}).not_to raise_error
|
84
85
|
end
|
85
86
|
|
86
|
-
it "
|
87
|
+
it "picks right step definition when an equal number of capture groups" do
|
87
88
|
right = dsl.Given(/Three (.*) mice/) {|disability|}
|
88
89
|
wrong = dsl.Given(/Three (.*)/) {|animal|}
|
89
90
|
|
90
|
-
subject.step_match("Three blind mice").step_definition.
|
91
|
+
expect(subject.step_match("Three blind mice").step_definition).to eq right
|
91
92
|
end
|
92
93
|
|
93
|
-
it "
|
94
|
+
it "picks right step definition when an unequal number of capture groups" do
|
94
95
|
right = dsl.Given(/Three (.*) mice ran (.*)/) {|disability|}
|
95
96
|
wrong = dsl.Given(/Three (.*)/) {|animal|}
|
96
97
|
|
97
|
-
subject.step_match("Three blind mice ran far").step_definition.
|
98
|
+
expect(subject.step_match("Three blind mice ran far").step_definition).to eq right
|
98
99
|
end
|
99
100
|
|
100
|
-
it "
|
101
|
+
it "picks most specific step definition when an unequal number of capture groups" do
|
101
102
|
general = dsl.Given(/Three (.*) mice ran (.*)/) {|disability|}
|
102
103
|
specific = dsl.Given(/Three blind mice ran far/) do; end
|
103
104
|
more_specific = dsl.Given(/^Three blind mice ran far$/) do; end
|
104
105
|
|
105
|
-
subject.step_match("Three blind mice ran far").step_definition.
|
106
|
+
expect(subject.step_match("Three blind mice ran far").step_definition).to eq more_specific
|
106
107
|
end
|
107
108
|
end
|
108
109
|
|
109
|
-
it "
|
110
|
-
|
110
|
+
it "raises Undefined error when no step definitions match" do
|
111
|
+
expect(-> {
|
111
112
|
subject.step_match("Three blind mice")
|
112
|
-
|
113
|
+
}).to raise_error(Undefined)
|
113
114
|
end
|
114
115
|
|
115
116
|
# http://railsforum.com/viewtopic.php?pid=93881
|
116
|
-
it "
|
117
|
+
it "does not raise Redundant unless it's really redundant" do
|
117
118
|
dsl.Given(/^(.*) (.*) user named '(.*)'$/) {|a,b,c|}
|
118
119
|
dsl.Given(/^there is no (.*) user named '(.*)'$/) {|a,b|}
|
119
120
|
end
|
120
121
|
end
|
121
|
-
|
122
122
|
end
|
123
123
|
end
|
@@ -0,0 +1,59 @@
|
|
1
|
+
require "cucumber/runtime/tag_limits"
|
2
|
+
|
3
|
+
describe Cucumber::Runtime::TagLimits::Filter do
|
4
|
+
subject(:filter) { Cucumber::Runtime::TagLimits::Filter.new(tag_limits, receiver) }
|
5
|
+
|
6
|
+
let(:tag_limits) { double(:tag_limits) }
|
7
|
+
let(:receiver) { double(:receiver) }
|
8
|
+
|
9
|
+
let(:gated_receiver) { double(:gated_receiver) }
|
10
|
+
let(:test_case_index) { double(:test_case_index) }
|
11
|
+
let(:test_case) { double(:test_case) }
|
12
|
+
|
13
|
+
before do
|
14
|
+
allow(Cucumber::Runtime::GatedReceiver).to receive(:new).with(receiver) { gated_receiver }
|
15
|
+
allow(Cucumber::Runtime::TagLimits::TestCaseIndex).to receive(:new) { test_case_index }
|
16
|
+
end
|
17
|
+
|
18
|
+
describe "#test_case" do
|
19
|
+
before do
|
20
|
+
allow(test_case_index).to receive(:add)
|
21
|
+
allow(gated_receiver).to receive(:test_case)
|
22
|
+
end
|
23
|
+
|
24
|
+
it "indexes the test case" do
|
25
|
+
expect(test_case_index).to receive(:add).with(test_case)
|
26
|
+
filter.test_case(test_case)
|
27
|
+
end
|
28
|
+
|
29
|
+
it "adds the test case to the gated receiver" do
|
30
|
+
expect(gated_receiver).to receive(:test_case).with(test_case)
|
31
|
+
filter.test_case(test_case)
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
describe "#done" do
|
36
|
+
let(:verifier) { double(:verifier) }
|
37
|
+
|
38
|
+
before do
|
39
|
+
allow(Cucumber::Runtime::TagLimits::Verifier).to receive(:new).with(tag_limits) { verifier }
|
40
|
+
allow(gated_receiver).to receive(:done)
|
41
|
+
end
|
42
|
+
|
43
|
+
it "verifies tag limits have not been exceeded" do
|
44
|
+
expect(verifier).to receive(:verify!).with(test_case_index)
|
45
|
+
filter.done
|
46
|
+
end
|
47
|
+
|
48
|
+
context "the verifier verifies successfully" do
|
49
|
+
before do
|
50
|
+
allow(verifier).to receive(:verify!).with(test_case_index)
|
51
|
+
end
|
52
|
+
|
53
|
+
it "calls done on the receiver gate" do
|
54
|
+
expect(gated_receiver).to receive(:done)
|
55
|
+
filter.done
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
require "cucumber/runtime/tag_limits"
|
2
|
+
|
3
|
+
describe Cucumber::Runtime::TagLimits::TestCaseIndex do
|
4
|
+
subject(:index) { Cucumber::Runtime::TagLimits::TestCaseIndex.new }
|
5
|
+
|
6
|
+
let(:test_cases) do
|
7
|
+
[
|
8
|
+
double(:test_case, tags: [tag_one], location: a_location_of_tag_one),
|
9
|
+
double(:test_case, tags: [tag_one, tag_two], location: a_location_of_tag_one_and_tag_two)
|
10
|
+
]
|
11
|
+
end
|
12
|
+
|
13
|
+
let(:tag_one) { double(:tag_one, name: "@one") }
|
14
|
+
let(:tag_two) { double(:tag_two, name: "@two") }
|
15
|
+
|
16
|
+
let(:a_location_of_tag_one) { double(:a_location_of_tag_one) }
|
17
|
+
let(:a_location_of_tag_one_and_tag_two) { double(:a_location_of_tag_one_and_tag_two) }
|
18
|
+
|
19
|
+
before do
|
20
|
+
test_cases.map do |test_case|
|
21
|
+
index.add(test_case)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
describe "#count_by_tag_name" do
|
26
|
+
it "returns the number of test cases with the tag" do
|
27
|
+
expect(index.count_by_tag_name("@one")).to eq(2)
|
28
|
+
expect(index.count_by_tag_name("@two")).to eq(1)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
describe "#locations_by_tag_name" do
|
33
|
+
it "returns the locations of test cases with the tag" do
|
34
|
+
expect(index.locations_of_tag_name("@one")).to eq([a_location_of_tag_one, a_location_of_tag_one_and_tag_two])
|
35
|
+
expect(index.locations_of_tag_name("@two")).to eq([a_location_of_tag_one_and_tag_two])
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -0,0 +1,57 @@
|
|
1
|
+
require "cucumber/runtime/tag_limits"
|
2
|
+
|
3
|
+
describe Cucumber::Runtime::TagLimits::Verifier do
|
4
|
+
describe "#verify!" do
|
5
|
+
subject(:verifier) { Cucumber::Runtime::TagLimits::Verifier.new(tag_limits) }
|
6
|
+
let(:test_case_index) { double(:test_case_index) }
|
7
|
+
|
8
|
+
context "the tag counts exceed the tag limits" do
|
9
|
+
let(:tag_limits) do
|
10
|
+
{
|
11
|
+
"@exceed_me" => 1
|
12
|
+
}
|
13
|
+
end
|
14
|
+
|
15
|
+
let(:locations) do
|
16
|
+
[
|
17
|
+
double(:location, to_s: "path/to/some.feature:3"),
|
18
|
+
double(:location, to_s: "path/to/some/other.feature:8"),
|
19
|
+
]
|
20
|
+
end
|
21
|
+
|
22
|
+
before do
|
23
|
+
allow(test_case_index).to receive(:count_by_tag_name).with("@exceed_me") { 2 }
|
24
|
+
allow(test_case_index).to receive(:locations_of_tag_name).with("@exceed_me") { locations }
|
25
|
+
end
|
26
|
+
|
27
|
+
it "raises a TagLimitExceeded error with the locations of the tags" do
|
28
|
+
expect {
|
29
|
+
verifier.verify!(test_case_index)
|
30
|
+
}.to raise_error(
|
31
|
+
Cucumber::Runtime::TagLimits::TagLimitExceededError,
|
32
|
+
"@exceed_me occurred 2 times, but the limit was set to 1\n" +
|
33
|
+
" path/to/some.feature:3\n" +
|
34
|
+
" path/to/some/other.feature:8"
|
35
|
+
)
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
context "the tag counts do not exceed the tag limits" do
|
40
|
+
let(:tag_limits) do
|
41
|
+
{
|
42
|
+
"@dont_exceed_me" => 2
|
43
|
+
}
|
44
|
+
end
|
45
|
+
|
46
|
+
before do
|
47
|
+
allow(test_case_index).to receive(:count_by_tag_name).with("@dont_exceed_me") { 1 }
|
48
|
+
end
|
49
|
+
|
50
|
+
it "does not raise an error" do
|
51
|
+
expect {
|
52
|
+
verifier.verify!(test_case_index)
|
53
|
+
}.to_not raise_error
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|