cucumber 2.0.0.rc.4 → 4.0.0.rc.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/{History.md → CHANGELOG.md} +734 -283
- data/CONTRIBUTING.md +26 -23
- data/LICENSE +1 -1
- data/README.md +25 -8
- data/bin/cucumber +3 -3
- data/lib/autotest/cucumber.rb +2 -0
- data/lib/autotest/cucumber_mixin.rb +45 -48
- data/lib/autotest/cucumber_rails.rb +2 -0
- data/lib/autotest/cucumber_rails_rspec.rb +2 -0
- data/lib/autotest/cucumber_rails_rspec2.rb +2 -0
- data/lib/autotest/cucumber_rspec.rb +2 -0
- data/lib/autotest/cucumber_rspec2.rb +2 -0
- data/lib/autotest/discover.rb +4 -2
- data/lib/cucumber.rb +3 -9
- data/lib/cucumber/cli/configuration.rb +23 -106
- data/lib/cucumber/cli/main.rb +45 -25
- data/lib/cucumber/cli/options.rb +411 -223
- data/lib/cucumber/cli/profile_loader.rb +64 -38
- data/lib/cucumber/cli/rerun_file.rb +31 -0
- data/lib/cucumber/configuration.rb +240 -8
- data/lib/cucumber/constantize.rb +9 -10
- data/lib/cucumber/core_ext/string.rb +3 -1
- data/lib/cucumber/deprecate.rb +30 -0
- data/lib/cucumber/encoding.rb +7 -0
- data/lib/cucumber/errors.rb +17 -8
- data/lib/cucumber/events.rb +40 -0
- data/lib/cucumber/events/gherkin_source_parsed.rb +11 -0
- data/lib/cucumber/events/gherkin_source_read.rb +14 -0
- data/lib/cucumber/events/step_activated.rb +26 -0
- data/lib/cucumber/events/step_definition_registered.rb +20 -0
- data/lib/cucumber/events/test_case_finished.rb +14 -0
- data/lib/cucumber/events/test_case_started.rb +11 -0
- data/lib/cucumber/events/test_run_finished.rb +11 -0
- data/lib/cucumber/events/test_run_started.rb +14 -0
- data/lib/cucumber/events/test_step_finished.rb +14 -0
- data/lib/cucumber/events/test_step_started.rb +11 -0
- data/lib/cucumber/file_specs.rb +8 -6
- data/lib/cucumber/filters.rb +4 -0
- data/lib/cucumber/filters/activate_steps.rb +48 -7
- data/lib/cucumber/filters/apply_after_hooks.rb +2 -0
- data/lib/cucumber/filters/apply_after_step_hooks.rb +2 -0
- data/lib/cucumber/filters/apply_around_hooks.rb +2 -0
- data/lib/cucumber/filters/apply_before_hooks.rb +2 -0
- data/lib/cucumber/filters/broadcast_test_run_started_event.rb +28 -0
- data/lib/cucumber/filters/gated_receiver.rb +2 -2
- data/lib/cucumber/filters/prepare_world.rb +13 -11
- data/lib/cucumber/filters/quit.rb +4 -7
- data/lib/cucumber/filters/randomizer.rb +10 -5
- data/lib/cucumber/filters/retry.rb +32 -0
- data/lib/cucumber/filters/tag_limits.rb +6 -5
- data/lib/cucumber/filters/tag_limits/test_case_index.rb +2 -2
- data/lib/cucumber/filters/tag_limits/verifier.rb +5 -7
- data/lib/cucumber/formatter/ansicolor.rb +39 -45
- data/lib/cucumber/formatter/ast_lookup.rb +165 -0
- data/lib/cucumber/formatter/backtrace_filter.rb +54 -0
- data/lib/cucumber/formatter/console.rb +93 -115
- data/lib/cucumber/formatter/console_counts.rb +39 -0
- data/lib/cucumber/formatter/console_issues.rb +61 -0
- data/lib/cucumber/formatter/duration.rb +3 -1
- data/lib/cucumber/formatter/duration_extractor.rb +31 -0
- data/lib/cucumber/formatter/fail_fast.rb +23 -0
- data/lib/cucumber/formatter/fanout.rb +4 -3
- data/lib/cucumber/formatter/ignore_missing_messages.rb +3 -4
- data/lib/cucumber/formatter/interceptor.rb +13 -14
- data/lib/cucumber/formatter/io.rb +10 -5
- data/lib/cucumber/formatter/json.rb +310 -8
- data/lib/cucumber/formatter/junit.rb +175 -110
- data/lib/cucumber/formatter/pretty.rb +359 -154
- data/lib/cucumber/formatter/progress.rb +78 -72
- data/lib/cucumber/formatter/rerun.rb +34 -17
- data/lib/cucumber/formatter/stepdefs.rb +3 -2
- data/lib/cucumber/formatter/steps.rb +7 -7
- data/lib/cucumber/formatter/summary.rb +50 -20
- data/lib/cucumber/formatter/unicode.rb +17 -18
- data/lib/cucumber/formatter/usage.rb +61 -54
- data/lib/cucumber/gherkin/data_table_parser.rb +44 -0
- data/lib/cucumber/gherkin/formatter/ansi_escapes.rb +97 -0
- data/lib/cucumber/gherkin/formatter/escaping.rb +19 -0
- data/lib/cucumber/gherkin/i18n.rb +17 -0
- data/lib/cucumber/gherkin/steps_parser.rb +42 -0
- data/lib/cucumber/{rb_support/rb_dsl.rb → glue/dsl.rb} +47 -26
- data/lib/cucumber/glue/hook.rb +51 -0
- data/lib/cucumber/glue/invoke_in_world.rb +65 -0
- data/lib/cucumber/glue/proto_world.rb +219 -0
- data/lib/cucumber/glue/registry_and_more.rb +192 -0
- data/lib/cucumber/glue/snippet.rb +205 -0
- data/lib/cucumber/glue/step_definition.rb +142 -0
- data/lib/cucumber/glue/world_factory.rb +21 -0
- data/lib/cucumber/hooks.rb +34 -21
- data/lib/cucumber/load_path.rb +2 -0
- data/lib/cucumber/multiline_argument.rb +10 -24
- data/lib/cucumber/multiline_argument/data_table.rb +157 -253
- data/lib/cucumber/multiline_argument/data_table/diff_matrices.rb +154 -0
- data/lib/cucumber/multiline_argument/doc_string.rb +3 -2
- data/lib/cucumber/platform.rb +7 -10
- data/lib/cucumber/project_initializer.rb +44 -0
- data/lib/cucumber/rake/task.rb +37 -29
- data/lib/cucumber/rspec/disable_option_parser.rb +11 -8
- data/lib/cucumber/rspec/doubles.rb +3 -1
- data/lib/cucumber/running_test_case.rb +60 -0
- data/lib/cucumber/runtime.rb +84 -78
- data/lib/cucumber/runtime/after_hooks.rb +10 -7
- data/lib/cucumber/runtime/before_hooks.rb +12 -6
- data/lib/cucumber/runtime/for_programming_languages.rb +14 -44
- data/lib/cucumber/runtime/step_hooks.rb +8 -4
- data/lib/cucumber/runtime/support_code.rb +55 -159
- data/lib/cucumber/runtime/user_interface.rb +15 -24
- data/lib/cucumber/step_definition_light.rb +10 -6
- data/lib/cucumber/step_definitions.rb +6 -4
- data/lib/cucumber/step_match.rb +58 -38
- data/lib/cucumber/step_match_search.rb +67 -0
- data/lib/cucumber/term/ansicolor.rb +40 -39
- data/lib/cucumber/unit.rb +2 -0
- data/lib/cucumber/version +1 -0
- data/{spec → lib}/simplecov_setup.rb +3 -1
- metadata +260 -607
- data/.coveralls.yml +0 -1
- data/.rspec +0 -1
- data/.ruby-gemset +0 -1
- data/.travis.yml +0 -18
- data/.yardopts +0 -1
- data/Gemfile +0 -11
- data/Rakefile +0 -22
- data/bin/cuke +0 -60
- data/cucumber.gemspec +0 -50
- data/cucumber.yml +0 -20
- data/examples/i18n/README.textile +0 -3
- data/examples/i18n/Rakefile +0 -33
- data/examples/i18n/ar/Rakefile +0 -6
- data/examples/i18n/ar/features/addition.feature +0 -17
- data/examples/i18n/ar/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/ar/lib/calculator.rb +0 -11
- data/examples/i18n/bg/Rakefile +0 -6
- data/examples/i18n/bg/features/addition.feature +0 -12
- data/examples/i18n/bg/features/consecutive_calculations.feature +0 -19
- data/examples/i18n/bg/features/division.feature +0 -17
- data/examples/i18n/bg/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/bg/features/support/env.rb +0 -5
- data/examples/i18n/bg/features/support/world.rb +0 -8
- data/examples/i18n/bg/lib/calculator.rb +0 -24
- data/examples/i18n/ca/Rakefile +0 -6
- data/examples/i18n/ca/features/step_definitions/calculator_steps.rb +0 -21
- data/examples/i18n/ca/features/suma.feature +0 -17
- data/examples/i18n/ca/lib/calculadora.rb +0 -16
- data/examples/i18n/cs/Rakefile +0 -6
- data/examples/i18n/cs/features/addition.feature +0 -17
- data/examples/i18n/cs/features/division.feature +0 -11
- data/examples/i18n/cs/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/cs/lib/calculator.rb +0 -14
- data/examples/i18n/da/Rakefile +0 -6
- data/examples/i18n/da/features/sammenlaegning.feature +0 -18
- data/examples/i18n/da/features/step_definitions/lommeregner_steps.rb +0 -24
- data/examples/i18n/da/lib/lommeregner.rb +0 -11
- data/examples/i18n/de/Rakefile +0 -6
- data/examples/i18n/de/features/addition.feature +0 -17
- data/examples/i18n/de/features/division.feature +0 -10
- data/examples/i18n/de/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/de/lib/calculator.rb +0 -14
- data/examples/i18n/el/Rakefile +0 -6
- data/examples/i18n/el/features/addition.feature +0 -17
- data/examples/i18n/el/features/division.feature +0 -10
- data/examples/i18n/el/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/el/lib/calculator.rb +0 -14
- data/examples/i18n/en-lol/Rakefile +0 -4
- data/examples/i18n/en-lol/features/step_definitions/cucumbrz_steps.rb +0 -16
- data/examples/i18n/en-lol/features/stuffing.feature +0 -8
- data/examples/i18n/en-lol/features/support/env.rb +0 -7
- data/examples/i18n/en-lol/lib/basket.rb +0 -12
- data/examples/i18n/en-lol/lib/belly.rb +0 -11
- data/examples/i18n/en/Rakefile +0 -6
- data/examples/i18n/en/features/addition.feature +0 -17
- data/examples/i18n/en/features/division.feature +0 -10
- data/examples/i18n/en/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/en/lib/calculator.rb +0 -14
- data/examples/i18n/eo/Rakefile +0 -6
- data/examples/i18n/eo/features/adicio.feature +0 -17
- data/examples/i18n/eo/features/divido.feature +0 -10
- data/examples/i18n/eo/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/eo/lib/calculator.rb +0 -14
- data/examples/i18n/es/Rakefile +0 -6
- data/examples/i18n/es/features/adicion.feature +0 -17
- data/examples/i18n/es/features/step_definitions/calculador_steps.rb +0 -21
- data/examples/i18n/es/lib/calculador.rb +0 -14
- data/examples/i18n/et/Rakefile +0 -6
- data/examples/i18n/et/features/jagamine.feature +0 -10
- data/examples/i18n/et/features/liitmine.feature +0 -17
- data/examples/i18n/et/features/step_definitions/kalkulaator_steps.rb +0 -24
- data/examples/i18n/et/lib/kalkulaator.rb +0 -14
- data/examples/i18n/fi/Rakefile +0 -6
- data/examples/i18n/fi/features/jakolasku.feature +0 -10
- data/examples/i18n/fi/features/step_definitions/laskin_steps.rb +0 -24
- data/examples/i18n/fi/features/yhteenlasku.feature +0 -17
- data/examples/i18n/fi/lib/laskin.rb +0 -14
- data/examples/i18n/fr/Rakefile +0 -8
- data/examples/i18n/fr/features/addition.feature +0 -18
- data/examples/i18n/fr/features/addition2.feature +0 -17
- data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +0 -32
- data/examples/i18n/fr/features/support/env.rb +0 -5
- data/examples/i18n/fr/lib/calculatrice.rb +0 -10
- data/examples/i18n/he/Rakefile +0 -6
- data/examples/i18n/he/features/addition.feature +0 -17
- data/examples/i18n/he/features/division.feature +0 -10
- data/examples/i18n/he/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/he/lib/calculator.rb +0 -15
- data/examples/i18n/hi/Rakefile +0 -6
- data/examples/i18n/hi/features/addition.feature +0 -16
- data/examples/i18n/hi/features/division.feature +0 -10
- data/examples/i18n/hi/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/hi/lib/calculator.rb +0 -15
- data/examples/i18n/hu/Rakefile +0 -6
- data/examples/i18n/hu/features/osszeadas.feature +0 -17
- data/examples/i18n/hu/features/osztas.feature +0 -10
- data/examples/i18n/hu/features/step_definitions/calculator_steps.rb +0 -25
- data/examples/i18n/hu/lib/calculator.rb +0 -14
- data/examples/i18n/id/Rakefile +0 -6
- data/examples/i18n/id/features/addition.feature +0 -17
- data/examples/i18n/id/features/division.feature +0 -10
- data/examples/i18n/id/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/id/lib/calculator.rb +0 -14
- data/examples/i18n/it/Rakefile +0 -6
- data/examples/i18n/it/features/somma.feature +0 -11
- data/examples/i18n/it/features/step_definitions/calcolatrice_steps.rb +0 -24
- data/examples/i18n/it/lib/calcolatrice.rb +0 -11
- data/examples/i18n/ja/Rakefile +0 -6
- data/examples/i18n/ja/features/addition.feature +0 -17
- data/examples/i18n/ja/features/division.feature +0 -10
- data/examples/i18n/ja/features/step_definitions/calculator_steps.rb +0 -19
- data/examples/i18n/ja/features/support/env.rb +0 -5
- data/examples/i18n/ja/lib/calculator.rb +0 -14
- data/examples/i18n/ko/Rakefile +0 -6
- data/examples/i18n/ko/features/addition.feature +0 -17
- data/examples/i18n/ko/features/division.feature +0 -11
- data/examples/i18n/ko/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/ko/lib/calculator.rb +0 -14
- data/examples/i18n/lt/Rakefile +0 -6
- data/examples/i18n/lt/features/addition.feature +0 -17
- data/examples/i18n/lt/features/division.feature +0 -10
- data/examples/i18n/lt/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/lt/lib/calculator.rb +0 -14
- data/examples/i18n/lv/Rakefile +0 -6
- data/examples/i18n/lv/features/addition.feature +0 -17
- data/examples/i18n/lv/features/division.feature +0 -10
- data/examples/i18n/lv/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/lv/lib/calculator.rb +0 -14
- data/examples/i18n/no/Rakefile +0 -6
- data/examples/i18n/no/features/step_definitions/kalkulator_steps.rb +0 -17
- data/examples/i18n/no/features/summering.feature +0 -19
- data/examples/i18n/no/features/support/env.rb +0 -6
- data/examples/i18n/no/lib/kalkulator.rb +0 -11
- data/examples/i18n/pl/Rakefile +0 -6
- data/examples/i18n/pl/features/addition.feature +0 -17
- data/examples/i18n/pl/features/division.feature +0 -10
- data/examples/i18n/pl/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/pl/features/support/env.rb +0 -5
- data/examples/i18n/pl/lib/calculator.rb +0 -14
- data/examples/i18n/pt/Rakefile +0 -6
- data/examples/i18n/pt/features/adicao.feature +0 -11
- data/examples/i18n/pt/features/step_definitions/calculadora_steps.rb +0 -20
- data/examples/i18n/pt/features/support/env.rb +0 -5
- data/examples/i18n/pt/lib/calculadora.rb +0 -10
- data/examples/i18n/ro/Rakefile +0 -6
- data/examples/i18n/ro/features/adunare.feature +0 -12
- data/examples/i18n/ro/features/step_definitions/calculator_steps.rb +0 -21
- data/examples/i18n/ro/lib/calculator.rb +0 -11
- data/examples/i18n/ru/Rakefile +0 -6
- data/examples/i18n/ru/features/addition.feature +0 -11
- data/examples/i18n/ru/features/consecutive_calculations.feature +0 -17
- data/examples/i18n/ru/features/division.feature +0 -16
- data/examples/i18n/ru/features/step_definitions/calculator_steps.rb +0 -19
- data/examples/i18n/ru/features/support/env.rb +0 -5
- data/examples/i18n/ru/features/support/world.rb +0 -8
- data/examples/i18n/ru/lib/calculator.rb +0 -24
- data/examples/i18n/sk/Rakefile +0 -6
- data/examples/i18n/sk/features/addition.feature +0 -17
- data/examples/i18n/sk/features/division.feature +0 -10
- data/examples/i18n/sk/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/sk/lib/calculator.rb +0 -14
- data/examples/i18n/sr-Cyrl/Rakefile +0 -6
- data/examples/i18n/sr-Cyrl/features/sabiranje.feature +0 -18
- data/examples/i18n/sr-Cyrl/features/step_definitions/calculator_steps.rb +0 -20
- data/examples/i18n/sr-Cyrl/features/support/env.rb +0 -5
- data/examples/i18n/sr-Cyrl/lib/calculator.rb +0 -12
- data/examples/i18n/sr-Latn/Rakefile +0 -6
- data/examples/i18n/sr-Latn/features/sabiranje.feature +0 -18
- data/examples/i18n/sr-Latn/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/sr-Latn/lib/calculator.rb +0 -12
- data/examples/i18n/sv/Rakefile +0 -6
- data/examples/i18n/sv/features/step_definitions/kalkulator_steps.rb +0 -24
- data/examples/i18n/sv/features/summering.feature +0 -18
- data/examples/i18n/sv/lib/kalkulator.rb +0 -11
- data/examples/i18n/tr/Rakefile +0 -6
- data/examples/i18n/tr/features/bolme.feature +0 -10
- data/examples/i18n/tr/features/step_definitions/hesap_makinesi_adimlari.rb +0 -24
- data/examples/i18n/tr/features/toplama.feature +0 -18
- data/examples/i18n/tr/lib/hesap_makinesi.rb +0 -15
- data/examples/i18n/uk/Rakefile +0 -6
- data/examples/i18n/uk/features/addition.feature +0 -11
- data/examples/i18n/uk/features/consecutive_calculations.feature +0 -17
- data/examples/i18n/uk/features/division.feature +0 -16
- data/examples/i18n/uk/features/step_definitions/calculator_steps.rb +0 -19
- data/examples/i18n/uk/features/support/env.rb +0 -5
- data/examples/i18n/uk/features/support/world.rb +0 -8
- data/examples/i18n/uk/lib/calculator.rb +0 -24
- data/examples/i18n/uz/Rakefile +0 -6
- data/examples/i18n/uz/features/addition.feature +0 -10
- data/examples/i18n/uz/features/consecutive_calculations.feature +0 -17
- data/examples/i18n/uz/features/division.feature +0 -17
- data/examples/i18n/uz/features/step_definitions/calculator_steps.rb +0 -19
- data/examples/i18n/uz/features/support/env.rb +0 -5
- data/examples/i18n/uz/features/support/world.rb +0 -8
- data/examples/i18n/uz/lib/calculator.rb +0 -24
- data/examples/i18n/zh-CN/Rakefile +0 -4
- data/examples/i18n/zh-CN/features/addition.feature +0 -18
- data/examples/i18n/zh-CN/features/step_definitions/calculator_steps.rb +0 -26
- data/examples/i18n/zh-CN/lib/calculator.rb +0 -10
- data/examples/i18n/zh-TW/Rakefile +0 -4
- data/examples/i18n/zh-TW/features/addition.feature +0 -17
- data/examples/i18n/zh-TW/features/division.feature +0 -11
- data/examples/i18n/zh-TW/features/step_definitions/calculator_steps.rb +0 -24
- data/examples/i18n/zh-TW/lib/calculator.rb +0 -14
- data/examples/rspec_doubles/Rakefile +0 -4
- data/examples/rspec_doubles/features/mocking.feature +0 -9
- data/examples/rspec_doubles/features/step_definitions/calvin_steps.rb +0 -19
- data/examples/rspec_doubles/features/support/env.rb +0 -12
- data/examples/sinatra/README.textile +0 -13
- data/examples/sinatra/Rakefile +0 -6
- data/examples/sinatra/app.rb +0 -14
- data/examples/sinatra/features/add.feature +0 -11
- data/examples/sinatra/features/step_definitions/add_steps.rb +0 -15
- data/examples/sinatra/features/support/env.rb +0 -10
- data/examples/sinatra/views/add.erb +0 -7
- data/examples/sinatra/views/layout.erb +0 -8
- data/examples/tcl/README.textile +0 -11
- data/examples/tcl/Rakefile +0 -6
- data/examples/tcl/features/fibonnacci.feature +0 -17
- data/examples/tcl/features/step_definitions/fib_steps.rb +0 -7
- data/examples/tcl/features/support/env.rb +0 -6
- data/examples/tcl/src/fib.tcl +0 -3
- data/examples/test_unit/Gemfile +0 -4
- data/examples/test_unit/Rakefile +0 -6
- data/examples/test_unit/features/step_definitions/test_unit_steps.rb +0 -20
- data/examples/test_unit/features/test_unit.feature +0 -9
- data/examples/watir/README.textile +0 -16
- data/examples/watir/Rakefile +0 -12
- data/examples/watir/cucumber.yml +0 -1
- data/examples/watir/features/search.feature +0 -12
- data/examples/watir/features/step_definitions/search_steps.rb +0 -26
- data/examples/watir/features/support/env.rb +0 -35
- data/examples/watir/features/support/screenshots.rb +0 -47
- data/features/docs/api/list_step_defs_as_json.feature +0 -50
- data/features/docs/api/run_cli_main_with_existing_runtime.feature +0 -29
- data/features/docs/cli/backtraces.feature +0 -36
- data/features/docs/cli/dry_run.feature +0 -25
- data/features/docs/cli/exclude_files.feature +0 -19
- data/features/docs/cli/execute_with_tag_filter.feature +0 -117
- data/features/docs/cli/randomize.feature +0 -46
- data/features/docs/cli/require.feature +0 -27
- data/features/docs/cli/run_scenarios_matching_name.feature +0 -104
- data/features/docs/cli/run_specific_scenarios.feature +0 -130
- data/features/docs/cli/showing_differences.feature +0 -43
- data/features/docs/cli/specifying_multiple_formatters.feature +0 -44
- data/features/docs/cli/strict_mode.feature +0 -41
- data/features/docs/defining_steps/nested_steps.feature +0 -129
- data/features/docs/defining_steps/nested_steps_i18n.feature +0 -34
- data/features/docs/defining_steps/nested_steps_with_second_arg.feature +0 -73
- data/features/docs/defining_steps/one_line_step_definitions.feature +0 -65
- data/features/docs/defining_steps/printing_messages.feature +0 -148
- data/features/docs/defining_steps/skip_scenario.feature +0 -62
- data/features/docs/defining_steps/snippets.feature +0 -56
- data/features/docs/defining_steps/table_diffing.feature +0 -50
- data/features/docs/defining_steps/transforms.feature +0 -63
- data/features/docs/exception_in_after_hook.feature +0 -126
- data/features/docs/exception_in_after_step_hook.feature +0 -102
- data/features/docs/exception_in_before_hook.feature +0 -96
- data/features/docs/extending_cucumber/custom_filter.feature +0 -29
- data/features/docs/extending_cucumber/custom_formatter.feature +0 -94
- data/features/docs/formatters/debug_formatter.feature +0 -47
- data/features/docs/formatters/formatter_step_file_colon_line.feature +0 -44
- data/features/docs/formatters/html_formatter.feature +0 -90
- data/features/docs/formatters/json_formatter.feature +0 -696
- data/features/docs/formatters/junit_formatter.feature +0 -276
- data/features/docs/formatters/pretty_formatter.feature +0 -73
- data/features/docs/formatters/progress_formatter.feature +0 -31
- data/features/docs/formatters/rerun_formatter.feature +0 -136
- data/features/docs/formatters/usage_formatter.feature +0 -102
- data/features/docs/getting_started.feature +0 -27
- data/features/docs/gherkin/background.feature +0 -559
- data/features/docs/gherkin/doc_strings.feature +0 -74
- data/features/docs/gherkin/expand_option_for_outlines.feature +0 -46
- data/features/docs/gherkin/language_from_header.feature +0 -32
- data/features/docs/gherkin/language_help.feature +0 -37
- data/features/docs/gherkin/outlines.feature +0 -158
- data/features/docs/gherkin/unicode_table.feature +0 -32
- data/features/docs/gherkin/using_descriptions.feature +0 -88
- data/features/docs/gherkin/using_star_notation.feature +0 -37
- data/features/docs/iso-8859-1.feature +0 -6
- data/features/docs/post_configuration_hook.feature +0 -49
- data/features/docs/profiles.feature +0 -120
- data/features/docs/rake_task.feature +0 -141
- data/features/docs/raketask.feature +0 -44
- data/features/docs/report_called_undefined_steps.feature +0 -57
- data/features/docs/wire_protocol.feature +0 -337
- data/features/docs/wire_protocol_erb.feature +0 -56
- data/features/docs/wire_protocol_table_diffing.feature +0 -125
- data/features/docs/wire_protocol_tags.feature +0 -86
- data/features/docs/wire_protocol_timeouts.feature +0 -63
- data/features/docs/work_in_progress.feature +0 -154
- data/features/docs/writing_support_code/after_hooks.feature +0 -56
- data/features/docs/writing_support_code/around_hooks.feature +0 -229
- data/features/docs/writing_support_code/before_hook.feature +0 -61
- data/features/docs/writing_support_code/hook_order.feature +0 -61
- data/features/docs/writing_support_code/load_path.feature +0 -17
- data/features/docs/writing_support_code/state.feature +0 -32
- data/features/docs/writing_support_code/tagged_hooks.feature +0 -57
- data/features/lib/step_definitions/aruba_steps.rb +0 -22
- data/features/lib/step_definitions/cucumber_steps.rb +0 -50
- data/features/lib/step_definitions/iso-8859-1_steps.rb +0 -12
- data/features/lib/step_definitions/json_steps.rb +0 -7
- data/features/lib/step_definitions/junit_steps.rb +0 -13
- data/features/lib/step_definitions/language_steps.rb +0 -8
- data/features/lib/step_definitions/profile_steps.rb +0 -15
- data/features/lib/step_definitions/ruby_steps.rb +0 -3
- data/features/lib/step_definitions/wire_steps.rb +0 -41
- data/features/lib/support/env.rb +0 -21
- data/features/lib/support/fake_wire_server.rb +0 -77
- data/features/lib/support/feature_factory.rb +0 -67
- data/features/lib/support/normalise_output.rb +0 -33
- data/gem_tasks/contributors.rake +0 -15
- data/gem_tasks/cov.rake +0 -5
- data/gem_tasks/cucumber.rake +0 -25
- data/gem_tasks/downloads.rb +0 -7
- data/gem_tasks/environment.rake +0 -7
- data/gem_tasks/examples.rake +0 -11
- data/gem_tasks/fix_cr_lf.rake +0 -10
- data/gem_tasks/flog.rake +0 -4
- data/gem_tasks/rspec.rake +0 -6
- data/gem_tasks/sass.rake +0 -4
- data/gem_tasks/stats +0 -16
- data/gem_tasks/versions.txt +0 -74
- data/lib/cucumber/ast.rb +0 -13
- data/lib/cucumber/ast/facade.rb +0 -117
- data/lib/cucumber/core_ext/instance_exec.rb +0 -70
- data/lib/cucumber/core_ext/proc.rb +0 -36
- data/lib/cucumber/formatter/cucumber.css +0 -285
- data/lib/cucumber/formatter/cucumber.sass +0 -247
- data/lib/cucumber/formatter/debug.rb +0 -35
- data/lib/cucumber/formatter/gherkin_formatter_adapter.rb +0 -201
- data/lib/cucumber/formatter/gpretty.rb +0 -24
- data/lib/cucumber/formatter/html.rb +0 -674
- data/lib/cucumber/formatter/jquery-min.js +0 -154
- data/lib/cucumber/formatter/json_pretty.rb +0 -10
- data/lib/cucumber/formatter/legacy_api/adapter.rb +0 -1024
- data/lib/cucumber/formatter/legacy_api/ast.rb +0 -376
- data/lib/cucumber/formatter/legacy_api/results.rb +0 -51
- data/lib/cucumber/formatter/legacy_api/runtime_facade.rb +0 -30
- data/lib/cucumber/language_support.rb +0 -30
- data/lib/cucumber/language_support/language_methods.rb +0 -71
- data/lib/cucumber/rb_support/rb_hook.rb +0 -18
- data/lib/cucumber/rb_support/rb_language.rb +0 -160
- data/lib/cucumber/rb_support/rb_step_definition.rb +0 -122
- data/lib/cucumber/rb_support/rb_transform.rb +0 -59
- data/lib/cucumber/rb_support/rb_world.rb +0 -142
- data/lib/cucumber/rb_support/regexp_argument_matcher.rb +0 -21
- data/lib/cucumber/rb_support/snippet.rb +0 -149
- data/lib/cucumber/wire_support/configuration.rb +0 -38
- data/lib/cucumber/wire_support/connection.rb +0 -61
- data/lib/cucumber/wire_support/request_handler.rb +0 -32
- data/lib/cucumber/wire_support/wire_exception.rb +0 -32
- data/lib/cucumber/wire_support/wire_language.rb +0 -68
- data/lib/cucumber/wire_support/wire_packet.rb +0 -34
- data/lib/cucumber/wire_support/wire_protocol.rb +0 -43
- data/lib/cucumber/wire_support/wire_protocol/requests.rb +0 -133
- data/lib/cucumber/wire_support/wire_step_definition.rb +0 -19
- data/spec/cucumber/cli/configuration_spec.rb +0 -503
- data/spec/cucumber/cli/main_spec.rb +0 -105
- data/spec/cucumber/cli/options_spec.rb +0 -335
- data/spec/cucumber/cli/profile_loader_spec.rb +0 -46
- data/spec/cucumber/configuration_spec.rb +0 -23
- data/spec/cucumber/constantize_spec.rb +0 -19
- data/spec/cucumber/core_ext/proc_spec.rb +0 -69
- data/spec/cucumber/file_specs_spec.rb +0 -60
- data/spec/cucumber/filters/activate_steps_spec.rb +0 -57
- data/spec/cucumber/filters/gated_receiver_spec.rb +0 -47
- data/spec/cucumber/filters/tag_limits/test_case_index_spec.rb +0 -38
- data/spec/cucumber/filters/tag_limits/verifier_spec.rb +0 -57
- data/spec/cucumber/filters/tag_limits_spec.rb +0 -59
- data/spec/cucumber/formatter/ansicolor_spec.rb +0 -32
- data/spec/cucumber/formatter/debug_spec.rb +0 -64
- data/spec/cucumber/formatter/duration_spec.rb +0 -22
- data/spec/cucumber/formatter/html_spec.rb +0 -459
- data/spec/cucumber/formatter/interceptor_spec.rb +0 -136
- data/spec/cucumber/formatter/junit_spec.rb +0 -196
- data/spec/cucumber/formatter/legacy_api/adapter_spec.rb +0 -2002
- data/spec/cucumber/formatter/pretty_spec.rb +0 -810
- data/spec/cucumber/formatter/progress_spec.rb +0 -85
- data/spec/cucumber/formatter/rerun_spec.rb +0 -107
- data/spec/cucumber/formatter/spec_helper.rb +0 -67
- data/spec/cucumber/hooks_spec.rb +0 -30
- data/spec/cucumber/multiline_argument/data_table_spec.rb +0 -514
- data/spec/cucumber/rake/forked_spec.rb +0 -53
- data/spec/cucumber/rb_support/rb_language_spec.rb +0 -279
- data/spec/cucumber/rb_support/rb_step_definition_spec.rb +0 -152
- data/spec/cucumber/rb_support/rb_transform_spec.rb +0 -46
- data/spec/cucumber/rb_support/regexp_argument_matcher_spec.rb +0 -22
- data/spec/cucumber/rb_support/snippet_spec.rb +0 -137
- data/spec/cucumber/runtime/for_programming_languages_spec.rb +0 -36
- data/spec/cucumber/runtime/support_code_spec.rb +0 -123
- data/spec/cucumber/runtime_spec.rb +0 -46
- data/spec/cucumber/sell_cucumbers.feature +0 -19
- data/spec/cucumber/step_match_spec.rb +0 -79
- data/spec/cucumber/wire_support/configuration_spec.rb +0 -64
- data/spec/cucumber/wire_support/connection_spec.rb +0 -64
- data/spec/cucumber/wire_support/wire_exception_spec.rb +0 -50
- data/spec/cucumber/wire_support/wire_language_spec.rb +0 -46
- data/spec/cucumber/wire_support/wire_packet_spec.rb +0 -44
- data/spec/cucumber/world/pending_spec.rb +0 -46
- data/spec/spec_helper.rb +0 -32
@@ -0,0 +1,54 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'cucumber/platform'
|
4
|
+
|
5
|
+
module Cucumber
|
6
|
+
module Formatter
|
7
|
+
@backtrace_filters = %w[
|
8
|
+
/vendor/rails
|
9
|
+
lib/cucumber
|
10
|
+
bin/cucumber:
|
11
|
+
lib/rspec
|
12
|
+
gems/
|
13
|
+
site_ruby/
|
14
|
+
minitest
|
15
|
+
test/unit
|
16
|
+
.gem/ruby
|
17
|
+
bin/bundle
|
18
|
+
]
|
19
|
+
|
20
|
+
@backtrace_filters << RbConfig::CONFIG['rubyarchdir'] if RbConfig::CONFIG['rubyarchdir']
|
21
|
+
@backtrace_filters << RbConfig::CONFIG['rubylibdir'] if RbConfig::CONFIG['rubylibdir']
|
22
|
+
|
23
|
+
@backtrace_filters << 'org/jruby/' if ::Cucumber::JRUBY
|
24
|
+
|
25
|
+
BACKTRACE_FILTER_PATTERNS = Regexp.new(@backtrace_filters.join('|'))
|
26
|
+
|
27
|
+
class BacktraceFilter
|
28
|
+
def initialize(exception)
|
29
|
+
@exception = exception
|
30
|
+
end
|
31
|
+
|
32
|
+
def exception
|
33
|
+
return @exception if ::Cucumber.use_full_backtrace
|
34
|
+
|
35
|
+
pwd_pattern = /#{::Regexp.escape(::Dir.pwd)}\//m # rubocop:disable Style/RegexpLiteral
|
36
|
+
backtrace = @exception.backtrace.map { |line| line.gsub(pwd_pattern, './') }
|
37
|
+
|
38
|
+
filtered = (backtrace || []).reject do |line|
|
39
|
+
line =~ BACKTRACE_FILTER_PATTERNS
|
40
|
+
end
|
41
|
+
|
42
|
+
if ::ENV['CUCUMBER_TRUNCATE_OUTPUT']
|
43
|
+
# Strip off file locations
|
44
|
+
filtered = filtered.map do |line|
|
45
|
+
line =~ /(.*):in `/ ? Regexp.last_match(1) : line
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
@exception.set_backtrace(filtered)
|
50
|
+
@exception
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
@@ -1,10 +1,11 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'cucumber/formatter/ansicolor'
|
2
4
|
require 'cucumber/formatter/duration'
|
3
|
-
require 'cucumber/
|
5
|
+
require 'cucumber/gherkin/i18n'
|
4
6
|
|
5
7
|
module Cucumber
|
6
8
|
module Formatter
|
7
|
-
|
8
9
|
# This module contains helper methods that are used by formatters that
|
9
10
|
# print output to the terminal.
|
10
11
|
#
|
@@ -28,15 +29,14 @@ module Cucumber
|
|
28
29
|
module Console
|
29
30
|
extend ANSIColor
|
30
31
|
include Duration
|
31
|
-
include Summary
|
32
32
|
|
33
33
|
def format_step(keyword, step_match, status, source_indent)
|
34
34
|
comment = if source_indent
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
35
|
+
c = ('# ' + step_match.location.to_s).indent(source_indent)
|
36
|
+
format_string(c, :comment)
|
37
|
+
else
|
38
|
+
''
|
39
|
+
end
|
40
40
|
|
41
41
|
format = format_for(status, :param)
|
42
42
|
line = keyword + step_match.format_args(format) + comment
|
@@ -46,7 +46,7 @@ module Cucumber
|
|
46
46
|
def format_string(o, status)
|
47
47
|
fmt = format_for(status)
|
48
48
|
o.to_s.split("\n").map do |line|
|
49
|
-
if Proc
|
49
|
+
if Proc == fmt.class
|
50
50
|
fmt.call(line)
|
51
51
|
else
|
52
52
|
fmt % line
|
@@ -54,101 +54,81 @@ module Cucumber
|
|
54
54
|
end.join("\n")
|
55
55
|
end
|
56
56
|
|
57
|
-
def
|
58
|
-
|
57
|
+
def print_elements(elements, status, kind)
|
58
|
+
return if elements.empty?
|
59
|
+
|
60
|
+
element_messages = element_messages(elements, status)
|
61
|
+
print_element_messages(element_messages, status, kind)
|
59
62
|
end
|
60
63
|
|
61
|
-
def
|
62
|
-
if
|
64
|
+
def print_element_messages(element_messages, status, kind)
|
65
|
+
if element_messages.any?
|
63
66
|
@io.puts(format_string("(::) #{status} #{kind} (::)", status))
|
64
67
|
@io.puts
|
65
68
|
@io.flush
|
66
69
|
end
|
67
70
|
|
68
|
-
|
69
|
-
|
70
|
-
print_exception(element.exception, status, 0)
|
71
|
-
else
|
72
|
-
@io.puts(format_string(element.backtrace_line, status))
|
73
|
-
end
|
71
|
+
element_messages.each do |message|
|
72
|
+
@io.puts(format_string(message, status))
|
74
73
|
@io.puts
|
75
74
|
@io.flush
|
76
75
|
end
|
77
76
|
end
|
78
77
|
|
79
|
-
def
|
80
|
-
|
81
|
-
|
82
|
-
|
78
|
+
def print_statistics(duration, config, counts, issues)
|
79
|
+
if issues.any?
|
80
|
+
@io.puts issues.to_s
|
81
|
+
@io.puts
|
83
82
|
end
|
84
83
|
|
85
|
-
@io.puts
|
86
|
-
@io.puts
|
84
|
+
@io.puts counts.to_s
|
85
|
+
@io.puts(format_duration(duration)) if duration && config.duration?
|
87
86
|
|
88
|
-
|
89
|
-
|
90
|
-
if runtime.configuration.randomize?
|
87
|
+
if config.randomize?
|
91
88
|
@io.puts
|
92
|
-
@io.puts "Randomized with seed #{
|
89
|
+
@io.puts "Randomized with seed #{config.seed}"
|
93
90
|
end
|
94
91
|
|
95
92
|
@io.flush
|
96
93
|
end
|
97
94
|
|
98
|
-
def
|
99
|
-
|
100
|
-
|
101
|
-
example_table_class = Core::Ast::ExamplesTable
|
102
|
-
|
103
|
-
runtime.scenarios(:failed).select do |s|
|
104
|
-
[scenario_class, example_table_class].include?(s.class)
|
105
|
-
end.map do |s|
|
106
|
-
s.is_a?(example_table_class)? s.scenario_outline : s
|
107
|
-
end
|
95
|
+
def print_exception(e, status, indent)
|
96
|
+
string = exception_message_string(e, indent)
|
97
|
+
@io.puts(format_string(string, status))
|
108
98
|
end
|
109
99
|
|
110
|
-
def
|
111
|
-
|
112
|
-
|
113
|
-
profiles_string = custom_profiles.empty? ? '' : (custom_profiles.map{|profile| "-p #{profile}" }).join(' ') + ' '
|
114
|
-
source = given_source ? format_string(" # " + failure.name, :comment) : ''
|
115
|
-
@io.puts format_string("cucumber #{profiles_string}" + failure.location, :failed) + source
|
116
|
-
end
|
117
|
-
@io.puts
|
118
|
-
end
|
100
|
+
def exception_message_string(e, indent)
|
101
|
+
message = "#{e.message} (#{e.class})".dup.force_encoding('UTF-8')
|
102
|
+
message = linebreaks(message, ENV['CUCUMBER_TRUNCATE_OUTPUT'].to_i)
|
119
103
|
|
120
|
-
|
121
|
-
message = "#{e.message} (#{e.class})"
|
122
|
-
if ENV['CUCUMBER_TRUNCATE_OUTPUT']
|
123
|
-
message = linebreaks(message, ENV['CUCUMBER_TRUNCATE_OUTPUT'].to_i)
|
124
|
-
end
|
125
|
-
|
126
|
-
string = "#{message}\n#{e.backtrace.join("\n")}".indent(indent)
|
127
|
-
@io.puts(format_string(string, status))
|
104
|
+
"#{message}\n#{e.backtrace.join("\n")}".indent(indent)
|
128
105
|
end
|
129
106
|
|
130
107
|
# http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-talk/10655
|
131
|
-
def linebreaks(
|
132
|
-
|
108
|
+
def linebreaks(msg, max)
|
109
|
+
return msg unless max && max > 0
|
110
|
+
msg.gsub(/.{1,#{max}}(?:\s|\Z)/) { ($& + 5.chr).gsub(/\n\005/, "\n").gsub(/\005/, "\n") }.rstrip
|
133
111
|
end
|
134
112
|
|
135
|
-
def collect_snippet_data(test_step,
|
113
|
+
def collect_snippet_data(test_step, ast_lookup)
|
136
114
|
# collect snippet data for undefined steps
|
137
|
-
|
138
|
-
|
139
|
-
@previous_step_keyword = keyword
|
140
|
-
if result.undefined?
|
141
|
-
@snippets_input << Console::SnippetData.new(keyword, test_step.source.last)
|
142
|
-
end
|
143
|
-
end
|
115
|
+
keyword = ast_lookup.snippet_step_keyword(test_step)
|
116
|
+
@snippets_input << Console::SnippetData.new(keyword, test_step)
|
144
117
|
end
|
145
118
|
|
146
119
|
def print_snippets(options)
|
147
120
|
return unless options[:snippets]
|
148
|
-
return if
|
121
|
+
return if @snippets_input.empty?
|
149
122
|
|
123
|
+
snippet_text_proc = lambda do |step_keyword, step_name, multiline_arg|
|
124
|
+
snippet_text(step_keyword, step_name, multiline_arg)
|
125
|
+
end
|
126
|
+
do_print_snippets(snippet_text_proc)
|
127
|
+
end
|
128
|
+
|
129
|
+
def do_print_snippets(snippet_text_proc)
|
150
130
|
snippets = @snippets_input.map do |data|
|
151
|
-
|
131
|
+
snippet_text_proc.call(data.actual_keyword, data.step.text, data.step.multiline_arg)
|
152
132
|
end.uniq
|
153
133
|
|
154
134
|
text = "\nYou can implement step definitions for undefined steps with these snippets:\n\n"
|
@@ -159,12 +139,20 @@ module Cucumber
|
|
159
139
|
@io.flush
|
160
140
|
end
|
161
141
|
|
162
|
-
def print_passing_wip(
|
163
|
-
return unless
|
164
|
-
|
165
|
-
|
142
|
+
def print_passing_wip(config, passed_test_cases, ast_lookup)
|
143
|
+
return unless config.wip?
|
144
|
+
messages = passed_test_cases.map do |test_case|
|
145
|
+
scenario_source = ast_lookup.scenario_source(test_case)
|
146
|
+
keyword = scenario_source.type == :Scenario ? scenario_source.scenario.keyword : scenario_source.scenario_outline.keyword
|
147
|
+
linebreaks("#{test_case.location.on_line(test_case.location.lines.max)}:in `#{keyword}: #{test_case.name}'", ENV['CUCUMBER_TRUNCATE_OUTPUT'].to_i)
|
148
|
+
end
|
149
|
+
do_print_passing_wip(messages)
|
150
|
+
end
|
151
|
+
|
152
|
+
def do_print_passing_wip(passed_messages)
|
153
|
+
if passed_messages.any?
|
166
154
|
@io.puts format_string("\nThe --wip switch was used, so I didn't expect anything to pass. These scenarios passed:", :failed)
|
167
|
-
|
155
|
+
print_element_messages(passed_messages, :passed, 'scenarios')
|
168
156
|
else
|
169
157
|
@io.puts format_string("\nThe --wip switch was used, so the failures were expected. All is good.\n", :passed)
|
170
158
|
end
|
@@ -174,56 +162,33 @@ module Cucumber
|
|
174
162
|
# no-op
|
175
163
|
end
|
176
164
|
|
177
|
-
#define @delayed_messages = [] in your Formatter if you want to
|
178
|
-
#activate this feature
|
179
165
|
def puts(*messages)
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
@io.puts
|
185
|
-
messages.each do |message|
|
186
|
-
@io.puts(format_string(message, :tag))
|
187
|
-
end
|
188
|
-
@io.flush
|
189
|
-
end
|
166
|
+
return unless @io
|
167
|
+
@io.puts
|
168
|
+
messages.each do |message|
|
169
|
+
@io.puts(format_string(message, :tag))
|
190
170
|
end
|
191
|
-
end
|
192
|
-
|
193
|
-
def print_messages
|
194
|
-
@delayed_messages.each {|message| print_message(message)}
|
195
|
-
empty_messages
|
196
|
-
end
|
197
|
-
|
198
|
-
def print_table_row_messages
|
199
|
-
return if @delayed_messages.empty?
|
200
|
-
@io.print(format_string(@delayed_messages.join(', '), :tag).indent(2))
|
201
|
-
@io.flush
|
202
|
-
empty_messages
|
203
|
-
end
|
204
|
-
|
205
|
-
def print_message(message)
|
206
|
-
@io.puts(format_string(message, :tag).indent(@indent))
|
207
171
|
@io.flush
|
208
172
|
end
|
209
173
|
|
210
|
-
def empty_messages
|
211
|
-
@delayed_messages = []
|
212
|
-
end
|
213
|
-
|
214
174
|
def print_profile_information
|
215
175
|
return if @options[:skip_profile_information] || @options[:profiles].nil? || @options[:profiles].empty?
|
216
|
-
|
217
|
-
|
218
|
-
profiles_sentence = profiles.size == 1 ? profiles.first :
|
219
|
-
"#{profiles[0...-1].join(', ')} and #{profiles.last}"
|
176
|
+
do_print_profile_information(@options[:profiles])
|
177
|
+
end
|
220
178
|
|
221
|
-
|
179
|
+
def do_print_profile_information(profiles)
|
180
|
+
profiles_sentence = if profiles.size == 1
|
181
|
+
profiles.first
|
182
|
+
else
|
183
|
+
"#{profiles[0...-1].join(', ')} and #{profiles.last}"
|
184
|
+
end
|
185
|
+
|
186
|
+
@io.puts "Using the #{profiles_sentence} profile#{'s' if profiles.size > 1}..."
|
222
187
|
end
|
223
188
|
|
224
189
|
private
|
225
190
|
|
226
|
-
FORMATS = Hash.new{ |hash, format| hash[format] = method(format).to_proc }
|
191
|
+
FORMATS = Hash.new { |hash, format| hash[format] = method(format).to_proc }
|
227
192
|
|
228
193
|
def format_for(*keys)
|
229
194
|
key = keys.join('_').to_sym
|
@@ -232,17 +197,30 @@ module Cucumber
|
|
232
197
|
fmt
|
233
198
|
end
|
234
199
|
|
235
|
-
def
|
236
|
-
|
200
|
+
def element_messages(elements, status)
|
201
|
+
elements.map do |element|
|
202
|
+
if status == :failed
|
203
|
+
exception_message_string(element.exception, 0)
|
204
|
+
else
|
205
|
+
linebreaks(element.backtrace_line, ENV['CUCUMBER_TRUNCATE_OUTPUT'].to_i)
|
206
|
+
end
|
207
|
+
end
|
208
|
+
end
|
209
|
+
|
210
|
+
def snippet_text(step_keyword, step_name, multiline_arg)
|
211
|
+
keyword = Cucumber::Gherkin::I18n.code_keyword_for(step_keyword).strip
|
212
|
+
config.snippet_generators.map do |generator|
|
213
|
+
generator.call(keyword, step_name, multiline_arg, config.snippet_type)
|
214
|
+
end.join("\n")
|
237
215
|
end
|
238
216
|
|
239
217
|
class SnippetData
|
240
218
|
attr_reader :actual_keyword, :step
|
241
219
|
def initialize(actual_keyword, step)
|
242
|
-
@actual_keyword
|
220
|
+
@actual_keyword = actual_keyword
|
221
|
+
@step = step
|
243
222
|
end
|
244
223
|
end
|
245
|
-
|
246
224
|
end
|
247
225
|
end
|
248
226
|
end
|
@@ -0,0 +1,39 @@
|
|
1
|
+
require 'cucumber/formatter/console'
|
2
|
+
|
3
|
+
module Cucumber
|
4
|
+
module Formatter
|
5
|
+
class ConsoleCounts
|
6
|
+
include Console
|
7
|
+
|
8
|
+
def initialize(config)
|
9
|
+
@summary = Core::Report::Summary.new(config.event_bus)
|
10
|
+
end
|
11
|
+
|
12
|
+
def to_s
|
13
|
+
[
|
14
|
+
[scenario_count, status_counts(@summary.test_cases)].compact.join(' '),
|
15
|
+
[step_count, status_counts(@summary.test_steps)].compact.join(' ')
|
16
|
+
].join("\n")
|
17
|
+
end
|
18
|
+
|
19
|
+
private
|
20
|
+
|
21
|
+
def scenario_count
|
22
|
+
count = @summary.test_cases.total
|
23
|
+
"#{count} scenario" + (count == 1 ? '' : 's')
|
24
|
+
end
|
25
|
+
|
26
|
+
def step_count
|
27
|
+
count = @summary.test_steps.total
|
28
|
+
"#{count} step" + (count == 1 ? '' : 's')
|
29
|
+
end
|
30
|
+
|
31
|
+
def status_counts(summary)
|
32
|
+
counts = Core::Test::Result::TYPES.map { |status| [status, summary.total(status)] }
|
33
|
+
counts = counts.select { |_status, count| count > 0 }
|
34
|
+
counts = counts.map { |status, count| format_string("#{count} #{status}", status) }
|
35
|
+
"(#{counts.join(', ')})" if counts.any?
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
@@ -0,0 +1,61 @@
|
|
1
|
+
require 'cucumber/formatter/console'
|
2
|
+
|
3
|
+
module Cucumber
|
4
|
+
module Formatter
|
5
|
+
class ConsoleIssues
|
6
|
+
include Console
|
7
|
+
|
8
|
+
def initialize(config, ast_lookup = AstLookup.new(config))
|
9
|
+
@previous_test_case = nil
|
10
|
+
@issues = Hash.new { |h, k| h[k] = [] }
|
11
|
+
@config = config
|
12
|
+
@config.on_event(:test_case_finished) do |event|
|
13
|
+
if event.test_case != @previous_test_case
|
14
|
+
@previous_test_case = event.test_case
|
15
|
+
@issues[event.result.to_sym] << event.test_case unless event.result.ok?(@config.strict)
|
16
|
+
elsif event.result.passed?
|
17
|
+
@issues[:flaky] << event.test_case unless Core::Test::Result::Flaky.ok?(@config.strict.strict?(:flaky))
|
18
|
+
@issues[:failed].delete(event.test_case)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
@ast_lookup = ast_lookup
|
22
|
+
end
|
23
|
+
|
24
|
+
def to_s
|
25
|
+
return if @issues.empty?
|
26
|
+
result = Core::Test::Result::TYPES.map { |type| scenario_listing(type, @issues[type]) }
|
27
|
+
result.flatten.join("\n")
|
28
|
+
end
|
29
|
+
|
30
|
+
def any?
|
31
|
+
@issues.any?
|
32
|
+
end
|
33
|
+
|
34
|
+
private
|
35
|
+
|
36
|
+
def scenario_listing(type, test_cases)
|
37
|
+
return [] if test_cases.empty?
|
38
|
+
[format_string("#{type_heading(type)} Scenarios:", type)] + test_cases.map do |test_case|
|
39
|
+
scenario_source = @ast_lookup.scenario_source(test_case)
|
40
|
+
keyword = scenario_source.type == :Scenario ? scenario_source.scenario.keyword : scenario_source.scenario_outline.keyword
|
41
|
+
source = @config.source? ? format_string(" # #{keyword}: #{test_case.name}", :comment) : ''
|
42
|
+
format_string("cucumber #{profiles_string}#{test_case.location.file}:#{test_case.location.lines.max}", type) + source
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
def type_heading(type)
|
47
|
+
case type
|
48
|
+
when :failed
|
49
|
+
'Failing'
|
50
|
+
else
|
51
|
+
type.to_s.slice(0, 1).capitalize + type.to_s.slice(1..-1)
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
def profiles_string
|
56
|
+
return if @config.custom_profiles.empty?
|
57
|
+
@config.custom_profiles.map { |profile| "-p #{profile}" }.join(' ') + ' '
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|