cucumber 3.0.2 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/CHANGELOG.md +216 -17
- data/CONTRIBUTING.md +4 -21
- data/README.md +8 -10
- data/bin/cucumber +1 -1
- data/lib/autotest/cucumber.rb +1 -0
- data/lib/autotest/cucumber_mixin.rb +35 -39
- data/lib/autotest/cucumber_rails.rb +1 -0
- data/lib/autotest/cucumber_rails_rspec.rb +1 -0
- data/lib/autotest/cucumber_rails_rspec2.rb +1 -0
- data/lib/autotest/cucumber_rspec.rb +1 -0
- data/lib/autotest/cucumber_rspec2.rb +1 -0
- data/lib/autotest/discover.rb +1 -0
- data/lib/cucumber.rb +2 -1
- data/lib/cucumber/cli/configuration.rb +6 -5
- data/lib/cucumber/cli/main.rb +14 -14
- data/lib/cucumber/cli/options.rb +113 -116
- data/lib/cucumber/cli/profile_loader.rb +50 -29
- data/lib/cucumber/cli/rerun_file.rb +1 -0
- data/lib/cucumber/configuration.rb +38 -29
- data/lib/cucumber/constantize.rb +8 -10
- data/lib/cucumber/core_ext/string.rb +1 -0
- data/lib/cucumber/deprecate.rb +32 -8
- data/lib/cucumber/encoding.rb +2 -1
- data/lib/cucumber/errors.rb +6 -7
- data/lib/cucumber/events.rb +14 -7
- data/lib/cucumber/events/envelope.rb +9 -0
- data/lib/cucumber/events/gherkin_source_parsed.rb +11 -0
- data/lib/cucumber/events/gherkin_source_read.rb +1 -4
- data/lib/cucumber/events/hook_test_step_created.rb +13 -0
- data/lib/cucumber/events/step_activated.rb +6 -6
- data/lib/cucumber/events/step_definition_registered.rb +4 -8
- data/lib/cucumber/events/test_case_created.rb +13 -0
- data/lib/cucumber/events/test_case_finished.rb +0 -4
- data/lib/cucumber/events/test_case_ready.rb +12 -0
- data/lib/cucumber/events/test_case_started.rb +0 -4
- data/lib/cucumber/events/test_run_finished.rb +2 -3
- data/lib/cucumber/events/test_run_started.rb +2 -4
- data/lib/cucumber/events/test_step_created.rb +13 -0
- data/lib/cucumber/events/test_step_finished.rb +0 -4
- data/lib/cucumber/events/test_step_started.rb +1 -5
- data/lib/cucumber/events/undefined_parameter_type.rb +10 -0
- data/lib/cucumber/file_specs.rb +7 -6
- data/lib/cucumber/filters.rb +2 -0
- data/lib/cucumber/filters/activate_steps.rb +6 -4
- data/lib/cucumber/filters/apply_after_hooks.rb +1 -0
- data/lib/cucumber/filters/apply_after_step_hooks.rb +1 -0
- data/lib/cucumber/filters/apply_around_hooks.rb +1 -0
- data/lib/cucumber/filters/apply_before_hooks.rb +1 -0
- data/lib/cucumber/filters/broadcast_test_case_ready_event.rb +12 -0
- data/lib/cucumber/filters/broadcast_test_run_started_event.rb +2 -1
- data/lib/cucumber/filters/gated_receiver.rb +1 -2
- data/lib/cucumber/filters/prepare_world.rb +6 -13
- data/lib/cucumber/filters/quit.rb +3 -6
- data/lib/cucumber/filters/randomizer.rb +6 -7
- data/lib/cucumber/filters/retry.rb +2 -2
- data/lib/cucumber/filters/tag_limits.rb +2 -2
- data/lib/cucumber/filters/tag_limits/test_case_index.rb +1 -2
- data/lib/cucumber/filters/tag_limits/verifier.rb +3 -6
- data/lib/cucumber/formatter/ansicolor.rb +33 -37
- data/lib/cucumber/formatter/ast_lookup.rb +165 -0
- data/lib/cucumber/formatter/backtrace_filter.rb +10 -10
- data/lib/cucumber/formatter/console.rb +65 -74
- data/lib/cucumber/formatter/console_counts.rb +4 -9
- data/lib/cucumber/formatter/console_issues.rb +9 -6
- data/lib/cucumber/formatter/duration.rb +2 -1
- data/lib/cucumber/formatter/duration_extractor.rb +4 -2
- data/lib/cucumber/formatter/errors.rb +6 -0
- data/lib/cucumber/formatter/fail_fast.rb +9 -6
- data/lib/cucumber/formatter/fanout.rb +3 -3
- data/lib/cucumber/formatter/html.rb +11 -602
- data/lib/cucumber/formatter/http_io.rb +146 -0
- data/lib/cucumber/formatter/ignore_missing_messages.rb +2 -3
- data/lib/cucumber/formatter/interceptor.rb +11 -18
- data/lib/cucumber/formatter/io.rb +18 -11
- data/lib/cucumber/formatter/json.rb +102 -109
- data/lib/cucumber/formatter/junit.rb +73 -68
- data/lib/cucumber/formatter/message.rb +22 -0
- data/lib/cucumber/formatter/message_builder.rb +255 -0
- data/lib/cucumber/formatter/pretty.rb +360 -153
- data/lib/cucumber/formatter/progress.rb +31 -32
- data/lib/cucumber/formatter/query/hook_by_test_step.rb +31 -0
- data/lib/cucumber/formatter/query/pickle_by_test.rb +26 -0
- data/lib/cucumber/formatter/query/pickle_step_by_test_step.rb +26 -0
- data/lib/cucumber/formatter/query/step_definitions_by_test_step.rb +40 -0
- data/lib/cucumber/formatter/query/test_case_started_by_test_case.rb +40 -0
- data/lib/cucumber/formatter/rerun.rb +23 -4
- data/lib/cucumber/formatter/stepdefs.rb +2 -2
- data/lib/cucumber/formatter/steps.rb +4 -5
- data/lib/cucumber/formatter/summary.rb +17 -9
- data/lib/cucumber/formatter/unicode.rb +16 -18
- data/lib/cucumber/formatter/usage.rb +30 -26
- data/lib/cucumber/gherkin/data_table_parser.rb +18 -6
- data/lib/cucumber/gherkin/formatter/ansi_escapes.rb +83 -86
- data/lib/cucumber/gherkin/formatter/escaping.rb +13 -12
- data/lib/cucumber/gherkin/i18n.rb +1 -0
- data/lib/cucumber/gherkin/steps_parser.rb +18 -8
- data/lib/cucumber/glue/dsl.rb +2 -1
- data/lib/cucumber/glue/hook.rb +35 -11
- data/lib/cucumber/glue/invoke_in_world.rb +15 -20
- data/lib/cucumber/glue/proto_world.rb +47 -39
- data/lib/cucumber/glue/registry_and_more.rb +54 -23
- data/lib/cucumber/glue/snippet.rb +24 -27
- data/lib/cucumber/glue/step_definition.rb +51 -28
- data/lib/cucumber/glue/world_factory.rb +1 -3
- data/lib/cucumber/hooks.rb +24 -14
- data/lib/cucumber/load_path.rb +1 -0
- data/lib/cucumber/multiline_argument.rb +6 -8
- data/lib/cucumber/multiline_argument/data_table.rb +106 -73
- data/lib/cucumber/multiline_argument/data_table/diff_matrices.rb +8 -11
- data/lib/cucumber/multiline_argument/doc_string.rb +2 -1
- data/lib/cucumber/platform.rb +4 -3
- data/lib/cucumber/project_initializer.rb +1 -1
- data/lib/cucumber/rake/task.rb +21 -18
- data/lib/cucumber/rspec/disable_option_parser.rb +10 -8
- data/lib/cucumber/rspec/doubles.rb +1 -0
- data/lib/cucumber/running_test_case.rb +4 -54
- data/lib/cucumber/runtime.rb +57 -61
- data/lib/cucumber/runtime/after_hooks.rb +9 -4
- data/lib/cucumber/runtime/before_hooks.rb +9 -4
- data/lib/cucumber/runtime/for_programming_languages.rb +12 -9
- data/lib/cucumber/runtime/step_hooks.rb +5 -2
- data/lib/cucumber/runtime/support_code.rb +16 -22
- data/lib/cucumber/runtime/user_interface.rb +8 -19
- data/lib/cucumber/step_definition_light.rb +6 -4
- data/lib/cucumber/step_definitions.rb +3 -2
- data/lib/cucumber/step_match.rb +20 -18
- data/lib/cucumber/step_match_search.rb +9 -9
- data/lib/cucumber/term/ansicolor.rb +39 -39
- data/lib/cucumber/unit.rb +1 -0
- data/lib/cucumber/version +1 -1
- data/lib/simplecov_setup.rb +1 -0
- metadata +214 -127
- data/lib/cucumber/formatter/cucumber.css +0 -286
- data/lib/cucumber/formatter/cucumber.sass +0 -247
- data/lib/cucumber/formatter/hook_query_visitor.rb +0 -41
- data/lib/cucumber/formatter/html_builder.rb +0 -120
- data/lib/cucumber/formatter/inline-js.js +0 -30
- 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 -1028
- data/lib/cucumber/formatter/legacy_api/ast.rb +0 -394
- data/lib/cucumber/formatter/legacy_api/results.rb +0 -50
- data/lib/cucumber/formatter/legacy_api/runtime_facade.rb +0 -32
- data/lib/cucumber/step_argument.rb +0 -24
@@ -1,16 +1,14 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
module Cucumber
|
3
4
|
module Filters
|
4
|
-
|
5
5
|
class Quit
|
6
|
-
def initialize(receiver=nil)
|
6
|
+
def initialize(receiver = nil)
|
7
7
|
@receiver = receiver
|
8
8
|
end
|
9
9
|
|
10
10
|
def test_case(test_case)
|
11
|
-
unless Cucumber.wants_to_quit
|
12
|
-
test_case.describe_to @receiver
|
13
|
-
end
|
11
|
+
test_case.describe_to @receiver unless Cucumber.wants_to_quit
|
14
12
|
self
|
15
13
|
end
|
16
14
|
|
@@ -23,6 +21,5 @@ module Cucumber
|
|
23
21
|
self.class.new(receiver)
|
24
22
|
end
|
25
23
|
end
|
26
|
-
|
27
24
|
end
|
28
25
|
end
|
@@ -1,12 +1,12 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
require 'digest/sha2'
|
3
4
|
|
4
5
|
module Cucumber
|
5
6
|
module Filters
|
6
|
-
|
7
|
-
# Batches up all test cases, randomizes them, and then sends them on
|
7
|
+
# Batches up all test cases, randomizes them, and then sends them on
|
8
8
|
class Randomizer
|
9
|
-
def initialize(seed, receiver=nil)
|
9
|
+
def initialize(seed, receiver = nil)
|
10
10
|
@receiver = receiver
|
11
11
|
@test_cases = []
|
12
12
|
@seed = seed
|
@@ -33,14 +33,13 @@ module Cucumber
|
|
33
33
|
|
34
34
|
def shuffled_test_cases
|
35
35
|
digester = Digest::SHA2.new(256)
|
36
|
-
@test_cases.map.with_index
|
37
|
-
|
38
|
-
|
36
|
+
@test_cases.map.with_index
|
37
|
+
.sort_by { |_, index| digester.digest((@seed + index).to_s) }
|
38
|
+
.map { |test_case, _| test_case }
|
39
39
|
end
|
40
40
|
|
41
41
|
attr_reader :seed
|
42
42
|
private :seed
|
43
43
|
end
|
44
|
-
|
45
44
|
end
|
46
45
|
end
|
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
require 'cucumber/core/filter'
|
3
4
|
require 'cucumber/running_test_case'
|
4
5
|
require 'cucumber/events'
|
@@ -6,7 +7,6 @@ require 'cucumber/events'
|
|
6
7
|
module Cucumber
|
7
8
|
module Filters
|
8
9
|
class Retry < Core::Filter.new(:configuration)
|
9
|
-
|
10
10
|
def test_case(test_case)
|
11
11
|
configuration.on_event(:test_case_finished) do |event|
|
12
12
|
next unless retry_required?(test_case, event)
|
@@ -25,7 +25,7 @@ module Cucumber
|
|
25
25
|
end
|
26
26
|
|
27
27
|
def test_case_counts
|
28
|
-
@test_case_counts ||= Hash.new {|h,k| h[k] = 0 }
|
28
|
+
@test_case_counts ||= Hash.new { |h, k| h[k] = 0 }
|
29
29
|
end
|
30
30
|
end
|
31
31
|
end
|
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
require 'cucumber/filters/gated_receiver'
|
3
4
|
require 'cucumber/filters/tag_limits/test_case_index'
|
4
5
|
require 'cucumber/filters/tag_limits/verifier'
|
@@ -12,7 +13,7 @@ module Cucumber
|
|
12
13
|
end
|
13
14
|
|
14
15
|
class TagLimits
|
15
|
-
def initialize(tag_limits, receiver=nil)
|
16
|
+
def initialize(tag_limits, receiver = nil)
|
16
17
|
@tag_limits = tag_limits
|
17
18
|
@gated_receiver = GatedReceiver.new(receiver)
|
18
19
|
@test_case_index = TestCaseIndex.new
|
@@ -41,6 +42,5 @@ module Cucumber
|
|
41
42
|
attr_reader :test_case_index
|
42
43
|
attr_reader :verifier
|
43
44
|
end
|
44
|
-
|
45
45
|
end
|
46
46
|
end
|
@@ -1,8 +1,8 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
module Cucumber
|
3
4
|
module Filters
|
4
5
|
class TagLimits
|
5
|
-
|
6
6
|
class TestCaseIndex
|
7
7
|
def initialize
|
8
8
|
@index = Hash.new { |hash, key| hash[key] = [] }
|
@@ -26,7 +26,6 @@ module Cucumber
|
|
26
26
|
|
27
27
|
attr_accessor :index
|
28
28
|
end
|
29
|
-
|
30
29
|
end
|
31
30
|
end
|
32
31
|
end
|
@@ -1,8 +1,8 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
module Cucumber
|
3
4
|
module Filters
|
4
5
|
class TagLimits
|
5
|
-
|
6
6
|
class Verifier
|
7
7
|
def initialize(tag_limits)
|
8
8
|
@tag_limits = tag_limits
|
@@ -17,10 +17,8 @@ module Cucumber
|
|
17
17
|
|
18
18
|
def collect_breaches(test_case_index)
|
19
19
|
tag_limits.reduce([]) do |breaches, (tag_name, limit)|
|
20
|
-
breaches.tap do |
|
21
|
-
if test_case_index.count_by_tag_name(tag_name) > limit
|
22
|
-
breaches << Breach.new(tag_name, limit, test_case_index.locations_of_tag_name(tag_name))
|
23
|
-
end
|
20
|
+
breaches.tap do |breach|
|
21
|
+
breach << Breach.new(tag_name, limit, test_case_index.locations_of_tag_name(tag_name)) if test_case_index.count_by_tag_name(tag_name) > limit
|
24
22
|
end
|
25
23
|
end
|
26
24
|
end
|
@@ -53,7 +51,6 @@ module Cucumber
|
|
53
51
|
attr_reader :limit
|
54
52
|
attr_reader :locations
|
55
53
|
end
|
56
|
-
|
57
54
|
end
|
58
55
|
end
|
59
56
|
end
|
@@ -1,4 +1,5 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
+
|
2
3
|
require 'cucumber/platform'
|
3
4
|
require 'cucumber/term/ansicolor'
|
4
5
|
|
@@ -53,11 +54,9 @@ module Cucumber
|
|
53
54
|
module ANSIColor
|
54
55
|
include Cucumber::Term::ANSIColor
|
55
56
|
|
56
|
-
ALIASES = Hash.new do |h,k|
|
57
|
-
if k.to_s =~ /(.*)_param/
|
58
|
-
|
59
|
-
end
|
60
|
-
end.merge({
|
57
|
+
ALIASES = Hash.new do |h, k|
|
58
|
+
h[Regexp.last_match(1)] + ',bold' if k.to_s =~ /(.*)_param/
|
59
|
+
end.merge(
|
61
60
|
'undefined' => 'yellow',
|
62
61
|
'pending' => 'yellow',
|
63
62
|
'flaky' => 'yellow',
|
@@ -67,7 +66,7 @@ module Cucumber
|
|
67
66
|
'skipped' => 'cyan',
|
68
67
|
'comment' => 'grey',
|
69
68
|
'tag' => 'cyan'
|
70
|
-
|
69
|
+
)
|
71
70
|
|
72
71
|
if ENV['CUCUMBER_COLORS'] # Example: export CUCUMBER_COLORS="passed=red:failed=yellow"
|
73
72
|
ENV['CUCUMBER_COLORS'].split(':').each do |pair|
|
@@ -88,45 +87,42 @@ module Cucumber
|
|
88
87
|
# red(bold(string, &proc)) + red
|
89
88
|
# end
|
90
89
|
ALIASES.each_key do |method_name|
|
91
|
-
|
92
|
-
|
90
|
+
next if method_name =~ /.*_param/
|
91
|
+
code = <<-COLOR
|
93
92
|
def #{method_name}(string=nil, &proc)
|
94
|
-
#{ALIASES[method_name].split(
|
93
|
+
#{ALIASES[method_name].split(',').join('(') + '(string, &proc' + ')' * ALIASES[method_name].split(',').length}
|
95
94
|
end
|
96
95
|
# This resets the colour to the non-param colour
|
97
96
|
def #{method_name}_param(string=nil, &proc)
|
98
|
-
#{ALIASES[method_name+'_param'].split(
|
97
|
+
#{ALIASES[method_name + '_param'].split(',').join('(') + '(string, &proc' + ')' * ALIASES[method_name + '_param'].split(',').length} + #{ALIASES[method_name].split(',').join(' + ')}
|
99
98
|
end
|
100
|
-
|
101
|
-
|
102
|
-
end
|
99
|
+
COLOR
|
100
|
+
eval(code) # rubocop:disable Security/Eval
|
103
101
|
end
|
104
102
|
|
105
103
|
def self.define_grey #:nodoc:
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
define_real_grey
|
129
|
-
end
|
104
|
+
gem 'genki-ruby-terminfo'
|
105
|
+
require 'terminfo'
|
106
|
+
case TermInfo.default_object.tigetnum('colors')
|
107
|
+
when 0
|
108
|
+
raise "Your terminal doesn't support colours."
|
109
|
+
when 1
|
110
|
+
::Cucumber::Term::ANSIColor.coloring = false
|
111
|
+
alias_method :grey, :white
|
112
|
+
when 2..8
|
113
|
+
alias_method :grey, :white # rubocop:disable Lint/DuplicateMethods
|
114
|
+
else
|
115
|
+
define_real_grey
|
116
|
+
end
|
117
|
+
rescue Exception => e # rubocop:disable Lint/RescueException
|
118
|
+
if e.class.name == 'TermInfo::TermInfoError'
|
119
|
+
STDERR.puts '*** WARNING ***'
|
120
|
+
STDERR.puts "You have the genki-ruby-terminfo gem installed, but you haven't set your TERM variable."
|
121
|
+
STDERR.puts 'Try setting it to TERM=xterm-256color to get grey colour in output.'
|
122
|
+
STDERR.puts "\n"
|
123
|
+
alias_method :grey, :white
|
124
|
+
else
|
125
|
+
define_real_grey
|
130
126
|
end
|
131
127
|
end
|
132
128
|
|
@@ -0,0 +1,165 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Cucumber
|
4
|
+
module Formatter
|
5
|
+
class AstLookup
|
6
|
+
def initialize(config)
|
7
|
+
@gherkin_documents = {}
|
8
|
+
@test_case_lookups = {}
|
9
|
+
@test_step_lookups = {}
|
10
|
+
@step_keyword_lookups = {}
|
11
|
+
config.on_event :gherkin_source_parsed, &method(:on_gherkin_source_parsed)
|
12
|
+
end
|
13
|
+
|
14
|
+
def on_gherkin_source_parsed(event)
|
15
|
+
@gherkin_documents[event.gherkin_document.uri] = event.gherkin_document
|
16
|
+
end
|
17
|
+
|
18
|
+
def gherkin_document(uri)
|
19
|
+
@gherkin_documents[uri]
|
20
|
+
end
|
21
|
+
|
22
|
+
def scenario_source(test_case)
|
23
|
+
uri = test_case.location.file
|
24
|
+
@test_case_lookups[uri] ||= TestCaseLookupBuilder.new(gherkin_document(uri)).lookup_hash
|
25
|
+
@test_case_lookups[uri][test_case.location.lines.max]
|
26
|
+
end
|
27
|
+
|
28
|
+
def step_source(test_step)
|
29
|
+
uri = test_step.location.file
|
30
|
+
@test_step_lookups[uri] ||= TestStepLookupBuilder.new(gherkin_document(uri)).lookup_hash
|
31
|
+
@test_step_lookups[uri][test_step.location.lines.min]
|
32
|
+
end
|
33
|
+
|
34
|
+
def snippet_step_keyword(test_step)
|
35
|
+
uri = test_step.location.file
|
36
|
+
document = gherkin_document(uri)
|
37
|
+
dialect = ::Gherkin::Dialect.for(document.feature.language)
|
38
|
+
given_when_then_keywords = [dialect.given_keywords, dialect.when_keywords, dialect.then_keywords].flatten.uniq.reject { |kw| kw == '* ' }
|
39
|
+
keyword_lookup = step_keyword_lookup(uri)
|
40
|
+
keyword = nil
|
41
|
+
node = keyword_lookup[test_step.location.lines.min]
|
42
|
+
while keyword.nil?
|
43
|
+
if given_when_then_keywords.include?(node.keyword)
|
44
|
+
keyword = node.keyword
|
45
|
+
break
|
46
|
+
end
|
47
|
+
break if node.previous_node.nil?
|
48
|
+
node = node.previous_node
|
49
|
+
end
|
50
|
+
keyword = dialect.given_keywords.reject { |kw| kw == '* ' }[0] if keyword.nil?
|
51
|
+
keyword = Cucumber::Gherkin::I18n.code_keyword_for(keyword)
|
52
|
+
keyword
|
53
|
+
end
|
54
|
+
|
55
|
+
ScenarioSource = Struct.new(:type, :scenario)
|
56
|
+
|
57
|
+
ScenarioOutlineSource = Struct.new(:type, :scenario_outline, :examples, :row)
|
58
|
+
|
59
|
+
StepSource = Struct.new(:type, :step)
|
60
|
+
|
61
|
+
private
|
62
|
+
|
63
|
+
def step_keyword_lookup(uri)
|
64
|
+
@step_keyword_lookups[uri] ||= KeywordLookupBuilder.new(gherkin_document(uri)).lookup_hash
|
65
|
+
end
|
66
|
+
|
67
|
+
class TestCaseLookupBuilder
|
68
|
+
attr_reader :lookup_hash
|
69
|
+
|
70
|
+
def initialize(gherkin_document)
|
71
|
+
@lookup_hash = {}
|
72
|
+
process_scenario_container(gherkin_document.feature)
|
73
|
+
end
|
74
|
+
|
75
|
+
private
|
76
|
+
|
77
|
+
def process_scenario_container(container)
|
78
|
+
container.children.each do |child|
|
79
|
+
if child.respond_to?(:rule) && child.rule
|
80
|
+
process_scenario_container(child.rule)
|
81
|
+
elsif child.respond_to?(:scenario) && child.scenario
|
82
|
+
process_scenario(child)
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
87
|
+
def process_scenario(child)
|
88
|
+
if child.scenario.examples.empty?
|
89
|
+
@lookup_hash[child.scenario.location.line] = ScenarioSource.new(:Scenario, child.scenario)
|
90
|
+
else
|
91
|
+
child.scenario.examples.each do |examples|
|
92
|
+
examples.table_body.each do |row|
|
93
|
+
@lookup_hash[row.location.line] = ScenarioOutlineSource.new(:ScenarioOutline, child.scenario, examples, row)
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
100
|
+
class TestStepLookupBuilder
|
101
|
+
attr_reader :lookup_hash
|
102
|
+
|
103
|
+
def initialize(gherkin_document)
|
104
|
+
@lookup_hash = {}
|
105
|
+
process_scenario_container(gherkin_document.feature)
|
106
|
+
end
|
107
|
+
|
108
|
+
private
|
109
|
+
|
110
|
+
def process_scenario_container(container)
|
111
|
+
container.children.each do |child|
|
112
|
+
if child.respond_to?(:rule) && child.rule
|
113
|
+
process_scenario_container(child.rule)
|
114
|
+
elsif child.respond_to?(:scenario) && child.scenario
|
115
|
+
child.scenario.steps.each do |step|
|
116
|
+
@lookup_hash[step.location.line] = StepSource.new(:Step, step)
|
117
|
+
end
|
118
|
+
elsif !child.background.nil?
|
119
|
+
child.background.steps.each do |step|
|
120
|
+
@lookup_hash[step.location.line] = StepSource.new(:Step, step)
|
121
|
+
end
|
122
|
+
end
|
123
|
+
end
|
124
|
+
end
|
125
|
+
end
|
126
|
+
|
127
|
+
KeywordSearchNode = Struct.new(:keyword, :previous_node)
|
128
|
+
|
129
|
+
class KeywordLookupBuilder
|
130
|
+
attr_reader :lookup_hash
|
131
|
+
|
132
|
+
def initialize(gherkin_document)
|
133
|
+
@lookup_hash = {}
|
134
|
+
process_scenario_container(gherkin_document.feature, nil)
|
135
|
+
end
|
136
|
+
|
137
|
+
private
|
138
|
+
|
139
|
+
# rubocop:disable Metrics/PerceivedComplexity
|
140
|
+
def process_scenario_container(container, original_previous_node)
|
141
|
+
container.children.each do |child|
|
142
|
+
previous_node = original_previous_node
|
143
|
+
if child.respond_to?(:rule) && child.rule
|
144
|
+
process_scenario_container(child.rule, original_previous_node)
|
145
|
+
elsif child.respond_to?(:scenario) && child.scenario
|
146
|
+
child.scenario.steps.each do |step|
|
147
|
+
node = KeywordSearchNode.new(step.keyword, previous_node)
|
148
|
+
@lookup_hash[step.location.line] = node
|
149
|
+
previous_node = node
|
150
|
+
end
|
151
|
+
elsif child.respond_to?(:background) && child.background
|
152
|
+
child.background.steps.each do |step|
|
153
|
+
node = KeywordSearchNode.new(step.keyword, previous_node)
|
154
|
+
@lookup_hash[step.location.line] = node
|
155
|
+
previous_node = node
|
156
|
+
original_previous_node = previous_node
|
157
|
+
end
|
158
|
+
end
|
159
|
+
end
|
160
|
+
end
|
161
|
+
# rubocop:enable Metrics/PerceivedComplexity
|
162
|
+
end
|
163
|
+
end
|
164
|
+
end
|
165
|
+
end
|
@@ -1,25 +1,26 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
|
-
require 'cucumber/platform'
|
3
2
|
|
3
|
+
require 'cucumber/platform'
|
4
4
|
|
5
5
|
module Cucumber
|
6
6
|
module Formatter
|
7
|
-
@backtrace_filters = %w
|
7
|
+
@backtrace_filters = %w[
|
8
8
|
/vendor/rails
|
9
9
|
lib/cucumber
|
10
10
|
bin/cucumber:
|
11
11
|
lib/rspec
|
12
12
|
gems/
|
13
|
+
site_ruby/
|
13
14
|
minitest
|
14
15
|
test/unit
|
15
16
|
.gem/ruby
|
16
|
-
lib/ruby/
|
17
17
|
bin/bundle
|
18
|
-
|
18
|
+
]
|
19
19
|
|
20
|
-
if ::
|
21
|
-
|
22
|
-
|
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
|
23
24
|
|
24
25
|
BACKTRACE_FILTER_PATTERNS = Regexp.new(@backtrace_filters.join('|'))
|
25
26
|
|
@@ -31,7 +32,7 @@ module Cucumber
|
|
31
32
|
def exception
|
32
33
|
return @exception if ::Cucumber.use_full_backtrace
|
33
34
|
|
34
|
-
pwd_pattern = /#{::Regexp.escape(::Dir.pwd)}\//m
|
35
|
+
pwd_pattern = /#{::Regexp.escape(::Dir.pwd)}\//m # rubocop:disable Style/RegexpLiteral
|
35
36
|
backtrace = @exception.backtrace.map { |line| line.gsub(pwd_pattern, './') }
|
36
37
|
|
37
38
|
filtered = (backtrace || []).reject do |line|
|
@@ -41,7 +42,7 @@ module Cucumber
|
|
41
42
|
if ::ENV['CUCUMBER_TRUNCATE_OUTPUT']
|
42
43
|
# Strip off file locations
|
43
44
|
filtered = filtered.map do |line|
|
44
|
-
line =~ /(.*):in `/ ?
|
45
|
+
line =~ /(.*):in `/ ? Regexp.last_match(1) : line
|
45
46
|
end
|
46
47
|
end
|
47
48
|
|
@@ -49,6 +50,5 @@ module Cucumber
|
|
49
50
|
@exception
|
50
51
|
end
|
51
52
|
end
|
52
|
-
|
53
53
|
end
|
54
54
|
end
|