cucumber 3.0.0.pre.1 → 3.0.0.pre.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.cucumberproignore +6 -0
- data/.rubocop.yml +13 -0
- data/.rubocop_todo.yml +1075 -0
- data/.travis.yml +42 -8
- data/CONTRIBUTING.md +8 -1
- data/Gemfile +16 -10
- data/History.md +96 -36
- data/README.md +12 -3
- data/Rakefile +12 -2
- data/appveyor.yml +26 -0
- data/cucumber.gemspec +15 -10
- data/cucumber.yml +9 -10
- data/examples/i18n/Rakefile +1 -1
- data/examples/i18n/ar/features/step_definitions/calculator_steps.rb +2 -2
- data/examples/i18n/ar/lib/calculator.rb +2 -2
- data/examples/i18n/bg/features/step_definitions/calculator_steps.rb +6 -6
- data/examples/i18n/ca/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/ca/lib/calculadora.rb +2 -2
- data/examples/i18n/cs/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/cs/lib/calculator.rb +3 -3
- data/examples/i18n/da/features/step_definitions/lommeregner_steps.rb +4 -4
- data/examples/i18n/da/lib/lommeregner.rb +2 -2
- data/examples/i18n/de/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/de/lib/calculator.rb +2 -2
- data/examples/i18n/el/features/step_definitions/calculator_steps.rb +5 -5
- data/examples/i18n/el/lib/calculator.rb +2 -2
- data/examples/i18n/en-lol/features/step_definitions/cucumbrz_steps.rb +4 -4
- data/examples/i18n/en-lol/lib/basket.rb +2 -2
- data/examples/i18n/en-lol/lib/belly.rb +2 -2
- data/examples/i18n/en/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/en/lib/calculator.rb +2 -2
- data/examples/i18n/eo/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/eo/lib/calculator.rb +2 -2
- data/examples/i18n/es/features/step_definitions/calculador_steps.rb +5 -5
- data/examples/i18n/es/lib/calculador.rb +2 -2
- data/examples/i18n/et/features/step_definitions/kalkulaator_steps.rb +4 -4
- data/examples/i18n/et/lib/kalkulaator.rb +3 -3
- data/examples/i18n/fi/features/step_definitions/laskin_steps.rb +3 -3
- data/examples/i18n/fi/lib/laskin.rb +1 -1
- data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +8 -8
- data/examples/i18n/fr/features/support/env.rb +1 -1
- data/examples/i18n/fr/lib/calculatrice.rb +2 -2
- data/examples/i18n/he/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/he/lib/calculator.rb +1 -1
- data/examples/i18n/hi/features/step_definitions/calculator_steps.rb +3 -3
- data/examples/i18n/hi/lib/calculator.rb +1 -1
- data/examples/i18n/ht/features/step_definitions/kalkilatris_steps.rb +4 -4
- data/examples/i18n/ht/lib/kalkilatris.rb +2 -2
- data/examples/i18n/hu/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/hu/lib/calculator.rb +1 -1
- data/examples/i18n/id/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/id/lib/calculator.rb +2 -2
- data/examples/i18n/it/features/step_definitions/calcolatrice_steps.rb +4 -4
- data/examples/i18n/it/lib/calcolatrice.rb +3 -3
- data/examples/i18n/ja/features/step_definitions/calculator_steps.rb +3 -3
- data/examples/i18n/ja/features/support/env.rb +1 -1
- data/examples/i18n/ja/lib/calculator.rb +2 -2
- data/examples/i18n/ko/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/ko/lib/calculator.rb +2 -2
- data/examples/i18n/lt/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/lt/lib/calculator.rb +2 -2
- data/examples/i18n/lv/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/lv/lib/calculator.rb +2 -2
- data/examples/i18n/no/features/step_definitions/kalkulator_steps.rb +3 -3
- data/examples/i18n/no/features/support/env.rb +1 -1
- data/examples/i18n/no/lib/kalkulator.rb +2 -2
- data/examples/i18n/pl/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/pl/lib/calculator.rb +2 -2
- data/examples/i18n/pt/features/step_definitions/calculadora_steps.rb +3 -3
- data/examples/i18n/pt/features/support/env.rb +1 -1
- data/examples/i18n/pt/lib/calculadora.rb +1 -1
- data/examples/i18n/ro/features/step_definitions/calculator_steps.rb +5 -5
- data/examples/i18n/ro/lib/calculator.rb +1 -1
- data/examples/i18n/ru/features/step_definitions/calculator_steps.rb +5 -5
- data/examples/i18n/sk/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/sk/lib/calculator.rb +2 -2
- data/examples/i18n/sr-Cyrl/features/step_definitions/calculator_steps.rb +3 -3
- data/examples/i18n/sr-Cyrl/features/support/env.rb +1 -1
- data/examples/i18n/sr-Cyrl/lib/calculator.rb +2 -2
- data/examples/i18n/sr-Latn/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/sr-Latn/lib/calculator.rb +2 -2
- data/examples/i18n/sv/features/step_definitions/kalkulator_steps.rb +3 -3
- data/examples/i18n/sv/lib/kalkulator.rb +2 -2
- data/examples/i18n/tr/features/step_definitions/hesap_makinesi_adimlari.rb +4 -4
- data/examples/i18n/tr/lib/hesap_makinesi.rb +2 -2
- data/examples/i18n/uk/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/uz/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/zh-CN/features/step_definitions/calculator_steps.rb +5 -5
- data/examples/i18n/zh-CN/lib/calculator.rb +2 -2
- data/examples/i18n/zh-TW/features/step_definitions/calculator_steps.rb +4 -4
- data/examples/i18n/zh-TW/lib/calculator.rb +2 -2
- data/examples/rspec_doubles/features/step_definitions/calvin_steps.rb +3 -3
- data/examples/sinatra/features/step_definitions/add_steps.rb +4 -4
- data/examples/tcl/features/step_definitions/fib_steps.rb +2 -2
- data/examples/test_unit/features/step_definitions/test_unit_steps.rb +4 -4
- data/examples/watir/features/step_definitions/search_steps.rb +3 -3
- data/examples/watir/features/support/screenshots.rb +5 -5
- data/features/docs/api/list_step_defs_as_json.feature +21 -7
- data/features/docs/api/listen_for_events.feature +1 -1
- data/features/docs/api/run_cli_main_with_existing_runtime.feature +1 -0
- data/features/docs/cli/dry_run.feature +3 -0
- data/features/docs/cli/execute_with_tag_filter.feature +4 -4
- data/features/docs/cli/fail_fast.feature +2 -0
- data/features/docs/{gherkin/language_help.feature → cli/i18n.feature} +6 -6
- data/features/docs/cli/randomize.feature +2 -2
- data/features/docs/cli/retry_failing_tests.feature +28 -3
- data/features/docs/cli/run_scenarios_matching_name.feature +1 -0
- data/features/docs/cli/specifying_multiple_formatters.feature +3 -0
- data/features/docs/cli/strict_mode.feature +6 -0
- data/features/docs/defining_steps/nested_steps.feature +5 -1
- data/features/docs/defining_steps/nested_steps_i18n.feature +1 -0
- data/features/docs/defining_steps/nested_steps_with_second_arg.feature +2 -0
- data/features/docs/defining_steps/printing_messages.feature +1 -1
- data/features/docs/defining_steps/skip_scenario.feature +1 -0
- data/features/docs/defining_steps/snippets.feature +18 -18
- data/features/docs/events/gherkin_source_read_event.feature +43 -0
- data/features/docs/events/step_activated_event.feature +36 -0
- data/features/docs/events/step_definition_registered_event.feature +29 -0
- data/features/docs/events/test_case_finished_event.feature +35 -0
- data/features/docs/events/test_case_starting_event.feature +54 -0
- data/features/docs/events/test_run_finished_event.feature +40 -0
- data/features/docs/events/test_run_starting_event.feature +41 -0
- data/features/docs/events/test_step_finished_event.feature +47 -0
- data/features/docs/events/test_step_starting_event.feature +43 -0
- data/features/docs/exception_in_after_hook.feature +3 -2
- data/features/docs/exception_in_after_step_hook.feature +2 -0
- data/features/docs/exception_in_around_hook.feature +2 -0
- data/features/docs/exception_in_before_hook.feature +3 -1
- data/features/docs/extending_cucumber/custom_formatter.feature +21 -1
- data/features/docs/formatters/json_formatter.feature +4 -4
- data/features/docs/formatters/junit_formatter.feature +7 -6
- data/features/docs/formatters/pretty_formatter.feature +1 -0
- data/features/docs/formatters/progress_formatter.feature +1 -0
- data/features/docs/formatters/rerun_formatter.feature +2 -0
- data/features/docs/formatters/summary_formatter.feature +1 -0
- data/features/docs/formatters/usage_formatter.feature +3 -0
- data/features/docs/getting_started.feature +2 -1
- data/features/docs/gherkin/background.feature +5 -5
- data/features/docs/gherkin/doc_strings.feature +2 -0
- data/features/docs/gherkin/expand_option_for_outlines.feature +1 -0
- data/features/docs/gherkin/outlines.feature +4 -0
- data/features/docs/gherkin/unicode_table.feature +1 -0
- data/features/docs/gherkin/using_descriptions.feature +1 -0
- data/features/docs/gherkin/using_star_notation.feature +1 -1
- data/features/docs/post_configuration_hook.feature +1 -1
- data/features/docs/rake_task.feature +5 -0
- data/features/docs/raketask.feature +3 -1
- data/features/docs/work_in_progress.feature +5 -2
- data/features/docs/writing_support_code/after_step_hooks.feature +3 -1
- data/features/docs/writing_support_code/around_hooks.feature +6 -0
- data/features/docs/writing_support_code/before_hook.feature +1 -0
- data/features/docs/writing_support_code/hook_order.feature +3 -1
- data/features/docs/writing_support_code/parameter_types.feature +75 -0
- data/features/docs/writing_support_code/tagged_hooks.feature +1 -1
- data/features/lib/step_definitions/aruba_steps.rb +4 -10
- data/features/lib/step_definitions/cli_steps.rb +2 -2
- data/features/lib/step_definitions/cucumber_steps.rb +8 -12
- data/features/lib/step_definitions/iso-8859-1_steps.rb +2 -2
- data/features/lib/step_definitions/json_steps.rb +1 -1
- data/features/lib/step_definitions/junit_steps.rb +1 -1
- data/features/lib/step_definitions/language_steps.rb +2 -2
- data/features/lib/step_definitions/profile_steps.rb +6 -6
- data/features/lib/step_definitions/retry_steps.rb +3 -3
- data/features/lib/step_definitions/ruby_steps.rb +1 -1
- data/features/lib/support/env.rb +1 -1
- data/features/lib/support/fake_wire_server.rb +7 -2
- data/features/lib/support/feature_factory.rb +1 -1
- data/features/lib/support/normalise_output.rb +13 -12
- data/features/lib/support/parameter_types.rb +8 -0
- data/gem_tasks/contributors.rake +9 -6
- data/gem_tasks/environment.rake +1 -5
- data/gem_tasks/examples.rake +1 -1
- data/gem_tasks/fix_cr_lf.rake +1 -1
- data/gem_tasks/flog.rake +2 -2
- data/gem_tasks/rspec.rake +1 -1
- data/lib/autotest/cucumber_mixin.rb +15 -15
- data/lib/autotest/discover.rb +2 -2
- data/lib/cucumber/cli/configuration.rb +7 -13
- data/lib/cucumber/cli/main.rb +6 -6
- data/lib/cucumber/cli/options.rb +163 -126
- data/lib/cucumber/cli/profile_loader.rb +24 -20
- data/lib/cucumber/configuration.rb +12 -17
- data/lib/cucumber/constantize.rb +1 -1
- data/lib/cucumber/core_ext/string.rb +1 -1
- data/lib/cucumber/deprecate.rb +1 -1
- data/lib/cucumber/events.rb +11 -1
- data/lib/cucumber/events/gherkin_source_read.rb +17 -0
- data/lib/cucumber/events/{step_match.rb → step_activated.rb} +2 -2
- data/lib/cucumber/events/step_definition_registered.rb +1 -1
- data/lib/cucumber/events/test_case_finished.rb +18 -0
- data/lib/cucumber/events/test_case_starting.rb +15 -0
- data/lib/cucumber/events/test_run_starting.rb +16 -0
- data/lib/cucumber/events/test_step_finished.rb +20 -0
- data/lib/cucumber/events/test_step_starting.rb +17 -0
- data/lib/cucumber/filters.rb +1 -0
- data/lib/cucumber/filters/activate_steps.rb +1 -1
- data/lib/cucumber/filters/broadcast_test_run_starting_event.rb +27 -0
- data/lib/cucumber/filters/retry.rb +1 -1
- data/lib/cucumber/filters/tag_limits.rb +3 -3
- data/lib/cucumber/filters/tag_limits/verifier.rb +1 -1
- data/lib/cucumber/formatter/ansicolor.rb +8 -11
- data/lib/cucumber/formatter/backtrace_filter.rb +19 -7
- data/lib/cucumber/formatter/console.rb +16 -19
- data/lib/cucumber/formatter/console_counts.rb +8 -21
- data/lib/cucumber/formatter/console_issues.rb +30 -9
- data/lib/cucumber/formatter/duration.rb +1 -1
- data/lib/cucumber/formatter/fail_fast.rb +1 -1
- data/lib/cucumber/formatter/html.rb +168 -242
- data/lib/cucumber/formatter/html_builder.rb +110 -0
- data/lib/cucumber/formatter/inline-js.js +30 -0
- data/lib/cucumber/formatter/interceptor.rb +2 -2
- data/lib/cucumber/formatter/json.rb +12 -12
- data/lib/cucumber/formatter/junit.rb +11 -11
- data/lib/cucumber/formatter/legacy_api/adapter.rb +27 -27
- data/lib/cucumber/formatter/legacy_api/ast.rb +16 -20
- data/lib/cucumber/formatter/legacy_api/results.rb +6 -8
- data/lib/cucumber/formatter/pretty.rb +17 -17
- data/lib/cucumber/formatter/progress.rb +11 -12
- data/lib/cucumber/formatter/rerun.rb +1 -1
- data/lib/cucumber/formatter/steps.rb +1 -1
- data/lib/cucumber/formatter/unicode.rb +1 -1
- data/lib/cucumber/formatter/usage.rb +12 -12
- data/lib/cucumber/gherkin/formatter/ansi_escapes.rb +1 -1
- data/lib/cucumber/gherkin/formatter/escaping.rb +1 -1
- data/lib/cucumber/{rb_support/rb_dsl.rb → glue/dsl.rb} +44 -17
- data/lib/cucumber/glue/hook.rb +43 -0
- data/lib/cucumber/glue/invoke_in_world.rb +70 -0
- data/lib/cucumber/glue/proto_world.rb +225 -0
- data/lib/cucumber/{rb_support/rb_language.rb → glue/registry_and_more.rb} +45 -86
- data/lib/cucumber/{rb_support → glue}/snippet.rb +62 -25
- data/lib/cucumber/glue/step_definition.rb +143 -0
- data/lib/cucumber/glue/world_factory.rb +23 -0
- data/lib/cucumber/hooks.rb +4 -4
- data/lib/cucumber/multiline_argument.rb +2 -2
- data/lib/cucumber/multiline_argument/data_table.rb +40 -178
- data/lib/cucumber/multiline_argument/data_table/diff_matrices.rb +158 -0
- data/lib/cucumber/platform.rb +3 -5
- data/lib/cucumber/rake/task.rb +11 -11
- data/lib/cucumber/rspec/disable_option_parser.rb +1 -1
- data/lib/cucumber/rspec/doubles.rb +1 -1
- data/lib/cucumber/running_test_case.rb +2 -2
- data/lib/cucumber/runtime.rb +46 -34
- data/lib/cucumber/runtime/after_hooks.rb +1 -1
- data/lib/cucumber/runtime/for_programming_languages.rb +1 -36
- data/lib/cucumber/runtime/support_code.rb +19 -15
- data/lib/cucumber/runtime/user_interface.rb +4 -11
- data/lib/cucumber/step_argument.rb +0 -2
- data/lib/cucumber/step_definition_light.rb +1 -0
- data/lib/cucumber/step_match.rb +16 -15
- data/lib/cucumber/step_match_search.rb +2 -3
- data/lib/cucumber/term/ansicolor.rb +1 -1
- data/lib/cucumber/version +1 -1
- data/lib/simplecov_setup.rb +1 -1
- data/scripts/invite-collaborator +40 -0
- data/scripts/update-history +83 -0
- data/spec/cucumber/cli/configuration_spec.rb +95 -97
- data/spec/cucumber/cli/main_spec.rb +7 -7
- data/spec/cucumber/cli/options_spec.rb +112 -78
- data/spec/cucumber/cli/profile_loader_spec.rb +24 -5
- data/spec/cucumber/cli/rerun_spec.rb +20 -20
- data/spec/cucumber/configuration_spec.rb +47 -47
- data/spec/cucumber/constantize_spec.rb +2 -2
- data/spec/cucumber/events_spec.rb +9 -0
- data/spec/cucumber/file_specs_spec.rb +25 -25
- data/spec/cucumber/filters/activate_steps_spec.rb +16 -16
- data/spec/cucumber/filters/gated_receiver_spec.rb +6 -6
- data/spec/cucumber/filters/retry_spec.rb +22 -9
- data/spec/cucumber/filters/tag_limits/test_case_index_spec.rb +11 -11
- data/spec/cucumber/filters/tag_limits/verifier_spec.rb +14 -14
- data/spec/cucumber/filters/tag_limits_spec.rb +8 -8
- data/spec/cucumber/formatter/ansicolor_spec.rb +9 -9
- data/spec/cucumber/formatter/backtrace_filter_spec.rb +32 -0
- data/spec/cucumber/formatter/console_counts_spec.rb +1 -1
- data/spec/cucumber/formatter/duration_spec.rb +3 -3
- data/spec/cucumber/formatter/fail_fast_spec.rb +21 -21
- data/spec/cucumber/formatter/html_spec.rb +58 -58
- data/spec/cucumber/formatter/json_spec.rb +44 -46
- data/spec/cucumber/formatter/junit_spec.rb +43 -45
- data/spec/cucumber/formatter/legacy_api/adapter_spec.rb +43 -43
- data/spec/cucumber/formatter/pretty_spec.rb +107 -107
- data/spec/cucumber/formatter/progress_spec.rb +20 -20
- data/spec/cucumber/formatter/rerun_spec.rb +1 -1
- data/spec/cucumber/formatter/spec_helper.rb +6 -5
- data/spec/cucumber/{rb_support/rb_world_spec.rb → glue/proto_world_spec.rb} +20 -5
- data/spec/cucumber/glue/registry_and_more_spec.rb +213 -0
- data/spec/cucumber/{rb_support → glue}/snippet_spec.rb +61 -25
- data/spec/cucumber/glue/step_definition_spec.rb +207 -0
- data/spec/cucumber/hooks_spec.rb +3 -3
- data/spec/cucumber/multiline_argument/data_table_spec.rb +177 -133
- data/spec/cucumber/project_initializer_spec.rb +10 -10
- data/spec/cucumber/rake/forked_spec.rb +10 -10
- data/spec/cucumber/rake/task_spec.rb +20 -20
- data/spec/cucumber/running_test_case_spec.rb +35 -35
- data/spec/cucumber/runtime/for_programming_languages_spec.rb +1 -30
- data/spec/cucumber/runtime_spec.rb +2 -2
- data/spec/cucumber/step_argument_spec.rb +5 -5
- data/spec/cucumber/step_match_search_spec.rb +31 -41
- data/spec/cucumber/step_match_spec.rb +33 -33
- data/spec/cucumber/world/pending_spec.rb +10 -10
- metadata +117 -47
- data/features/docs/formatters/debug_formatter.feature +0 -47
- data/features/docs/writing_support_code/transforms.feature +0 -98
- data/features/lib/step_definitions/wire_steps.rb +0 -59
- data/gem_tasks/cucumber.rake +0 -26
- data/lib/cucumber/core_ext/instance_exec.rb +0 -71
- data/lib/cucumber/formatter/debug.rb +0 -36
- data/lib/cucumber/rb_support/rb_hook.rb +0 -20
- data/lib/cucumber/rb_support/rb_step_definition.rb +0 -132
- data/lib/cucumber/rb_support/rb_transform.rb +0 -60
- data/lib/cucumber/rb_support/rb_world.rb +0 -171
- data/spec/cucumber/core_ext/instance_exec_spec.rb +0 -5
- data/spec/cucumber/formatter/debug_spec.rb +0 -65
- data/spec/cucumber/rb_support/rb_language_spec.rb +0 -321
- data/spec/cucumber/rb_support/rb_step_definition_spec.rb +0 -200
- data/spec/cucumber/rb_support/rb_transform_spec.rb +0 -47
@@ -1,5 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
-
require
|
2
|
+
require 'cucumber/filters/gated_receiver'
|
3
3
|
|
4
4
|
describe Cucumber::Filters::GatedReceiver do
|
5
5
|
subject(:gated_receiver) { Cucumber::Filters::GatedReceiver.new(receiver) }
|
@@ -7,8 +7,8 @@ describe Cucumber::Filters::GatedReceiver do
|
|
7
7
|
let(:receiver) { double(:receiver) }
|
8
8
|
let(:test_cases){ [double(:test_case), double(:test_case)] }
|
9
9
|
|
10
|
-
describe
|
11
|
-
it
|
10
|
+
describe '#test_case' do
|
11
|
+
it 'does not immediately describe the test case to the receiver' do
|
12
12
|
test_cases.each do |test_case|
|
13
13
|
expect(test_case).to_not receive(:describe_to).with(receiver)
|
14
14
|
end
|
@@ -19,7 +19,7 @@ describe Cucumber::Filters::GatedReceiver do
|
|
19
19
|
end
|
20
20
|
end
|
21
21
|
|
22
|
-
describe
|
22
|
+
describe '#done' do
|
23
23
|
before do
|
24
24
|
test_cases.each do |test_case|
|
25
25
|
gated_receiver.test_case(test_case)
|
@@ -32,7 +32,7 @@ describe Cucumber::Filters::GatedReceiver do
|
|
32
32
|
allow(receiver).to receive(:done)
|
33
33
|
end
|
34
34
|
|
35
|
-
it
|
35
|
+
it 'describes all test cases to the receiver' do
|
36
36
|
test_cases.each do |test_case|
|
37
37
|
expect(test_case).to receive(:describe_to).with(receiver)
|
38
38
|
end
|
@@ -40,7 +40,7 @@ describe Cucumber::Filters::GatedReceiver do
|
|
40
40
|
gated_receiver.done
|
41
41
|
end
|
42
42
|
|
43
|
-
it
|
43
|
+
it 'calls done on the receiver' do
|
44
44
|
expect(receiver).to receive(:done)
|
45
45
|
gated_receiver.done
|
46
46
|
end
|
@@ -23,20 +23,33 @@ describe Cucumber::Filters::Retry do
|
|
23
23
|
it { is_expected.to respond_to(:with_receiver) }
|
24
24
|
it { is_expected.to respond_to(:done) }
|
25
25
|
|
26
|
-
context
|
26
|
+
context 'passing test case' do
|
27
27
|
let(:result) { Cucumber::Core::Test::Result::Passed.new(0) }
|
28
28
|
|
29
|
-
it
|
29
|
+
it 'describes the test case once' do
|
30
30
|
expect(receiver).to receive(:test_case).with(test_case).once
|
31
31
|
test_case.describe_to filter
|
32
32
|
configuration.notify :test_case_finished, test_case, result
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
|
-
context
|
36
|
+
context 'when performing retry' do
|
37
37
|
let(:result) { Cucumber::Core::Test::Result::Failed.new(0, StandardError.new) }
|
38
38
|
|
39
|
-
it
|
39
|
+
it 'describes the same test case object each time' do
|
40
|
+
allow(receiver).to receive(:test_case) {|tc|
|
41
|
+
expect(tc).to equal(test_case)
|
42
|
+
configuration.notify :test_case_finished, tc.with_steps(tc.test_steps), result
|
43
|
+
}
|
44
|
+
|
45
|
+
filter.test_case(test_case)
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
context 'consistently failing test case' do
|
50
|
+
let(:result) { Cucumber::Core::Test::Result::Failed.new(0, StandardError.new) }
|
51
|
+
|
52
|
+
it 'describes the test case the specified number of times' do
|
40
53
|
expect(receiver).to receive(:test_case) {|test_case|
|
41
54
|
configuration.notify :test_case_finished, test_case, result
|
42
55
|
}.exactly(3).times
|
@@ -45,9 +58,9 @@ describe Cucumber::Filters::Retry do
|
|
45
58
|
end
|
46
59
|
end
|
47
60
|
|
48
|
-
context
|
61
|
+
context 'flaky test cases' do
|
49
62
|
|
50
|
-
context
|
63
|
+
context 'a little flaky' do
|
51
64
|
let(:results) {
|
52
65
|
[
|
53
66
|
Cucumber::Core::Test::Result::Failed.new(0, StandardError.new),
|
@@ -55,7 +68,7 @@ describe Cucumber::Filters::Retry do
|
|
55
68
|
]
|
56
69
|
}
|
57
70
|
|
58
|
-
it
|
71
|
+
it 'describes the test case twice' do
|
59
72
|
expect(receiver).to receive(:test_case) {|test_case|
|
60
73
|
configuration.notify :test_case_finished, test_case, results.shift
|
61
74
|
}.exactly(2).times
|
@@ -64,7 +77,7 @@ describe Cucumber::Filters::Retry do
|
|
64
77
|
end
|
65
78
|
end
|
66
79
|
|
67
|
-
context
|
80
|
+
context 'really flaky' do
|
68
81
|
let(:results) {
|
69
82
|
[
|
70
83
|
Cucumber::Core::Test::Result::Failed.new(0, StandardError.new),
|
@@ -73,7 +86,7 @@ describe Cucumber::Filters::Retry do
|
|
73
86
|
]
|
74
87
|
}
|
75
88
|
|
76
|
-
it
|
89
|
+
it 'describes the test case 3 times' do
|
77
90
|
expect(receiver).to receive(:test_case) {|test_case|
|
78
91
|
configuration.notify :test_case_finished, test_case, results.shift
|
79
92
|
}.exactly(3).times
|
@@ -1,5 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
-
require
|
2
|
+
require 'cucumber/filters/tag_limits'
|
3
3
|
|
4
4
|
describe Cucumber::Filters::TagLimits::TestCaseIndex do
|
5
5
|
subject(:index) { Cucumber::Filters::TagLimits::TestCaseIndex.new }
|
@@ -11,8 +11,8 @@ describe Cucumber::Filters::TagLimits::TestCaseIndex do
|
|
11
11
|
]
|
12
12
|
end
|
13
13
|
|
14
|
-
let(:tag_one) { double(:tag_one, name:
|
15
|
-
let(:tag_two) { double(:tag_two, name:
|
14
|
+
let(:tag_one) { double(:tag_one, name: '@one') }
|
15
|
+
let(:tag_two) { double(:tag_two, name: '@two') }
|
16
16
|
|
17
17
|
let(:a_location_of_tag_one) { double(:a_location_of_tag_one) }
|
18
18
|
let(:a_location_of_tag_one_and_tag_two) { double(:a_location_of_tag_one_and_tag_two) }
|
@@ -23,17 +23,17 @@ describe Cucumber::Filters::TagLimits::TestCaseIndex do
|
|
23
23
|
end
|
24
24
|
end
|
25
25
|
|
26
|
-
describe
|
27
|
-
it
|
28
|
-
expect(index.count_by_tag_name(
|
29
|
-
expect(index.count_by_tag_name(
|
26
|
+
describe '#count_by_tag_name' do
|
27
|
+
it 'returns the number of test cases with the tag' do
|
28
|
+
expect(index.count_by_tag_name('@one')).to eq(2)
|
29
|
+
expect(index.count_by_tag_name('@two')).to eq(1)
|
30
30
|
end
|
31
31
|
end
|
32
32
|
|
33
|
-
describe
|
34
|
-
it
|
35
|
-
expect(index.locations_of_tag_name(
|
36
|
-
expect(index.locations_of_tag_name(
|
33
|
+
describe '#locations_by_tag_name' do
|
34
|
+
it 'returns the locations of test cases with the tag' do
|
35
|
+
expect(index.locations_of_tag_name('@one')).to eq([a_location_of_tag_one, a_location_of_tag_one_and_tag_two])
|
36
|
+
expect(index.locations_of_tag_name('@two')).to eq([a_location_of_tag_one_and_tag_two])
|
37
37
|
end
|
38
38
|
end
|
39
39
|
end
|
@@ -1,54 +1,54 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
-
require
|
2
|
+
require 'cucumber/filters/tag_limits'
|
3
3
|
|
4
4
|
describe Cucumber::Filters::TagLimits::Verifier do
|
5
|
-
describe
|
5
|
+
describe '#verify!' do
|
6
6
|
subject(:verifier) { Cucumber::Filters::TagLimits::Verifier.new(tag_limits) }
|
7
7
|
let(:test_case_index) { double(:test_case_index) }
|
8
8
|
|
9
|
-
context
|
9
|
+
context 'the tag counts exceed the tag limits' do
|
10
10
|
let(:tag_limits) do
|
11
11
|
{
|
12
|
-
|
12
|
+
'@exceed_me' => 1
|
13
13
|
}
|
14
14
|
end
|
15
15
|
|
16
16
|
let(:locations) do
|
17
17
|
[
|
18
|
-
double(:location, to_s:
|
19
|
-
double(:location, to_s:
|
18
|
+
double(:location, to_s: 'path/to/some.feature:3'),
|
19
|
+
double(:location, to_s: 'path/to/some/other.feature:8')
|
20
20
|
]
|
21
21
|
end
|
22
22
|
|
23
23
|
before do
|
24
|
-
allow(test_case_index).to receive(:count_by_tag_name).with(
|
25
|
-
allow(test_case_index).to receive(:locations_of_tag_name).with(
|
24
|
+
allow(test_case_index).to receive(:count_by_tag_name).with('@exceed_me') { 2 }
|
25
|
+
allow(test_case_index).to receive(:locations_of_tag_name).with('@exceed_me') { locations }
|
26
26
|
end
|
27
27
|
|
28
|
-
it
|
28
|
+
it 'raises a TagLimitExceeded error with the locations of the tags' do
|
29
29
|
expect {
|
30
30
|
verifier.verify!(test_case_index)
|
31
31
|
}.to raise_error(
|
32
32
|
Cucumber::Filters::TagLimitExceededError,
|
33
33
|
"@exceed_me occurred 2 times, but the limit was set to 1\n" +
|
34
34
|
" path/to/some.feature:3\n" +
|
35
|
-
|
35
|
+
' path/to/some/other.feature:8'
|
36
36
|
)
|
37
37
|
end
|
38
38
|
end
|
39
39
|
|
40
|
-
context
|
40
|
+
context 'the tag counts do not exceed the tag limits' do
|
41
41
|
let(:tag_limits) do
|
42
42
|
{
|
43
|
-
|
43
|
+
'@dont_exceed_me' => 2
|
44
44
|
}
|
45
45
|
end
|
46
46
|
|
47
47
|
before do
|
48
|
-
allow(test_case_index).to receive(:count_by_tag_name).with(
|
48
|
+
allow(test_case_index).to receive(:count_by_tag_name).with('@dont_exceed_me') { 1 }
|
49
49
|
end
|
50
50
|
|
51
|
-
it
|
51
|
+
it 'does not raise an error' do
|
52
52
|
expect {
|
53
53
|
verifier.verify!(test_case_index)
|
54
54
|
}.to_not raise_error
|
@@ -1,5 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
-
require
|
2
|
+
require 'cucumber/filters/tag_limits'
|
3
3
|
|
4
4
|
describe Cucumber::Filters::TagLimits do
|
5
5
|
subject(:filter) { Cucumber::Filters::TagLimits.new(tag_limits, receiver) }
|
@@ -16,24 +16,24 @@ describe Cucumber::Filters::TagLimits do
|
|
16
16
|
allow(Cucumber::Filters::TagLimits::TestCaseIndex).to receive(:new) { test_case_index }
|
17
17
|
end
|
18
18
|
|
19
|
-
describe
|
19
|
+
describe '#test_case' do
|
20
20
|
before do
|
21
21
|
allow(test_case_index).to receive(:add)
|
22
22
|
allow(gated_receiver).to receive(:test_case)
|
23
23
|
end
|
24
24
|
|
25
|
-
it
|
25
|
+
it 'indexes the test case' do
|
26
26
|
expect(test_case_index).to receive(:add).with(test_case)
|
27
27
|
filter.test_case(test_case)
|
28
28
|
end
|
29
29
|
|
30
|
-
it
|
30
|
+
it 'adds the test case to the gated receiver' do
|
31
31
|
expect(gated_receiver).to receive(:test_case).with(test_case)
|
32
32
|
filter.test_case(test_case)
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
|
-
describe
|
36
|
+
describe '#done' do
|
37
37
|
let(:verifier) { double(:verifier) }
|
38
38
|
|
39
39
|
before do
|
@@ -41,17 +41,17 @@ describe Cucumber::Filters::TagLimits do
|
|
41
41
|
allow(gated_receiver).to receive(:done)
|
42
42
|
end
|
43
43
|
|
44
|
-
it
|
44
|
+
it 'verifies tag limits have not been exceeded' do
|
45
45
|
expect(verifier).to receive(:verify!).with(test_case_index)
|
46
46
|
filter.done
|
47
47
|
end
|
48
48
|
|
49
|
-
context
|
49
|
+
context 'the verifier verifies successfully' do
|
50
50
|
before do
|
51
51
|
allow(verifier).to receive(:verify!).with(test_case_index)
|
52
52
|
end
|
53
53
|
|
54
|
-
it
|
54
|
+
it 'calls done on the receiver gate' do
|
55
55
|
expect(gated_receiver).to receive(:done)
|
56
56
|
filter.done
|
57
57
|
end
|
@@ -7,26 +7,26 @@ module Cucumber
|
|
7
7
|
describe ANSIColor do
|
8
8
|
include ANSIColor
|
9
9
|
|
10
|
-
it
|
11
|
-
expect(passed_param(
|
10
|
+
it 'wraps passed_param with bold green and reset to green' do
|
11
|
+
expect(passed_param('foo')).to eq "\e[32m\e[1mfoo\e[0m\e[0m\e[32m"
|
12
12
|
end
|
13
13
|
|
14
|
-
it
|
15
|
-
expect(passed(
|
14
|
+
it 'wraps passed in green' do
|
15
|
+
expect(passed('foo')).to eq "\e[32mfoo\e[0m"
|
16
16
|
end
|
17
17
|
|
18
|
-
it
|
18
|
+
it 'does not reset passed if there are no arguments' do
|
19
19
|
expect(passed).to eq "\e[32m"
|
20
20
|
end
|
21
21
|
|
22
|
-
it
|
23
|
-
expect(comment(
|
22
|
+
it 'wraps comments in grey' do
|
23
|
+
expect(comment('foo')).to eq "\e[90mfoo\e[0m"
|
24
24
|
end
|
25
25
|
|
26
|
-
it
|
26
|
+
it 'does not generate ansi codes when colors are disabled' do
|
27
27
|
::Cucumber::Term::ANSIColor.coloring = false
|
28
28
|
|
29
|
-
expect(passed(
|
29
|
+
expect(passed('foo')).to eq 'foo'
|
30
30
|
end
|
31
31
|
end
|
32
32
|
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
require 'cucumber/formatter/backtrace_filter'
|
2
|
+
|
3
|
+
module Cucumber
|
4
|
+
module Formatter
|
5
|
+
describe BacktraceFilter do
|
6
|
+
context '#exception' do
|
7
|
+
before do
|
8
|
+
trace = %w(a b
|
9
|
+
_anything__/vendor/rails__anything_
|
10
|
+
_anything__lib/cucumber__anything_
|
11
|
+
_anything__bin/cucumber:__anything_
|
12
|
+
_anything__lib/rspec__anything_
|
13
|
+
_anything__gems/__anything_
|
14
|
+
_anything__minitest__anything_
|
15
|
+
_anything__test/unit__anything_
|
16
|
+
_anything__Xgem/ruby__anything_
|
17
|
+
_anything__lib/ruby/__anything_
|
18
|
+
_anything__.rbenv/versions/2.3/bin/bundle__anything_)
|
19
|
+
@exception = Exception.new
|
20
|
+
@exception.set_backtrace(trace)
|
21
|
+
end
|
22
|
+
|
23
|
+
it 'filters unnecessary traces' do
|
24
|
+
BacktraceFilter.new(@exception).exception
|
25
|
+
expect(@exception.backtrace).to eql %w(a b)
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
|
@@ -4,7 +4,7 @@ require 'cucumber/formatter/console_counts'
|
|
4
4
|
module Cucumber
|
5
5
|
module Formatter
|
6
6
|
describe ConsoleCounts do
|
7
|
-
it
|
7
|
+
it 'works for zero' do
|
8
8
|
config = Configuration.new
|
9
9
|
counts = ConsoleCounts.new(config)
|
10
10
|
expect(counts.to_s).to eq "0 scenarios\n0 steps"
|
@@ -7,15 +7,15 @@ module Cucumber
|
|
7
7
|
describe Duration do
|
8
8
|
include Duration
|
9
9
|
|
10
|
-
it
|
10
|
+
it 'formats ms' do
|
11
11
|
expect(format_duration(0.002103)).to eq '0m0.002s'
|
12
12
|
end
|
13
13
|
|
14
|
-
it
|
14
|
+
it 'formats m' do
|
15
15
|
expect(format_duration(61.002503)).to eq'1m1.003s'
|
16
16
|
end
|
17
17
|
|
18
|
-
it
|
18
|
+
it 'formats h' do
|
19
19
|
expect(format_duration(3661.002503)).to eq '61m1.003s'
|
20
20
|
end
|
21
21
|
end
|
@@ -9,67 +9,67 @@ require 'cucumber'
|
|
9
9
|
require 'support/standard_step_actions'
|
10
10
|
|
11
11
|
module Cucumber::Formatter
|
12
|
-
describe FailFast do
|
12
|
+
describe FailFast do
|
13
13
|
include Cucumber::Core
|
14
14
|
include Cucumber::Core::Gherkin::Writer
|
15
15
|
|
16
16
|
let(:configuration) { Cucumber::Configuration.new }
|
17
17
|
before { FailFast.new(configuration) }
|
18
18
|
|
19
|
-
context 'failing scenario' do
|
20
|
-
before(:each) do
|
21
|
-
@gherkin = gherkin('foo.feature') do
|
22
|
-
feature do
|
23
|
-
scenario do
|
19
|
+
context 'failing scenario' do
|
20
|
+
before(:each) do
|
21
|
+
@gherkin = gherkin('foo.feature') do
|
22
|
+
feature do
|
23
|
+
scenario do
|
24
24
|
step 'failing'
|
25
25
|
end
|
26
26
|
|
27
|
-
scenario do
|
27
|
+
scenario do
|
28
28
|
step 'failing'
|
29
29
|
end
|
30
30
|
end
|
31
31
|
end
|
32
32
|
end
|
33
33
|
|
34
|
-
after(:each) do
|
34
|
+
after(:each) do
|
35
35
|
Cucumber.wants_to_quit = false
|
36
36
|
end
|
37
37
|
|
38
|
-
it 'sets Cucumber.wants_to_quit' do
|
38
|
+
it 'sets Cucumber.wants_to_quit' do
|
39
39
|
execute [@gherkin], [StandardStepActions.new], configuration.event_bus
|
40
40
|
expect(Cucumber.wants_to_quit).to be true
|
41
41
|
end
|
42
42
|
end
|
43
43
|
|
44
|
-
context 'passing scenario' do
|
45
|
-
before(:each) do
|
46
|
-
@gherkin = gherkin('foo.feature') do
|
47
|
-
feature do
|
48
|
-
scenario do
|
44
|
+
context 'passing scenario' do
|
45
|
+
before(:each) do
|
46
|
+
@gherkin = gherkin('foo.feature') do
|
47
|
+
feature do
|
48
|
+
scenario do
|
49
49
|
step 'passing'
|
50
50
|
end
|
51
51
|
end
|
52
52
|
end
|
53
53
|
end
|
54
54
|
|
55
|
-
it 'doesn\'t set Cucumber.wants_to_quit' do
|
55
|
+
it 'doesn\'t set Cucumber.wants_to_quit' do
|
56
56
|
execute [@gherkin], [StandardStepActions.new], configuration.event_bus
|
57
57
|
expect(Cucumber.wants_to_quit).to be_falsey
|
58
58
|
end
|
59
59
|
end
|
60
60
|
|
61
61
|
context 'undefined scenario' do
|
62
|
-
before(:each) do
|
63
|
-
@gherkin = gherkin('foo.feature') do
|
64
|
-
feature do
|
65
|
-
scenario do
|
62
|
+
before(:each) do
|
63
|
+
@gherkin = gherkin('foo.feature') do
|
64
|
+
feature do
|
65
|
+
scenario do
|
66
66
|
step 'undefined'
|
67
67
|
end
|
68
68
|
end
|
69
69
|
end
|
70
70
|
end
|
71
71
|
|
72
|
-
it 'doesn\'t set Cucumber.wants_to_quit' do
|
72
|
+
it 'doesn\'t set Cucumber.wants_to_quit' do
|
73
73
|
execute [@gherkin], [StandardStepActions.new], configuration.event_bus
|
74
74
|
expect(Cucumber.wants_to_quit).to be_falsey
|
75
75
|
end
|
@@ -77,7 +77,7 @@ module Cucumber::Formatter
|
|
77
77
|
context 'in strict mode' do
|
78
78
|
let(:configuration) { Cucumber::Configuration.new strict: true }
|
79
79
|
|
80
|
-
it 'sets Cucumber.wants_to_quit' do
|
80
|
+
it 'sets Cucumber.wants_to_quit' do
|
81
81
|
execute [@gherkin], [StandardStepActions.new], configuration.event_bus
|
82
82
|
expect(Cucumber.wants_to_quit).to be_truthy
|
83
83
|
end
|