cucumber-gherkin 18.1.0 → 19.0.3
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 +4 -4
- data/README.md +3 -3
- data/bin/gherkin +6 -28
- data/lib/gherkin.rb +3 -3
- data/lib/gherkin/ast_builder.rb +45 -46
- data/lib/gherkin/gherkin-languages.json +4 -3
- data/lib/gherkin/gherkin_line.rb +1 -1
- data/lib/gherkin/parser.rb +52 -104
- data/lib/gherkin/pickles/compiler.rb +73 -73
- data/lib/gherkin/query.rb +16 -16
- data/lib/gherkin/stream/parser_message_stream.rb +19 -19
- data/lib/gherkin/token_scanner.rb +1 -1
- data/spec/gherkin/query_spec.rb +29 -32
- data/spec/gherkin/stream/parser_message_stream_spec.rb +6 -6
- metadata +9 -12
- data/lib/gherkin/stream/subprocess_message_stream.rb +0 -26
- data/spec/gherkin/stream/subprocess_message_stream_spec.rb +0 -18
@@ -8,10 +8,10 @@ module Gherkin
|
|
8
8
|
def compile(gherkin_document, source)
|
9
9
|
pickles = []
|
10
10
|
|
11
|
-
return pickles unless gherkin_document
|
12
|
-
feature = gherkin_document
|
13
|
-
language = feature
|
14
|
-
tags = feature
|
11
|
+
return pickles unless gherkin_document[:feature]
|
12
|
+
feature = gherkin_document[:feature]
|
13
|
+
language = feature[:language]
|
14
|
+
tags = feature[:tags]
|
15
15
|
|
16
16
|
compile_feature(pickles, language, tags, feature, source)
|
17
17
|
pickles
|
@@ -21,14 +21,14 @@ module Gherkin
|
|
21
21
|
|
22
22
|
def compile_feature(pickles, language, tags, feature, source)
|
23
23
|
feature_background_steps = []
|
24
|
-
feature
|
25
|
-
if child
|
26
|
-
feature_background_steps.concat(child
|
27
|
-
elsif child
|
28
|
-
compile_rule(pickles, language, tags, feature_background_steps, child
|
24
|
+
feature[:children].each do |child|
|
25
|
+
if child[:background]
|
26
|
+
feature_background_steps.concat(child[:background][:steps])
|
27
|
+
elsif child[:rule]
|
28
|
+
compile_rule(pickles, language, tags, feature_background_steps, child[:rule], source)
|
29
29
|
else
|
30
|
-
scenario = child
|
31
|
-
if scenario
|
30
|
+
scenario = child[:scenario]
|
31
|
+
if scenario[:examples].empty?
|
32
32
|
compile_scenario(tags, feature_background_steps, scenario, language, pickles, source)
|
33
33
|
else
|
34
34
|
compile_scenario_outline(tags, feature_background_steps, scenario, language, pickles, source)
|
@@ -38,15 +38,15 @@ module Gherkin
|
|
38
38
|
end
|
39
39
|
|
40
40
|
def compile_rule(pickles, language, feature_tags, feature_background_steps, rule, source)
|
41
|
-
tags = [].concat(feature_tags).concat(rule
|
41
|
+
tags = [].concat(feature_tags).concat(rule[:tags])
|
42
42
|
|
43
43
|
rule_background_steps = feature_background_steps.dup
|
44
|
-
rule
|
45
|
-
if child
|
46
|
-
rule_background_steps.concat(child
|
44
|
+
rule[:children].each do |child|
|
45
|
+
if child[:background]
|
46
|
+
rule_background_steps.concat(child[:background][:steps])
|
47
47
|
else
|
48
|
-
scenario = child
|
49
|
-
if scenario
|
48
|
+
scenario = child[:scenario]
|
49
|
+
if scenario[:examples].empty?
|
50
50
|
compile_scenario(tags, rule_background_steps, scenario, language, pickles, source)
|
51
51
|
else
|
52
52
|
compile_scenario_outline(tags, rule_background_steps, scenario, language, pickles, source)
|
@@ -56,51 +56,51 @@ module Gherkin
|
|
56
56
|
end
|
57
57
|
|
58
58
|
def compile_scenario(inherited_tags, background_steps, scenario, language, pickles, source)
|
59
|
-
steps = scenario
|
59
|
+
steps = scenario[:steps].empty? ? [] : [].concat(pickle_steps(background_steps))
|
60
60
|
|
61
|
-
tags = [].concat(inherited_tags).concat(scenario
|
61
|
+
tags = [].concat(inherited_tags).concat(scenario[:tags])
|
62
62
|
|
63
|
-
scenario
|
63
|
+
scenario[:steps].each do |step|
|
64
64
|
steps.push(pickle_step(step))
|
65
65
|
end
|
66
66
|
|
67
|
-
pickle =
|
68
|
-
uri: source
|
67
|
+
pickle = {
|
68
|
+
uri: source[:uri],
|
69
69
|
id: @id_generator.new_id,
|
70
70
|
tags: pickle_tags(tags),
|
71
|
-
name: scenario
|
71
|
+
name: scenario[:name],
|
72
72
|
language: language,
|
73
|
-
|
73
|
+
astNodeIds: [scenario[:id]],
|
74
74
|
steps: steps
|
75
|
-
|
75
|
+
}
|
76
76
|
pickles.push(pickle)
|
77
77
|
end
|
78
78
|
|
79
79
|
def compile_scenario_outline(inherited_tags, background_steps, scenario, language, pickles, source)
|
80
|
-
scenario
|
81
|
-
variable_cells = examples
|
82
|
-
examples.
|
83
|
-
value_cells = values_row
|
84
|
-
steps = scenario
|
85
|
-
tags = [].concat(inherited_tags).concat(scenario
|
86
|
-
|
87
|
-
scenario
|
88
|
-
|
89
|
-
steps.push(
|
80
|
+
scenario[:examples].reject { |examples| examples[:tableHeader].nil? }.each do |examples|
|
81
|
+
variable_cells = examples[:tableHeader][:cells]
|
82
|
+
examples[:tableBody].each do |values_row|
|
83
|
+
value_cells = values_row[:cells]
|
84
|
+
steps = scenario[:steps].empty? ? [] : [].concat(pickle_steps(background_steps))
|
85
|
+
tags = [].concat(inherited_tags).concat(scenario[:tags]).concat(examples[:tags])
|
86
|
+
|
87
|
+
scenario[:steps].each do |scenario_step|
|
88
|
+
step = pickle_step_props(scenario_step, variable_cells, values_row)
|
89
|
+
steps.push(step)
|
90
90
|
end
|
91
91
|
|
92
|
-
pickle =
|
93
|
-
uri: source
|
92
|
+
pickle = {
|
93
|
+
uri: source[:uri],
|
94
94
|
id: @id_generator.new_id,
|
95
|
-
name: interpolate(scenario
|
95
|
+
name: interpolate(scenario[:name], variable_cells, value_cells),
|
96
96
|
language: language,
|
97
97
|
steps: steps,
|
98
98
|
tags: pickle_tags(tags),
|
99
|
-
|
100
|
-
scenario
|
101
|
-
values_row
|
99
|
+
astNodeIds: [
|
100
|
+
scenario[:id],
|
101
|
+
values_row[:id]
|
102
102
|
],
|
103
|
-
|
103
|
+
}
|
104
104
|
pickles.push(pickle)
|
105
105
|
|
106
106
|
end
|
@@ -110,7 +110,7 @@ module Gherkin
|
|
110
110
|
def interpolate(name, variable_cells, value_cells)
|
111
111
|
variable_cells.each_with_index do |variable_cell, n|
|
112
112
|
value_cell = value_cells[n]
|
113
|
-
name = name.gsub('<' + variable_cell
|
113
|
+
name = name.gsub('<' + variable_cell[:value] + '>', value_cell[:value])
|
114
114
|
end
|
115
115
|
name
|
116
116
|
end
|
@@ -122,57 +122,57 @@ module Gherkin
|
|
122
122
|
end
|
123
123
|
|
124
124
|
def pickle_step(step)
|
125
|
-
|
125
|
+
pickle_step_props(step, [], nil)
|
126
126
|
end
|
127
127
|
|
128
128
|
def pickle_step_props(step, variable_cells, values_row)
|
129
|
-
value_cells = values_row ? values_row
|
129
|
+
value_cells = values_row ? values_row[:cells] : []
|
130
130
|
props = {
|
131
131
|
id: @id_generator.new_id,
|
132
|
-
|
133
|
-
text: interpolate(step
|
132
|
+
astNodeIds: [step[:id]],
|
133
|
+
text: interpolate(step[:text], variable_cells, value_cells),
|
134
134
|
}
|
135
135
|
if values_row
|
136
|
-
props[:
|
136
|
+
props[:astNodeIds].push(values_row[:id])
|
137
137
|
end
|
138
138
|
|
139
|
-
if step
|
140
|
-
data_table =
|
141
|
-
|
142
|
-
|
139
|
+
if step[:dataTable]
|
140
|
+
data_table = {
|
141
|
+
dataTable: pickle_data_table(step[:dataTable], variable_cells, value_cells)
|
142
|
+
}
|
143
143
|
props[:argument] = data_table
|
144
144
|
end
|
145
|
-
if step
|
146
|
-
doc_string =
|
147
|
-
|
148
|
-
|
145
|
+
if step[:docString]
|
146
|
+
doc_string = {
|
147
|
+
docString: pickle_doc_string(step[:docString], variable_cells, value_cells)
|
148
|
+
}
|
149
149
|
props[:argument] = doc_string
|
150
150
|
end
|
151
151
|
props
|
152
152
|
end
|
153
153
|
|
154
154
|
def pickle_data_table(data_table, variable_cells, value_cells)
|
155
|
-
|
156
|
-
rows: data_table
|
157
|
-
|
158
|
-
cells: row
|
159
|
-
|
160
|
-
value: interpolate(cell
|
161
|
-
|
155
|
+
{
|
156
|
+
rows: data_table[:rows].map do |row|
|
157
|
+
{
|
158
|
+
cells: row[:cells].map do |cell|
|
159
|
+
{
|
160
|
+
value: interpolate(cell[:value], variable_cells, value_cells)
|
161
|
+
}
|
162
162
|
end
|
163
|
-
|
163
|
+
}
|
164
164
|
end
|
165
|
-
|
165
|
+
}
|
166
166
|
end
|
167
167
|
|
168
168
|
def pickle_doc_string(doc_string, variable_cells, value_cells)
|
169
169
|
props = {
|
170
|
-
content: interpolate(doc_string
|
170
|
+
content: interpolate(doc_string[:content], variable_cells, value_cells)
|
171
171
|
}
|
172
|
-
if doc_string
|
173
|
-
props[:
|
172
|
+
if doc_string[:mediaType]
|
173
|
+
props[:mediaType] = interpolate(doc_string[:mediaType], variable_cells, value_cells)
|
174
174
|
end
|
175
|
-
|
175
|
+
props
|
176
176
|
end
|
177
177
|
|
178
178
|
def pickle_tags(tags)
|
@@ -180,10 +180,10 @@ module Gherkin
|
|
180
180
|
end
|
181
181
|
|
182
182
|
def pickle_tag(tag)
|
183
|
-
|
184
|
-
name: tag
|
185
|
-
|
186
|
-
|
183
|
+
{
|
184
|
+
name: tag[:name],
|
185
|
+
astNodeId: tag[:id]
|
186
|
+
}
|
187
187
|
end
|
188
188
|
end
|
189
189
|
end
|
data/lib/gherkin/query.rb
CHANGED
@@ -5,7 +5,7 @@ module Gherkin
|
|
5
5
|
end
|
6
6
|
|
7
7
|
def update(message)
|
8
|
-
update_feature(message
|
8
|
+
update_feature(message[:gherkinDocument][:feature]) if message[:gherkinDocument]
|
9
9
|
end
|
10
10
|
|
11
11
|
def location(ast_node_id)
|
@@ -17,33 +17,33 @@ module Gherkin
|
|
17
17
|
|
18
18
|
def update_feature(feature)
|
19
19
|
return if feature.nil?
|
20
|
-
store_nodes_location(feature
|
20
|
+
store_nodes_location(feature[:tags])
|
21
21
|
|
22
|
-
feature
|
23
|
-
update_rule(child
|
24
|
-
update_background(child
|
25
|
-
update_scenario(child
|
22
|
+
feature[:children].each do |child|
|
23
|
+
update_rule(child[:rule]) if child[:rule]
|
24
|
+
update_background(child[:background]) if child[:background]
|
25
|
+
update_scenario(child[:scenario]) if child[:scenario]
|
26
26
|
end
|
27
27
|
end
|
28
28
|
|
29
29
|
def update_rule(rule)
|
30
|
-
rule
|
31
|
-
update_background(child
|
32
|
-
update_scenario(child
|
30
|
+
rule[:children].each do |child|
|
31
|
+
update_background(child[:background]) if child[:background]
|
32
|
+
update_scenario(child[:scenario]) if child[:scenario]
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
36
|
def update_background(background)
|
37
|
-
update_steps(background
|
37
|
+
update_steps(background[:steps])
|
38
38
|
end
|
39
39
|
|
40
40
|
def update_scenario(scenario)
|
41
41
|
store_node_location(scenario)
|
42
|
-
store_nodes_location(scenario
|
43
|
-
update_steps(scenario
|
44
|
-
scenario
|
45
|
-
store_nodes_location(examples
|
46
|
-
store_nodes_location(examples
|
42
|
+
store_nodes_location(scenario[:tags])
|
43
|
+
update_steps(scenario[:steps])
|
44
|
+
scenario[:examples].each do |examples|
|
45
|
+
store_nodes_location(examples[:tags] || [])
|
46
|
+
store_nodes_location(examples[:tableBody] || [])
|
47
47
|
end
|
48
48
|
end
|
49
49
|
|
@@ -56,7 +56,7 @@ module Gherkin
|
|
56
56
|
end
|
57
57
|
|
58
58
|
def store_node_location(node)
|
59
|
-
@ast_node_locations[node
|
59
|
+
@ast_node_locations[node[:id]] = node[:location]
|
60
60
|
end
|
61
61
|
end
|
62
62
|
end
|
@@ -23,25 +23,25 @@ module Gherkin
|
|
23
23
|
enumerated = true
|
24
24
|
|
25
25
|
sources.each do |source|
|
26
|
-
y.yield(
|
26
|
+
y.yield({source: source}) if @options[:include_source]
|
27
27
|
begin
|
28
28
|
gherkin_document = nil
|
29
29
|
|
30
30
|
if @options[:include_gherkin_document]
|
31
31
|
gherkin_document = build_gherkin_document(source)
|
32
|
-
y.yield(
|
32
|
+
y.yield({gherkinDocument: gherkin_document})
|
33
33
|
end
|
34
34
|
if @options[:include_pickles]
|
35
35
|
gherkin_document ||= build_gherkin_document(source)
|
36
36
|
pickles = @compiler.compile(gherkin_document, source)
|
37
37
|
pickles.each do |pickle|
|
38
|
-
y.yield(
|
38
|
+
y.yield({pickle: pickle})
|
39
39
|
end
|
40
40
|
end
|
41
41
|
rescue CompositeParserException => err
|
42
|
-
yield_parse_errors(y, err.errors, source
|
42
|
+
yield_parse_errors(y, err.errors, source[:uri])
|
43
43
|
rescue ParserException => err
|
44
|
-
yield_parse_errors(y, [err], source
|
44
|
+
yield_parse_errors(y, [err], source[:uri])
|
45
45
|
end
|
46
46
|
end
|
47
47
|
end
|
@@ -51,28 +51,28 @@ module Gherkin
|
|
51
51
|
|
52
52
|
def yield_parse_errors(y, errors, uri)
|
53
53
|
errors.each do |err|
|
54
|
-
parse_error =
|
55
|
-
source:
|
54
|
+
parse_error = {
|
55
|
+
source: {
|
56
56
|
uri: uri,
|
57
|
-
location:
|
57
|
+
location: {
|
58
58
|
line: err.location[:line],
|
59
59
|
column: err.location[:column]
|
60
|
-
|
61
|
-
|
60
|
+
}.delete_if {|k,v| v.nil?}
|
61
|
+
},
|
62
62
|
message: err.message
|
63
|
-
|
64
|
-
y.yield(
|
63
|
+
}
|
64
|
+
y.yield({parseError: parse_error})
|
65
65
|
end
|
66
66
|
end
|
67
67
|
|
68
68
|
def sources
|
69
69
|
Enumerator.new do |y|
|
70
70
|
@paths.each do |path|
|
71
|
-
source =
|
71
|
+
source = {
|
72
72
|
uri: path,
|
73
73
|
data: File.open(path, 'r:UTF-8', &:read),
|
74
|
-
|
75
|
-
|
74
|
+
mediaType: 'text/x.cucumber.gherkin+plain'
|
75
|
+
}
|
76
76
|
y.yield(source)
|
77
77
|
end
|
78
78
|
@sources.each do |source|
|
@@ -84,12 +84,12 @@ module Gherkin
|
|
84
84
|
def build_gherkin_document(source)
|
85
85
|
if @options[:default_dialect]
|
86
86
|
token_matcher = TokenMatcher.new(@options[:default_dialect])
|
87
|
-
gd = @parser.parse(source
|
87
|
+
gd = @parser.parse(source[:data], token_matcher)
|
88
88
|
else
|
89
|
-
gd = @parser.parse(source
|
89
|
+
gd = @parser.parse(source[:data])
|
90
90
|
end
|
91
|
-
gd[:uri] = source
|
92
|
-
|
91
|
+
gd[:uri] = source[:uri]
|
92
|
+
gd
|
93
93
|
end
|
94
94
|
end
|
95
95
|
end
|
@@ -25,7 +25,7 @@ module Gherkin
|
|
25
25
|
end
|
26
26
|
|
27
27
|
def read
|
28
|
-
location = {line: @line_number += 1
|
28
|
+
location = {line: @line_number += 1}
|
29
29
|
if @io.nil? || line = @io.gets
|
30
30
|
gherkin_line = line ? GherkinLine.new(line, location[:line]) : nil
|
31
31
|
Token.new(gherkin_line, location)
|
data/spec/gherkin/query_spec.rb
CHANGED
@@ -3,20 +3,17 @@ require 'gherkin'
|
|
3
3
|
require 'gherkin/query'
|
4
4
|
|
5
5
|
describe Gherkin::Query do
|
6
|
-
let(:subject) { Gherkin::Query.new
|
6
|
+
let(:subject) { Gherkin::Query.new }
|
7
7
|
|
8
8
|
def filter_messages_by_attribute(messages, attribute)
|
9
|
-
messages.map
|
10
|
-
return unless message.respond_to?(attribute)
|
11
|
-
message.send(attribute)
|
12
|
-
end.compact
|
9
|
+
messages.select { |message| message.has_key?(attribute) }.map { |message| message[attribute] }
|
13
10
|
end
|
14
11
|
|
15
12
|
def find_message_by_attribute(messages, attribute)
|
16
13
|
filter_messages_by_attribute(messages, attribute).first
|
17
14
|
end
|
18
15
|
|
19
|
-
let(:gherkin_document) { find_message_by_attribute(messages, :
|
16
|
+
let(:gherkin_document) { find_message_by_attribute(messages, :gherkinDocument) }
|
20
17
|
|
21
18
|
let(:messages) {
|
22
19
|
Gherkin.from_source(
|
@@ -80,8 +77,8 @@ describe Gherkin::Query do
|
|
80
77
|
}
|
81
78
|
end
|
82
79
|
|
83
|
-
let(:background) { find_message_by_attribute(gherkin_document
|
84
|
-
let(:scenarios) { filter_messages_by_attribute(gherkin_document
|
80
|
+
let(:background) { find_message_by_attribute(gherkin_document[:feature][:children], :background) }
|
81
|
+
let(:scenarios) { filter_messages_by_attribute(gherkin_document[:feature][:children], :scenario) }
|
85
82
|
let(:scenario) { scenarios.first }
|
86
83
|
|
87
84
|
it 'raises an exception when the AST node ID is unknown' do
|
@@ -89,68 +86,68 @@ describe Gherkin::Query do
|
|
89
86
|
end
|
90
87
|
|
91
88
|
it 'provides the location of a scenario' do
|
92
|
-
expect(subject.location(scenario
|
89
|
+
expect(subject.location(scenario[:id])).to eq(scenario[:location])
|
93
90
|
end
|
94
91
|
|
95
92
|
it 'provides the location of an examples table row' do
|
96
|
-
node = scenarios.last
|
97
|
-
expect(subject.location(node
|
93
|
+
node = scenarios.last[:examples].first[:tableBody].first
|
94
|
+
expect(subject.location(node[:id])).to eq(node[:location])
|
98
95
|
end
|
99
96
|
|
100
97
|
context 'when querying steps' do
|
101
|
-
let(:background_step) { background
|
102
|
-
let(:scenario_step) { scenario
|
98
|
+
let(:background_step) { background[:steps].first }
|
99
|
+
let(:scenario_step) { scenario[:steps].first }
|
103
100
|
|
104
101
|
it 'provides the location of a background step' do
|
105
|
-
expect(subject.location(background_step
|
102
|
+
expect(subject.location(background_step[:id])).to eq(background_step[:location])
|
106
103
|
end
|
107
104
|
|
108
105
|
it 'provides the location of a scenario step' do
|
109
|
-
expect(subject.location(scenario_step
|
106
|
+
expect(subject.location(scenario_step[:id])).to eq(scenario_step[:location])
|
110
107
|
end
|
111
108
|
end
|
112
109
|
|
113
110
|
context 'when querying tags' do
|
114
|
-
let(:feature_tag) { gherkin_document
|
115
|
-
let(:scenario_tag) { scenario
|
116
|
-
let(:example_tag) { scenarios.last
|
111
|
+
let(:feature_tag) { gherkin_document[:feature][:tags].first }
|
112
|
+
let(:scenario_tag) { scenario[:tags].first }
|
113
|
+
let(:example_tag) { scenarios.last[:examples].first[:tags].first }
|
117
114
|
|
118
115
|
it 'provides the location of a feature tags' do
|
119
|
-
expect(subject.location(feature_tag
|
116
|
+
expect(subject.location(feature_tag[:id])).to eq(feature_tag[:location])
|
120
117
|
end
|
121
118
|
|
122
119
|
it 'provides the location of a scenario tags' do
|
123
|
-
expect(subject.location(scenario_tag
|
120
|
+
expect(subject.location(scenario_tag[:id])).to eq(scenario_tag[:location])
|
124
121
|
end
|
125
122
|
|
126
123
|
it 'provides the location of a scenario example tags' do
|
127
|
-
expect(subject.location(example_tag
|
124
|
+
expect(subject.location(example_tag[:id])).to eq(example_tag[:location])
|
128
125
|
end
|
129
126
|
end
|
130
127
|
|
131
128
|
context 'when children are scoped in a Rule' do
|
132
|
-
let(:rule) { find_message_by_attribute(gherkin_document
|
133
|
-
let(:rule_background) { find_message_by_attribute(rule
|
134
|
-
let(:rule_background_step) { rule_background
|
135
|
-
let(:rule_scenario) { find_message_by_attribute(rule
|
136
|
-
let(:rule_scenario_step) { rule_scenario
|
137
|
-
let(:rule_scenario_tag) { rule_scenario
|
129
|
+
let(:rule) { find_message_by_attribute(gherkin_document[:feature][:children], :rule) }
|
130
|
+
let(:rule_background) { find_message_by_attribute(rule[:children], :background) }
|
131
|
+
let(:rule_background_step) { rule_background[:steps].first }
|
132
|
+
let(:rule_scenario) { find_message_by_attribute(rule[:children], :scenario) }
|
133
|
+
let(:rule_scenario_step) { rule_scenario[:steps].first }
|
134
|
+
let(:rule_scenario_tag) { rule_scenario[:tags].first }
|
138
135
|
|
139
136
|
it 'provides the location of a background step' do
|
140
|
-
expect(subject.location(rule_background_step
|
137
|
+
expect(subject.location(rule_background_step[:id])).to eq(rule_background_step[:location])
|
141
138
|
end
|
142
139
|
|
143
140
|
it 'provides the location of a scenario' do
|
144
|
-
expect(subject.location(rule_scenario
|
141
|
+
expect(subject.location(rule_scenario[:id])).to eq(rule_scenario[:location])
|
145
142
|
end
|
146
143
|
|
147
144
|
it 'provides the location of a scenario tag' do
|
148
|
-
expect(subject.location(rule_scenario_tag
|
145
|
+
expect(subject.location(rule_scenario_tag[:id])).to eq(rule_scenario_tag[:location])
|
149
146
|
end
|
150
147
|
|
151
148
|
it 'provides the location of a scenario step' do
|
152
|
-
expect(subject.location(rule_scenario_step
|
149
|
+
expect(subject.location(rule_scenario_step[:id])).to eq(rule_scenario_step[:location])
|
153
150
|
end
|
154
151
|
end
|
155
152
|
end
|
156
|
-
end
|
153
|
+
end
|