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
@@ -1,45 +1,50 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
module Cucumber
|
4
|
-
describe Runtime do
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
describe "#features_paths" do
|
9
|
-
let(:options) { {:paths => ['foo/bar/baz.feature', 'foo/bar/features/baz.feature', 'other_features'] } }
|
10
|
-
it "returns the value from configuration.paths" do
|
11
|
-
subject.features_paths.should == options[:paths]
|
12
|
-
end
|
13
|
-
end
|
4
|
+
describe Runtime do
|
5
|
+
subject { Runtime.new(options) }
|
6
|
+
let(:options) { {} }
|
14
7
|
|
15
|
-
|
16
|
-
|
17
|
-
let(:results) { double(Runtime::Results).as_null_object }
|
18
|
-
let(:new_configuration) { double('New configuration')}
|
19
|
-
before(:each) do
|
20
|
-
Runtime::SupportCode.stub(:new => support_code)
|
21
|
-
Runtime::Results.stub(:new => results)
|
22
|
-
end
|
8
|
+
describe "#features_paths" do
|
9
|
+
let(:options) { {:paths => ['foo/bar/baz.feature', 'foo/bar/features/baz.feature', 'other_features'] } }
|
23
10
|
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
subject.configure(new_configuration)
|
11
|
+
it "returns the value from configuration.paths" do
|
12
|
+
expect(subject.features_paths).to eq options[:paths]
|
13
|
+
end
|
28
14
|
end
|
29
15
|
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
16
|
+
describe "#configure" do
|
17
|
+
let(:support_code) { double(Runtime::SupportCode).as_null_object }
|
18
|
+
let(:results) { double(Runtime::Results).as_null_object }
|
19
|
+
let(:new_configuration) { double('New configuration')}
|
20
|
+
|
21
|
+
before(:each) do
|
22
|
+
allow(Runtime::SupportCode).to receive(:new) { support_code }
|
23
|
+
allow(Runtime::Results).to receive(:new) { results }
|
24
|
+
end
|
25
|
+
|
26
|
+
it "tells the support_code and results about the new configuration" do
|
27
|
+
expect(support_code).to receive(:configure).with(new_configuration)
|
28
|
+
expect(results).to receive(:configure).with(new_configuration)
|
29
|
+
|
30
|
+
subject.configure(new_configuration)
|
31
|
+
end
|
38
32
|
|
39
|
-
|
40
|
-
|
33
|
+
it "replaces the existing configuration" do
|
34
|
+
# not really sure how to test this. Maybe we should just expose
|
35
|
+
# Runtime#configuration with an attr_reader?
|
36
|
+
some_new_paths = ['foo/bar', 'baz']
|
37
|
+
|
38
|
+
allow(new_configuration).to receive(:paths) { some_new_paths }
|
39
|
+
|
40
|
+
subject.configure(new_configuration)
|
41
|
+
|
42
|
+
expect(subject.features_paths).to eq some_new_paths
|
43
|
+
end
|
44
|
+
|
45
|
+
it '#doc_string' do
|
46
|
+
expect(subject.doc_string('Text')).to eq 'Text'
|
47
|
+
end
|
41
48
|
end
|
42
49
|
end
|
43
|
-
|
44
|
-
end
|
45
50
|
end
|
@@ -5,7 +5,7 @@ require 'cucumber/rb_support/rb_language'
|
|
5
5
|
|
6
6
|
module Cucumber
|
7
7
|
describe StepMatch do
|
8
|
-
WORD =
|
8
|
+
WORD = '[[:word:]]'
|
9
9
|
|
10
10
|
before do
|
11
11
|
@rb_language = RbSupport::RbLanguage.new(nil)
|
@@ -20,50 +20,60 @@ module Cucumber
|
|
20
20
|
StepMatch.new(stepdef, name, nil, stepdef.arguments_from(name))
|
21
21
|
end
|
22
22
|
|
23
|
-
it "
|
23
|
+
it "formats one group when we use Unicode" do
|
24
24
|
m = step_match(/I (#{WORD}+) ok/, "I æøåÆØÅæøåÆØÅæøåÆØÅæøåÆØÅ ok")
|
25
|
-
|
25
|
+
|
26
|
+
expect(m.format_args("<span>%s</span>")).to eq "I <span>æøåÆØÅæøåÆØÅæøåÆØÅæøåÆØÅ</span> ok"
|
26
27
|
end
|
27
28
|
|
28
|
-
it "
|
29
|
+
it "formats several groups when we use Unicode" do
|
29
30
|
m = step_match(/I (#{WORD}+) (#{WORD}+) (#{WORD}+) this (#{WORD}+)/, "I ate æøåÆØÅæøåÆØÅæøåÆØÅæøåÆØÅ egg this morning")
|
30
|
-
|
31
|
+
|
32
|
+
expect(m.format_args("<span>%s</span>")).to eq "I <span>ate</span> <span>æøåÆØÅæøåÆØÅæøåÆØÅæøåÆØÅ</span> <span>egg</span> this <span>morning</span>"
|
31
33
|
end
|
32
34
|
|
33
|
-
it "
|
34
|
-
"Jæ vø ålsker døtte løndet".
|
35
|
+
it "deals with Unicode both inside and outside arguments" do
|
36
|
+
expect("Jæ vø ålsker døtte løndet").to match /Jæ (.+) ålsker (.+) løndet/
|
37
|
+
|
35
38
|
m = step_match(/Jæ (#{WORD}+) ålsker (#{WORD}+) løndet/, "Jæ vø ålsker døtte løndet")
|
36
|
-
|
39
|
+
|
40
|
+
expect(m.format_args("<span>%s</span>")).to eq "Jæ <span>vø</span> ålsker <span>døtte</span> løndet"
|
37
41
|
end
|
38
42
|
|
39
|
-
it "
|
43
|
+
it "formats groups with format string" do
|
40
44
|
m = step_match(/I (#{WORD}+) (\d+) (#{WORD}+) this (#{WORD}+)/, "I ate 1 egg this morning")
|
41
|
-
|
45
|
+
|
46
|
+
expect(m.format_args("<span>%s</span>")).to eq "I <span>ate</span> <span>1</span> <span>egg</span> this <span>morning</span>"
|
42
47
|
end
|
43
48
|
|
44
|
-
it "
|
49
|
+
it "formats groups with format string when there are dupes" do
|
45
50
|
m = step_match(/I (#{WORD}+) (\d+) (#{WORD}+) this (#{WORD}+)/, "I bob 1 bo this bobs")
|
46
|
-
|
51
|
+
|
52
|
+
expect(m.format_args("<span>%s</span>")).to eq "I <span>bob</span> <span>1</span> <span>bo</span> this <span>bobs</span>"
|
47
53
|
end
|
48
54
|
|
49
|
-
it "
|
55
|
+
it "formats groups with block" do
|
50
56
|
m = step_match(/I (#{WORD}+) (\d+) (#{WORD}+) this (#{WORD}+)/, "I ate 1 egg this morning")
|
51
|
-
|
57
|
+
|
58
|
+
expect(m.format_args(&lambda{|m| "<span>#{m}</span>"})).to eq "I <span>ate</span> <span>1</span> <span>egg</span> this <span>morning</span>"
|
52
59
|
end
|
53
60
|
|
54
|
-
it "
|
61
|
+
it "formats groups with proc object" do
|
55
62
|
m = step_match(/I (#{WORD}+) (\d+) (#{WORD}+) this (#{WORD}+)/, "I ate 1 egg this morning")
|
56
|
-
|
63
|
+
|
64
|
+
expect(m.format_args(lambda{|m| "<span>#{m}</span>"})).to eq "I <span>ate</span> <span>1</span> <span>egg</span> this <span>morning</span>"
|
57
65
|
end
|
58
66
|
|
59
|
-
it "
|
67
|
+
it "formats groups even when first group is optional and not matched" do
|
60
68
|
m = step_match(/should( not)? be flashed '([^']*?)'$/, "I should be flashed 'Login failed.'")
|
61
|
-
|
69
|
+
|
70
|
+
expect(m.format_args("<span>%s</span>")).to eq "I should be flashed '<span>Login failed.</span>'"
|
62
71
|
end
|
63
72
|
|
64
|
-
it "
|
73
|
+
it "formats embedded groups" do
|
65
74
|
m = step_match(/running( (\d+) times)? (\d+) meters/, "running 5 times 10 meters")
|
66
|
-
|
75
|
+
|
76
|
+
expect(m.format_args("<span>%s</span>")).to eq "running<span> 5 times</span> <span>10</span> meters"
|
67
77
|
end
|
68
78
|
end
|
69
79
|
end
|
@@ -18,8 +18,9 @@ module Cucumber
|
|
18
18
|
host: localhost
|
19
19
|
port: 54321
|
20
20
|
}
|
21
|
-
|
22
|
-
config.
|
21
|
+
|
22
|
+
expect(config.host).to eq 'localhost'
|
23
|
+
expect(config.port).to eq 54321
|
23
24
|
end
|
24
25
|
|
25
26
|
it "reads the timeout for a specific message" do
|
@@ -29,7 +30,8 @@ module Cucumber
|
|
29
30
|
timeout:
|
30
31
|
invoke: 99
|
31
32
|
}
|
32
|
-
|
33
|
+
|
34
|
+
expect(config.timeout('invoke')).to eq 99
|
33
35
|
end
|
34
36
|
|
35
37
|
it "reads the timeout for a connect message" do
|
@@ -39,7 +41,8 @@ module Cucumber
|
|
39
41
|
timeout:
|
40
42
|
connect: 99
|
41
43
|
}
|
42
|
-
|
44
|
+
|
45
|
+
expect(config.timeout('connect')).to eq 99
|
43
46
|
end
|
44
47
|
|
45
48
|
describe "a wire file with no timeouts specified" do
|
@@ -52,7 +55,7 @@ module Cucumber
|
|
52
55
|
|
53
56
|
%w(invoke begin_scenario end_scenario).each do |message|
|
54
57
|
it "sets the default timeout for '#{message}' to 120 seconds" do
|
55
|
-
config.timeout(message).
|
58
|
+
expect(config.timeout(message)).to eq 120
|
56
59
|
end
|
57
60
|
end
|
58
61
|
end
|
@@ -37,23 +37,27 @@ module Cucumber
|
|
37
37
|
end
|
38
38
|
|
39
39
|
it "re-raises a timeout error" do
|
40
|
-
Timeout.
|
41
|
-
|
40
|
+
allow(Timeout).to receive(:timeout).and_raise(Timeout::Error.new(''))
|
41
|
+
expect(-> { @connection.call_remote(nil, :foo, []) }).to raise_error(Timeout::Error)
|
42
42
|
end
|
43
43
|
|
44
44
|
it "ignores timeout errors when configured to do so" do
|
45
45
|
@config.custom_timeout[:foo] = :never
|
46
|
-
|
46
|
+
|
47
|
+
allow(@socket).to receive(:gets) { @response }
|
48
|
+
|
47
49
|
handler = double(:handle_response => :response)
|
48
|
-
|
50
|
+
|
51
|
+
expect(@connection.call_remote(handler, :foo, [])).to eq :response
|
49
52
|
end
|
50
53
|
|
51
54
|
it "raises an exception on remote connection closed" do
|
52
55
|
@config.custom_timeout[:foo] = :never
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
56
|
+
|
57
|
+
allow(@socket).to receive(:gets)
|
58
|
+
expect(-> {
|
59
|
+
@connection.call_remote(nil, :foo, [])
|
60
|
+
}).to raise_error(WireException, 'Remote Socket with localhost:3902 closed.')
|
57
61
|
end
|
58
62
|
end
|
59
63
|
end
|
@@ -7,15 +7,18 @@ module Cucumber
|
|
7
7
|
before(:each) do
|
8
8
|
@config = Configuration.new('host' => 'localhost', 'port' => 54321)
|
9
9
|
end
|
10
|
+
|
10
11
|
def exception
|
11
12
|
WireException.new(@data, @config)
|
12
13
|
end
|
14
|
+
|
13
15
|
describe "with just a message" do
|
14
16
|
before(:each) do
|
15
17
|
@data = {'message' => 'foo'}
|
16
18
|
end
|
17
|
-
|
18
|
-
|
19
|
+
|
20
|
+
it "#to_s as expecteds" do
|
21
|
+
expect(exception.to_s).to eq "foo"
|
19
22
|
end
|
20
23
|
end
|
21
24
|
|
@@ -23,11 +26,13 @@ module Cucumber
|
|
23
26
|
before(:each) do
|
24
27
|
@data = {'message' => 'foo', 'exception' => 'Bar'}
|
25
28
|
end
|
26
|
-
|
27
|
-
|
29
|
+
|
30
|
+
it "#to_s as expecteds" do
|
31
|
+
expect(exception.to_s).to eq "foo"
|
28
32
|
end
|
29
|
-
|
30
|
-
|
33
|
+
|
34
|
+
it "#class.to_s returns the name of the exception" do
|
35
|
+
expect(exception.class.to_s).to eq 'Bar from localhost:54321'
|
31
36
|
end
|
32
37
|
end
|
33
38
|
|
@@ -35,8 +40,9 @@ module Cucumber
|
|
35
40
|
before(:each) do
|
36
41
|
@data = {'message' => 'foo', 'backtrace' => ['foo', 'bar', 'baz']}
|
37
42
|
end
|
38
|
-
|
39
|
-
|
43
|
+
|
44
|
+
it "#backrace returns the custom backtrace" do
|
45
|
+
expect(exception.backtrace).to eq ['foo', 'bar', 'baz']
|
40
46
|
end
|
41
47
|
end
|
42
48
|
end
|
@@ -5,7 +5,7 @@ module Cucumber
|
|
5
5
|
module WireSupport
|
6
6
|
describe WireLanguage do
|
7
7
|
def stub_wire_file!(filename, config)
|
8
|
-
Configuration.
|
8
|
+
allow(Configuration).to receive(:from_file).with(filename) { config }
|
9
9
|
end
|
10
10
|
|
11
11
|
describe "#load_code_file" do
|
@@ -14,16 +14,15 @@ module Cucumber
|
|
14
14
|
end
|
15
15
|
|
16
16
|
it "creates a RemoteSteps object" do
|
17
|
-
Connection.
|
18
|
-
|
17
|
+
expect(Connection).to receive(:new).with(:config)
|
18
|
+
|
19
|
+
WireLanguage.new.load_code_file('foo.wire')
|
19
20
|
end
|
20
21
|
end
|
21
22
|
|
22
23
|
describe "#step_matches" do
|
23
24
|
def stub_remote_steps!(config, attributes)
|
24
|
-
Connection.
|
25
|
-
with(config).
|
26
|
-
and_return( double('remote_steps', attributes) )
|
25
|
+
expect(Connection).to receive(:new).with(config) { double('remote_steps', attributes) }
|
27
26
|
end
|
28
27
|
|
29
28
|
before(:each) do
|
@@ -31,15 +30,15 @@ module Cucumber
|
|
31
30
|
stub_wire_file! 'two.wire', :config_two
|
32
31
|
end
|
33
32
|
|
34
|
-
it "
|
33
|
+
it "returns the matches from each of the RemoteSteps" do
|
35
34
|
stub_remote_steps! :config_one, :step_matches => [:a, :b]
|
36
35
|
stub_remote_steps! :config_two, :step_matches => [:c]
|
37
36
|
|
38
|
-
wire_language = WireLanguage.new
|
37
|
+
wire_language = WireLanguage.new
|
39
38
|
wire_language.load_code_file('one.wire')
|
40
39
|
wire_language.load_code_file('two.wire')
|
41
40
|
|
42
|
-
wire_language.step_matches('','').
|
41
|
+
expect(wire_language.step_matches('','')).to eq [:a, :b, :c]
|
43
42
|
end
|
44
43
|
end
|
45
44
|
end
|
@@ -4,35 +4,39 @@ require 'cucumber/wire_support/wire_language'
|
|
4
4
|
module Cucumber
|
5
5
|
module WireSupport
|
6
6
|
describe WirePacket do
|
7
|
-
|
8
7
|
describe "#to_json" do
|
9
|
-
it "
|
8
|
+
it "converts params to a JSON hash" do
|
10
9
|
packet = WirePacket.new('test_message', :foo => :bar)
|
11
|
-
|
10
|
+
|
11
|
+
expect(packet.to_json).to eq "[\"test_message\",{\"foo\":\"bar\"}]"
|
12
12
|
end
|
13
13
|
|
14
|
-
it "
|
14
|
+
it "does not pass blank params" do
|
15
15
|
packet = WirePacket.new('test_message')
|
16
|
-
|
16
|
+
|
17
|
+
expect(packet.to_json).to eq "[\"test_message\"]"
|
17
18
|
end
|
18
19
|
end
|
19
20
|
|
20
21
|
describe ".parse" do
|
21
|
-
it "
|
22
|
+
it "understands a raw packet containing null parameters" do
|
22
23
|
packet = WirePacket.parse("[\"test_message\",null]")
|
23
|
-
|
24
|
-
packet.
|
24
|
+
|
25
|
+
expect(packet.message).to eq 'test_message'
|
26
|
+
expect(packet.params).to be_nil
|
25
27
|
end
|
26
28
|
|
27
|
-
it "
|
29
|
+
it "understands a raw packet containing no parameters" do
|
28
30
|
packet = WirePacket.parse("[\"test_message\"]")
|
29
|
-
|
30
|
-
packet.
|
31
|
+
|
32
|
+
expect(packet.message).to eq 'test_message'
|
33
|
+
expect(packet.params).to be_nil
|
31
34
|
end
|
32
35
|
|
33
|
-
it "
|
36
|
+
it "understands a raw packet containging parameters data" do
|
34
37
|
packet = WirePacket.parse("[\"test_message\",{\"foo\":\"bar\"}]")
|
35
|
-
|
38
|
+
|
39
|
+
expect(packet.params['foo']).to eq 'bar'
|
36
40
|
end
|
37
41
|
end
|
38
42
|
end
|
@@ -2,45 +2,45 @@ require 'spec_helper'
|
|
2
2
|
require 'cucumber/rb_support/rb_language'
|
3
3
|
|
4
4
|
module Cucumber
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
end
|
12
|
-
|
13
|
-
it 'should raise a Pending if no block is supplied' do
|
14
|
-
lambda {
|
15
|
-
@world.pending "TODO"
|
16
|
-
}.should raise_error(Cucumber::Pending, /TODO/)
|
17
|
-
end
|
5
|
+
describe 'Pending' do
|
6
|
+
before(:each) do
|
7
|
+
l = RbSupport::RbLanguage.new(Runtime.new)
|
8
|
+
l.begin_rb_scenario(double('scenario').as_null_object)
|
9
|
+
@world = l.current_world
|
10
|
+
end
|
18
11
|
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
}.should raise_error(Cucumber::Pending, /TODO/)
|
25
|
-
end
|
12
|
+
it 'raises a Pending if no block is supplied' do
|
13
|
+
expect(-> {
|
14
|
+
@world.pending "TODO"
|
15
|
+
}).to raise_error(Cucumber::Pending, /TODO/)
|
16
|
+
end
|
26
17
|
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
}.should raise_error(Cucumber::Pending, /TODO/)
|
35
|
-
end
|
18
|
+
it 'raises a Pending if a supplied block fails as expected' do
|
19
|
+
expect(-> {
|
20
|
+
@world.pending "TODO" do
|
21
|
+
raise "oops"
|
22
|
+
end
|
23
|
+
}).to raise_error(Cucumber::Pending, /TODO/)
|
24
|
+
end
|
36
25
|
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
26
|
+
it 'raises a Pending if a supplied block fails as expected with a double' do
|
27
|
+
expect do
|
28
|
+
@world.pending "TODO" do
|
29
|
+
m = double('thing')
|
30
|
+
expect(m).to receive(:foo)
|
31
|
+
RSpec::Mocks.verify
|
32
|
+
end
|
33
|
+
end.to raise_error(Cucumber::Pending, /TODO/)
|
34
|
+
# The teardown is needed so that the message expectation does not bubble up.
|
35
|
+
RSpec::Mocks.teardown
|
36
|
+
end
|
44
37
|
|
38
|
+
it 'raises a Pending if a supplied block starts working' do
|
39
|
+
expect(-> {
|
40
|
+
@world.pending "TODO" do
|
41
|
+
# success!
|
42
|
+
end
|
43
|
+
}).to raise_error(Cucumber::Pending, /TODO/)
|
45
44
|
end
|
45
|
+
end
|
46
46
|
end
|