cucumber 2.0.0.beta.1 → 2.0.0.beta.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/History.md +13 -1
- data/cucumber.gemspec +1 -1
- data/features/docs/formatters/json_formatter.feature +61 -0
- data/features/docs/report_called_undefined_steps.feature +27 -27
- data/lib/cucumber/ast.rb +13 -0
- data/lib/cucumber/errors.rb +12 -11
- data/lib/cucumber/formatter/gherkin_formatter_adapter.rb +11 -6
- data/lib/cucumber/formatter/html.rb +4 -0
- data/lib/cucumber/formatter/rerun.rb +4 -0
- data/lib/cucumber/mappings.rb +10 -2
- data/lib/cucumber/multiline_argument.rb +1 -0
- data/lib/cucumber/platform.rb +1 -1
- data/lib/cucumber/rb_support/rb_world.rb +1 -1
- data/lib/cucumber/reports/legacy_formatter.rb +98 -75
- data/lib/cucumber/runtime/support_code.rb +3 -20
- data/spec/cucumber/formatter/html_spec.rb +33 -1
- data/spec/cucumber/mappings_spec.rb +51 -0
- data/spec/cucumber/rb_support/rb_step_definition_spec.rb +1 -1
- data/spec/cucumber/reports/legacy_formatter_spec.rb +111 -1
- metadata +9 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ec39cd25b8f17917a20fd5af809119a9ecad0671
|
4
|
+
data.tar.gz: 43aced438654c8263f00185586f45c42daeedab0
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 8b7126a89b0f2e88fc81dfbd3aebf4998928f8f49033ba67a453a74525234b1d73f811aba9346bafe2c0274fbc6cc8b4deb45c5a0a4411e54cbf47c3e5ece726
|
7
|
+
data.tar.gz: 4c81bc4dd772677dc1888a4da72eaf8401093440274faac071beb52f9dc320e481e6b34735486aec2e3c3b914d9096e3b273591265e379082447efa0f288a9d1
|
data/History.md
CHANGED
@@ -1,4 +1,14 @@
|
|
1
|
-
## [
|
1
|
+
## [In Git](https://github.com/cucumber/cucumber/compare/v.2.0.0.beta.1...master)
|
2
|
+
|
3
|
+
### Bugfixes
|
4
|
+
|
5
|
+
* Better reporting of exceptions in Before / After hooks ([723](https://github.com/cucumber/cucumber/pull/723) @mattwynne)
|
6
|
+
|
7
|
+
### New features
|
8
|
+
|
9
|
+
* Support embedding images directly in HTML and JSON reports ([696](https://github.com/cucumber/cucumber/pull/696),[695](https://github.com/cucumber/cucumber/pull/695/files) @brasmusson)
|
10
|
+
|
11
|
+
## [v2.0.0.beta.1 ](https://github.com/cucumber/cucumber/compare/v1.3.8...v.2.0.0.beta.1)
|
2
12
|
|
3
13
|
Version 2.0 contains a major internal redesign, extracting the core logic of
|
4
14
|
parsing and executing tests into a [separate gem](https://github.com/cucumber/cucumber-ruby-core).
|
@@ -13,6 +23,7 @@ all.
|
|
13
23
|
* Better snippet comment ([579](https://github.com/cucumber/cucumber/pull/579) Jeff Nyman)
|
14
24
|
* Random scenario ordering with `--order random`
|
15
25
|
* Embed plain text ([712](https://github.com/cucumber/cucumber/pull/712) @bingwei
|
26
|
+
* Support the cucumber-reporting tools also when using Scenario Outlines ([700](https://github.com/cucumber/cucumber/pull/700) @brasmusson
|
16
27
|
|
17
28
|
### Features removed
|
18
29
|
|
@@ -20,6 +31,7 @@ all.
|
|
20
31
|
* Remove support for i18n nested step methods (Matt Wynne)
|
21
32
|
* Remove experimental .js and .py support (Matt Wynne)
|
22
33
|
* Remove Ruby 1.8.7 support, including RCov
|
34
|
+
* Spork support
|
23
35
|
|
24
36
|
### API Changes
|
25
37
|
|
data/cucumber.gemspec
CHANGED
@@ -14,7 +14,7 @@ Gem::Specification.new do |s|
|
|
14
14
|
s.platform = Gem::Platform::RUBY
|
15
15
|
s.required_ruby_version = ">= 1.9.3"
|
16
16
|
|
17
|
-
s.add_dependency 'cucumber-core', '~> 1.0.0.beta.
|
17
|
+
s.add_dependency 'cucumber-core', '~> 1.0.0.beta.2'
|
18
18
|
s.add_dependency 'builder', '>= 2.1.2'
|
19
19
|
s.add_dependency 'diff-lcs', '>= 1.1.3'
|
20
20
|
s.add_dependency 'gherkin', '~> 2.12'
|
@@ -27,6 +27,11 @@ Feature: JSON output formatter
|
|
27
27
|
Given /^I print from step definition/ do
|
28
28
|
puts "from step definition"
|
29
29
|
end
|
30
|
+
|
31
|
+
Given /^I embed data directly/ do
|
32
|
+
data = "YWJj"
|
33
|
+
embed data, "mime-type;base64"
|
34
|
+
end
|
30
35
|
"""
|
31
36
|
And a file named "features/embed.feature" with:
|
32
37
|
"""
|
@@ -70,6 +75,14 @@ Feature: JSON output formatter
|
|
70
75
|
And I print from step definition
|
71
76
|
|
72
77
|
"""
|
78
|
+
And a file named "features/embed_data_directly.feature" with:
|
79
|
+
"""
|
80
|
+
Feature: An embed data directly feature
|
81
|
+
|
82
|
+
Scenario:
|
83
|
+
Given I embed data directly
|
84
|
+
|
85
|
+
"""
|
73
86
|
|
74
87
|
# Need to investigate why this won't pass in-process. error_message doesn't get det?
|
75
88
|
@spawn
|
@@ -586,3 +599,51 @@ Feature: JSON output formatter
|
|
586
599
|
]
|
587
600
|
|
588
601
|
"""
|
602
|
+
|
603
|
+
@spawn
|
604
|
+
Scenario: embedding data directly
|
605
|
+
When I run `cucumber -b --format json features/embed_data_directly.feature`
|
606
|
+
Then it should pass with JSON:
|
607
|
+
"""
|
608
|
+
[
|
609
|
+
{
|
610
|
+
"uri": "features/embed_data_directly.feature",
|
611
|
+
"id": "an-embed-data-directly-feature",
|
612
|
+
"keyword": "Feature",
|
613
|
+
"name": "An embed data directly feature",
|
614
|
+
"line": 1,
|
615
|
+
"description": "",
|
616
|
+
"elements": [
|
617
|
+
{
|
618
|
+
"id": "an-embed-data-directly-feature;",
|
619
|
+
"keyword": "Scenario",
|
620
|
+
"name": "",
|
621
|
+
"line": 3,
|
622
|
+
"description": "",
|
623
|
+
"type": "scenario",
|
624
|
+
"steps": [
|
625
|
+
{
|
626
|
+
"keyword": "Given ",
|
627
|
+
"name": "I embed data directly",
|
628
|
+
"line": 4,
|
629
|
+
"embeddings": [
|
630
|
+
{
|
631
|
+
"mime_type": "mime-type",
|
632
|
+
"data": "YWJj"
|
633
|
+
}
|
634
|
+
],
|
635
|
+
"match": {
|
636
|
+
"location": "features/step_definitions/json_steps.rb:10"
|
637
|
+
},
|
638
|
+
"result": {
|
639
|
+
"status": "passed",
|
640
|
+
"duration": 1
|
641
|
+
}
|
642
|
+
}
|
643
|
+
]
|
644
|
+
}
|
645
|
+
]
|
646
|
+
}
|
647
|
+
]
|
648
|
+
|
649
|
+
"""
|
@@ -2,56 +2,56 @@ Feature: Cucumber command line
|
|
2
2
|
In order to find out what step definitions need to be implemented
|
3
3
|
Developers should always see what step definition is missing
|
4
4
|
|
5
|
-
@wip-new-core
|
6
5
|
@spawn
|
7
6
|
Scenario: Get info at arbitrary levels of nesting
|
8
7
|
Given a file named "features/call_undefined_step_from_step_def.feature" with:
|
9
8
|
"""
|
10
9
|
Feature: Calling undefined step
|
11
10
|
|
11
|
+
Scenario: Call from feature
|
12
|
+
Given this directly called step does not exist
|
13
|
+
|
12
14
|
Scenario: Call directly
|
13
|
-
Given a step
|
15
|
+
Given a step that calls an undefined step
|
14
16
|
|
15
17
|
Scenario: Call via another
|
16
|
-
Given
|
18
|
+
Given a step that calls a step that calls an undefined step
|
17
19
|
"""
|
18
20
|
And a file named "features/step_definitions/steps.rb" with:
|
19
21
|
"""
|
20
|
-
Given /^a step
|
22
|
+
Given /^a step that calls an undefined step$/ do
|
21
23
|
step 'this does not exist'
|
22
24
|
end
|
23
25
|
|
24
|
-
Given /^
|
25
|
-
step
|
26
|
+
Given /^a step that calls a step that calls an undefined step$/ do
|
27
|
+
step 'a step that calls an undefined step'
|
26
28
|
end
|
27
29
|
"""
|
28
|
-
When I run `cucumber features/call_undefined_step_from_step_def.feature`
|
29
|
-
Then it should
|
30
|
+
When I run `cucumber --strict -q features/call_undefined_step_from_step_def.feature`
|
31
|
+
Then it should fail with exactly:
|
30
32
|
"""
|
31
33
|
Feature: Calling undefined step
|
32
34
|
|
33
|
-
Scenario: Call
|
34
|
-
Given
|
35
|
-
Undefined step: "this does not exist" (Cucumber::Undefined)
|
36
|
-
|
37
|
-
features/call_undefined_step_from_step_def.feature:4:in `Given a step definition that calls an undefined step'
|
35
|
+
Scenario: Call from feature
|
36
|
+
Given this directly called step does not exist
|
37
|
+
Undefined step: "this directly called step does not exist" (Cucumber::Undefined)
|
38
|
+
features/call_undefined_step_from_step_def.feature:4:in `Given this directly called step does not exist'
|
38
39
|
|
39
|
-
Scenario: Call
|
40
|
-
Given
|
40
|
+
Scenario: Call directly
|
41
|
+
Given a step that calls an undefined step
|
41
42
|
Undefined step: "this does not exist" (Cucumber::Undefined)
|
42
|
-
./features/step_definitions/steps.rb:2:in `/^a step
|
43
|
-
|
44
|
-
features/call_undefined_step_from_step_def.feature:7:in `Given call step "a step definition that calls an undefined step"'
|
43
|
+
./features/step_definitions/steps.rb:2:in `/^a step that calls an undefined step$/'
|
44
|
+
features/call_undefined_step_from_step_def.feature:7:in `Given a step that calls an undefined step'
|
45
45
|
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
46
|
+
Scenario: Call via another
|
47
|
+
Given a step that calls a step that calls an undefined step
|
48
|
+
Undefined step: "this does not exist" (Cucumber::Undefined)
|
49
|
+
./features/step_definitions/steps.rb:2:in `/^a step that calls an undefined step$/'
|
50
|
+
./features/step_definitions/steps.rb:6:in `/^a step that calls a step that calls an undefined step$/'
|
51
|
+
features/call_undefined_step_from_step_def.feature:10:in `Given a step that calls a step that calls an undefined step'
|
52
52
|
|
53
|
-
|
54
|
-
|
55
|
-
|
53
|
+
3 scenarios (3 undefined)
|
54
|
+
3 steps (3 undefined)
|
55
|
+
0m0.012s
|
56
56
|
|
57
57
|
"""
|
data/lib/cucumber/ast.rb
ADDED
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'cucumber/multiline_argument'
|
2
|
+
|
3
|
+
module Cucumber
|
4
|
+
module Ast
|
5
|
+
def self.const_missing(const_name)
|
6
|
+
if const_name == :Table
|
7
|
+
warn "`Cucumber::Ast::Table` has been deprecated. Use `Cucumber::MultilineArgument::DataTable` instead."
|
8
|
+
return Cucumber::MultilineArgument::DataTable
|
9
|
+
end
|
10
|
+
raise "`Cucumber::Ast` no longer exists. These classes have moved into the `Cucumber::Core::Ast` namespace, but may not have the same API."
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
data/lib/cucumber/errors.rb
CHANGED
@@ -2,20 +2,21 @@ require 'cucumber/core/test/result'
|
|
2
2
|
|
3
3
|
module Cucumber
|
4
4
|
# Raised when there is no matching StepDefinition for a step.
|
5
|
-
class Undefined <
|
6
|
-
|
5
|
+
class Undefined < Core::Test::Result::Undefined
|
6
|
+
def self.from(result, step_name)
|
7
|
+
if result.is_a?(self)
|
8
|
+
return result.with_message(with_prefix(result.message))
|
9
|
+
end
|
7
10
|
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
+
begin
|
12
|
+
raise self.new(with_prefix(step_name))
|
13
|
+
rescue => exception
|
14
|
+
return exception
|
15
|
+
end
|
11
16
|
end
|
12
17
|
|
13
|
-
def
|
14
|
-
|
15
|
-
end
|
16
|
-
|
17
|
-
def nested?
|
18
|
-
@nested
|
18
|
+
def self.with_prefix(step_name)
|
19
|
+
%(Undefined step: "#{step_name}")
|
19
20
|
end
|
20
21
|
end
|
21
22
|
|
@@ -146,15 +146,20 @@ module Cucumber
|
|
146
146
|
end
|
147
147
|
|
148
148
|
def embed(file, mime_type, label)
|
149
|
-
|
150
|
-
if File.exists?(file)
|
149
|
+
if File.file?(file)
|
151
150
|
data = File.open(file, 'rb') { |f| f.read }
|
152
|
-
|
153
|
-
if
|
154
|
-
|
151
|
+
else
|
152
|
+
if mime_type =~ /;base64$/
|
153
|
+
mime_type = mime_type[0..-8]
|
154
|
+
data = Base64.decode64(file)
|
155
|
+
else
|
156
|
+
data = file
|
155
157
|
end
|
156
|
-
@gf.embedding(mime_type, data)
|
157
158
|
end
|
159
|
+
if defined?(JRUBY_VERSION)
|
160
|
+
data = data.to_java_bytes
|
161
|
+
end
|
162
|
+
@gf.embedding(mime_type, data)
|
158
163
|
end
|
159
164
|
|
160
165
|
def puts(message)
|
@@ -37,6 +37,10 @@ module Cucumber
|
|
37
37
|
def embed(src, mime_type, label)
|
38
38
|
case(mime_type)
|
39
39
|
when /^image\/(png|gif|jpg|jpeg)/
|
40
|
+
unless File.file?(src) or src =~ /^data:image\/(png|gif|jpg|jpeg);base64,/
|
41
|
+
type = mime_type =~ /;base[0-9]+$/ ? mime_type : mime_type + ";base64"
|
42
|
+
src = "data:" + type + "," + src
|
43
|
+
end
|
40
44
|
embed_image(src, label)
|
41
45
|
when /^text\/plain/
|
42
46
|
embed_text(src, label)
|
@@ -25,6 +25,10 @@ module Cucumber
|
|
25
25
|
def before_feature(feature_element)
|
26
26
|
@lines = []
|
27
27
|
@file = feature_element.file
|
28
|
+
# See https://github.com/cucumber/cucumber/issues/629
|
29
|
+
if @file.include?(' ')
|
30
|
+
warn("Filenames with spaces like '#{@file}' cause unexpected behaviour from the rerun formatter.")
|
31
|
+
end
|
28
32
|
end
|
29
33
|
|
30
34
|
def after_feature(*)
|
data/lib/cucumber/mappings.rb
CHANGED
@@ -84,7 +84,7 @@ module Cucumber
|
|
84
84
|
end
|
85
85
|
end
|
86
86
|
|
87
|
-
# adapts our test_case to look like the Cucumber Runtime's Scenario
|
87
|
+
# adapts our test_case to look like the Cucumber Runtime's old Scenario
|
88
88
|
class TestCase
|
89
89
|
def initialize(test_case, feature)
|
90
90
|
@test_case = test_case
|
@@ -95,6 +95,10 @@ module Cucumber
|
|
95
95
|
hook.tag_expressions.all? { |expression| @test_case.match_tags?(expression) }
|
96
96
|
end
|
97
97
|
|
98
|
+
def failed?
|
99
|
+
warn("Calling failed? on a scenario is not currently supported in Cucumber 2.0. Please see https://github.com/cucumber/cucumber/issues/726")
|
100
|
+
end
|
101
|
+
|
98
102
|
def language
|
99
103
|
@test_case.language
|
100
104
|
end
|
@@ -108,10 +112,14 @@ module Cucumber
|
|
108
112
|
end
|
109
113
|
|
110
114
|
def source_tags
|
111
|
-
warn('deprecated: call #tags instead')
|
115
|
+
#warn('deprecated: call #tags instead')
|
112
116
|
tags
|
113
117
|
end
|
114
118
|
|
119
|
+
def source_tag_names
|
120
|
+
tags.map &:name
|
121
|
+
end
|
122
|
+
|
115
123
|
def tags
|
116
124
|
@test_case.tags
|
117
125
|
end
|
data/lib/cucumber/platform.rb
CHANGED
@@ -4,7 +4,7 @@ require 'rbconfig'
|
|
4
4
|
|
5
5
|
module Cucumber
|
6
6
|
unless defined?(Cucumber::VERSION)
|
7
|
-
VERSION = '2.0.0.beta.
|
7
|
+
VERSION = '2.0.0.beta.2'
|
8
8
|
BINARY = File.expand_path(File.dirname(__FILE__) + '/../../bin/cucumber')
|
9
9
|
LIBDIR = File.expand_path(File.dirname(__FILE__) + '/../../lib')
|
10
10
|
JRUBY = defined?(JRUBY_VERSION)
|
@@ -39,7 +39,7 @@ module Cucumber
|
|
39
39
|
# TODO: this argument parsing should move up out of core
|
40
40
|
location = Core::Ast::Location.new(*caller[0].split(':')[0..1])
|
41
41
|
core_multiline_arg = Core::Ast::MultilineArgument.from(raw_multiline_arg, location)
|
42
|
-
@__cucumber_runtime.invoke(name, MultilineArgument.from(core_multiline_arg))
|
42
|
+
@__cucumber_runtime.invoke(name, MultilineArgument.from(core_multiline_arg), location)
|
43
43
|
end
|
44
44
|
|
45
45
|
# Run a snippet of Gherkin
|
@@ -34,21 +34,12 @@ module Cucumber
|
|
34
34
|
extend Forwardable
|
35
35
|
|
36
36
|
def_delegators :formatter,
|
37
|
-
:embed,
|
38
37
|
:ask
|
39
|
-
:puts
|
40
38
|
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
def before_test_step(test_step)
|
46
|
-
printer.before_test_step(test_step)
|
47
|
-
end
|
48
|
-
|
49
|
-
def after_test_step(test_step, result)
|
50
|
-
printer.after_test_step(test_step, result)
|
51
|
-
end
|
39
|
+
def_delegators :printer,
|
40
|
+
:before_test_case,
|
41
|
+
:before_test_step,
|
42
|
+
:after_test_step
|
52
43
|
|
53
44
|
def after_test_case(test_case, result)
|
54
45
|
record_test_case_result(test_case, result)
|
@@ -168,9 +159,16 @@ module Cucumber
|
|
168
159
|
|
169
160
|
require 'ostruct'
|
170
161
|
class StepSource < OpenStruct
|
171
|
-
|
172
162
|
def build_step_invocation(indent, runtime, messages, embeddings)
|
173
|
-
step_result.step_invocation(
|
163
|
+
step_result.step_invocation(
|
164
|
+
step_match(runtime),
|
165
|
+
step,
|
166
|
+
indent,
|
167
|
+
background,
|
168
|
+
runtime.configuration,
|
169
|
+
messages,
|
170
|
+
embeddings
|
171
|
+
)
|
174
172
|
end
|
175
173
|
|
176
174
|
private
|
@@ -180,7 +178,6 @@ module Cucumber
|
|
180
178
|
rescue Cucumber::Undefined
|
181
179
|
NoStepMatch.new(step, step.name)
|
182
180
|
end
|
183
|
-
|
184
181
|
end
|
185
182
|
|
186
183
|
end
|
@@ -207,7 +204,7 @@ module Cucumber
|
|
207
204
|
attr_reader :current_test_step_source
|
208
205
|
|
209
206
|
def before_test_case(test_case)
|
210
|
-
@
|
207
|
+
@before_hook_results = Legacy::Ast::NodeCollection.new
|
211
208
|
end
|
212
209
|
|
213
210
|
def before_test_step(test_step)
|
@@ -232,11 +229,14 @@ module Cucumber
|
|
232
229
|
end
|
233
230
|
|
234
231
|
def before_hook(location, result)
|
235
|
-
@
|
232
|
+
@before_hook_results << Legacy::Ast::HookResult.new(LegacyResultBuilder.new(result))
|
236
233
|
end
|
237
234
|
|
238
235
|
def after_hook(location, result)
|
239
|
-
|
236
|
+
# if the scenario has no steps, we can hit this before we've created the scenario printer
|
237
|
+
# ideally we should call switch_step_container in before_step_step
|
238
|
+
switch_step_container if !@child
|
239
|
+
@child.after_hook Legacy::Ast::HookResult.new(LegacyResultBuilder.new(result))
|
240
240
|
end
|
241
241
|
|
242
242
|
def after_step_hook(hook, result)
|
@@ -272,8 +272,8 @@ module Cucumber
|
|
272
272
|
|
273
273
|
private
|
274
274
|
|
275
|
-
attr_reader :
|
276
|
-
private :
|
275
|
+
attr_reader :before_hook_results
|
276
|
+
private :before_hook_results
|
277
277
|
|
278
278
|
def switch_step_container
|
279
279
|
switch_to_child select_step_container(current_test_step_source), current_test_step_source
|
@@ -282,17 +282,17 @@ module Cucumber
|
|
282
282
|
def select_step_container(source)
|
283
283
|
if source.background
|
284
284
|
if same_background_as_previous_test_case?(source)
|
285
|
-
HiddenBackgroundPrinter.new(formatter,
|
285
|
+
HiddenBackgroundPrinter.new(formatter, source.background)
|
286
286
|
else
|
287
|
-
BackgroundPrinter.new(formatter,
|
287
|
+
BackgroundPrinter.new(formatter, source.background, before_hook_results)
|
288
288
|
end
|
289
289
|
elsif source.scenario
|
290
|
-
ScenarioPrinter.new(formatter,
|
290
|
+
ScenarioPrinter.new(formatter, source.scenario, before_hook_results)
|
291
291
|
elsif source.scenario_outline
|
292
292
|
if same_scenario_outline_as_previous_test_case?(source) and @previous_outline_child
|
293
293
|
@previous_outline_child
|
294
294
|
else
|
295
|
-
ScenarioOutlinePrinter.new(formatter, runtime, source.scenario_outline)
|
295
|
+
ScenarioOutlinePrinter.new(formatter, runtime.configuration, source.scenario_outline)
|
296
296
|
end
|
297
297
|
else
|
298
298
|
raise 'unknown step container'
|
@@ -313,7 +313,7 @@ module Cucumber
|
|
313
313
|
|
314
314
|
if current_test_step_source.scenario_outline
|
315
315
|
@child.examples_table(current_test_step_source.examples_table)
|
316
|
-
@child.examples_table_row(current_test_step_source.examples_table_row,
|
316
|
+
@child.examples_table_row(current_test_step_source.examples_table_row, before_hook_results)
|
317
317
|
end
|
318
318
|
|
319
319
|
if @failed_hidden_background_step
|
@@ -386,12 +386,33 @@ module Cucumber
|
|
386
386
|
|
387
387
|
end
|
388
388
|
|
389
|
-
|
389
|
+
module PrintsAfterHooks
|
390
|
+
def after_hook_results
|
391
|
+
@after_hook_results ||= Legacy::Ast::NodeCollection.new
|
392
|
+
end
|
393
|
+
|
394
|
+
def after_hook(result)
|
395
|
+
after_hook_results << result
|
396
|
+
end
|
397
|
+
end
|
398
|
+
|
399
|
+
# Basic printer used by default
|
400
|
+
class AfterHookPrinter
|
401
|
+
include Cucumber.initializer(:formatter)
|
402
|
+
|
403
|
+
include PrintsAfterHooks
|
404
|
+
|
405
|
+
def after
|
406
|
+
after_hook_results.accept(formatter)
|
407
|
+
end
|
408
|
+
end
|
409
|
+
|
410
|
+
BackgroundPrinter = Struct.new(:formatter, :node, :before_hook_results) do
|
390
411
|
|
391
412
|
def before
|
392
413
|
formatter.before_background node
|
393
414
|
formatter.background_name node.keyword, node.legacy_conflated_name_and_description, node.location.to_s, indent.of(node)
|
394
|
-
|
415
|
+
before_hook_results.accept(formatter)
|
395
416
|
self
|
396
417
|
end
|
397
418
|
|
@@ -400,7 +421,7 @@ module Cucumber
|
|
400
421
|
end
|
401
422
|
|
402
423
|
def step_invocation(step_invocation, source)
|
403
|
-
@child ||= StepsPrinter.new(formatter
|
424
|
+
@child ||= StepsPrinter.new(formatter).before
|
404
425
|
@child.step_invocation step_invocation
|
405
426
|
if source.step_result.status == :failed
|
406
427
|
@failed = true
|
@@ -426,7 +447,7 @@ module Cucumber
|
|
426
447
|
|
427
448
|
# Printer to handle background steps for anything but the first scenario in a
|
428
449
|
# feature. These steps should not be printed.
|
429
|
-
class HiddenBackgroundPrinter < Struct.new(:formatter, :
|
450
|
+
class HiddenBackgroundPrinter < Struct.new(:formatter, :node)
|
430
451
|
def get_failed_step_source
|
431
452
|
return @source_of_failed_step
|
432
453
|
end
|
@@ -446,26 +467,23 @@ module Cucumber
|
|
446
467
|
def after_test_case(*);end
|
447
468
|
end
|
448
469
|
|
449
|
-
ScenarioPrinter = Struct.new(:formatter, :
|
470
|
+
ScenarioPrinter = Struct.new(:formatter, :node, :before_hook_results) do
|
471
|
+
include PrintsAfterHooks
|
450
472
|
|
451
473
|
def before
|
452
474
|
formatter.before_feature_element(node)
|
453
475
|
Legacy::Ast::Tags.new(node.tags).accept(formatter)
|
454
476
|
formatter.scenario_name node.keyword, node.legacy_conflated_name_and_description, node.location.to_s, indent.of(node)
|
455
|
-
|
477
|
+
before_hook_results.accept(formatter)
|
456
478
|
self
|
457
479
|
end
|
458
480
|
|
459
481
|
def step_invocation(step_invocation, source)
|
460
|
-
@child ||= StepsPrinter.new(formatter
|
482
|
+
@child ||= StepsPrinter.new(formatter).before
|
461
483
|
@child.step_invocation step_invocation
|
462
484
|
@last_step_result = source.step_result
|
463
485
|
end
|
464
486
|
|
465
|
-
def after_hook(result)
|
466
|
-
@after_hook_result = result
|
467
|
-
end
|
468
|
-
|
469
487
|
def after_step_hook(result)
|
470
488
|
result.describe_exception_to formatter
|
471
489
|
end
|
@@ -480,7 +498,7 @@ module Cucumber
|
|
480
498
|
# TODO - the last step result might not accurately reflect the
|
481
499
|
# overall scenario result.
|
482
500
|
scenario = last_step_result.scenario(node.name, node.location)
|
483
|
-
|
501
|
+
after_hook_results.accept(formatter)
|
484
502
|
formatter.after_feature_element(scenario)
|
485
503
|
@done = true
|
486
504
|
self
|
@@ -497,7 +515,7 @@ module Cucumber
|
|
497
515
|
end
|
498
516
|
end
|
499
517
|
|
500
|
-
StepsPrinter = Struct.new(:formatter
|
518
|
+
StepsPrinter = Struct.new(:formatter) do
|
501
519
|
def before
|
502
520
|
formatter.before_steps(nil)
|
503
521
|
self
|
@@ -522,7 +540,7 @@ module Cucumber
|
|
522
540
|
|
523
541
|
end
|
524
542
|
|
525
|
-
ScenarioOutlinePrinter = Struct.new(:formatter, :
|
543
|
+
ScenarioOutlinePrinter = Struct.new(:formatter, :configuration, :node) do
|
526
544
|
extend Forwardable
|
527
545
|
def_delegators :@child, :after_hook, :after_step_hook
|
528
546
|
|
@@ -530,14 +548,10 @@ module Cucumber
|
|
530
548
|
formatter.before_feature_element(node)
|
531
549
|
Legacy::Ast::Tags.new(node.tags).accept(formatter)
|
532
550
|
formatter.scenario_name node.keyword, node.legacy_conflated_name_and_description, node.location.to_s, indent.of(node)
|
533
|
-
OutlineStepsPrinter.new(formatter,
|
551
|
+
OutlineStepsPrinter.new(formatter, configuration, indent).print(node)
|
534
552
|
self
|
535
553
|
end
|
536
554
|
|
537
|
-
def after_hook(result)
|
538
|
-
@child.after_hook(result)
|
539
|
-
end
|
540
|
-
|
541
555
|
def step_invocation(step_invocation, source)
|
542
556
|
node, result = source.step, source.step_result
|
543
557
|
@last_step_result = result
|
@@ -545,12 +559,12 @@ module Cucumber
|
|
545
559
|
end
|
546
560
|
|
547
561
|
def examples_table(examples_table)
|
548
|
-
@child ||= ExamplesArrayPrinter.new(formatter,
|
562
|
+
@child ||= ExamplesArrayPrinter.new(formatter, configuration).before
|
549
563
|
@child.examples_table(examples_table)
|
550
564
|
end
|
551
565
|
|
552
|
-
def examples_table_row(node,
|
553
|
-
@child.examples_table_row(node,
|
566
|
+
def examples_table_row(node, before_hook_results)
|
567
|
+
@child.examples_table_row(node, before_hook_results)
|
554
568
|
end
|
555
569
|
|
556
570
|
def after_test_case
|
@@ -577,7 +591,7 @@ module Cucumber
|
|
577
591
|
end
|
578
592
|
end
|
579
593
|
|
580
|
-
OutlineStepsPrinter = Struct.new(:formatter, :
|
594
|
+
OutlineStepsPrinter = Struct.new(:formatter, :configuration, :indent, :outline) do
|
581
595
|
def print(node)
|
582
596
|
node.describe_to self
|
583
597
|
steps_printer.after
|
@@ -590,7 +604,7 @@ module Cucumber
|
|
590
604
|
def outline_step(step)
|
591
605
|
step_match = NoStepMatch.new(step, step.name)
|
592
606
|
step_invocation = LegacyResultBuilder.new(Core::Test::Result::Skipped.new).
|
593
|
-
step_invocation(step_match, step, indent, background = nil,
|
607
|
+
step_invocation(step_match, step, indent, background = nil, configuration, messages = [], embeddings = [])
|
594
608
|
steps_printer.step_invocation step_invocation
|
595
609
|
end
|
596
610
|
|
@@ -603,7 +617,7 @@ module Cucumber
|
|
603
617
|
end
|
604
618
|
end
|
605
619
|
|
606
|
-
ExamplesArrayPrinter = Struct.new(:formatter, :
|
620
|
+
ExamplesArrayPrinter = Struct.new(:formatter, :configuration) do
|
607
621
|
extend Forwardable
|
608
622
|
def_delegators :@child, :step_invocation, :after_hook, :after_step_hook, :after_test_case, :examples_table_row
|
609
623
|
|
@@ -615,7 +629,7 @@ module Cucumber
|
|
615
629
|
def examples_table(examples_table)
|
616
630
|
return if examples_table == @current
|
617
631
|
@child.after if @child
|
618
|
-
@child = ExamplesTablePrinter.new(formatter,
|
632
|
+
@child = ExamplesTablePrinter.new(formatter, configuration, examples_table).before
|
619
633
|
@current = examples_table
|
620
634
|
end
|
621
635
|
|
@@ -626,7 +640,7 @@ module Cucumber
|
|
626
640
|
end
|
627
641
|
end
|
628
642
|
|
629
|
-
ExamplesTablePrinter = Struct.new(:formatter, :
|
643
|
+
ExamplesTablePrinter = Struct.new(:formatter, :configuration, :node) do
|
630
644
|
extend Forwardable
|
631
645
|
def_delegators :@child, :step_invocation, :after_hook, :after_step_hook, :after_test_case
|
632
646
|
|
@@ -634,20 +648,20 @@ module Cucumber
|
|
634
648
|
formatter.before_examples(node)
|
635
649
|
formatter.examples_name(node.keyword, node.legacy_conflated_name_and_description)
|
636
650
|
formatter.before_outline_table(legacy_table)
|
637
|
-
if !
|
638
|
-
HeaderTableRowPrinter.new(formatter,
|
651
|
+
if !configuration.expand?
|
652
|
+
HeaderTableRowPrinter.new(formatter, ExampleTableRow.new(node.header), Legacy::Ast::Node.new).before.after
|
639
653
|
end
|
640
654
|
self
|
641
655
|
end
|
642
656
|
|
643
|
-
def examples_table_row(examples_table_row,
|
657
|
+
def examples_table_row(examples_table_row, before_hook_results)
|
644
658
|
return if examples_table_row == @current
|
645
659
|
@child.after if @child
|
646
660
|
row = ExampleTableRow.new(examples_table_row)
|
647
|
-
if !
|
648
|
-
@child = TableRowPrinter.new(formatter,
|
661
|
+
if !configuration.expand?
|
662
|
+
@child = TableRowPrinter.new(formatter, row, before_hook_results).before
|
649
663
|
else
|
650
|
-
@child = ExpandTableRowPrinter.new(formatter,
|
664
|
+
@child = ExpandTableRowPrinter.new(formatter, row, before_hook_results).before
|
651
665
|
end
|
652
666
|
@current = examples_table_row
|
653
667
|
end
|
@@ -708,10 +722,8 @@ module Cucumber
|
|
708
722
|
end
|
709
723
|
end
|
710
724
|
|
711
|
-
class TableRowPrinterBase < Struct.new(:formatter, :
|
712
|
-
|
713
|
-
@after_hook_result = result
|
714
|
-
end
|
725
|
+
class TableRowPrinterBase < Struct.new(:formatter, :node, :before_hook_results)
|
726
|
+
include PrintsAfterHooks
|
715
727
|
|
716
728
|
def after_step_hook(result)
|
717
729
|
@after_step_hook_result = result
|
@@ -757,7 +769,7 @@ module Cucumber
|
|
757
769
|
|
758
770
|
class TableRowPrinter < TableRowPrinterBase
|
759
771
|
def before
|
760
|
-
|
772
|
+
before_hook_results.accept(formatter)
|
761
773
|
formatter.before_table_row(node)
|
762
774
|
self
|
763
775
|
end
|
@@ -780,7 +792,7 @@ module Cucumber
|
|
780
792
|
end
|
781
793
|
formatter.after_table_row(legacy_table_row)
|
782
794
|
@after_step_hook_result.describe_exception_to formatter if @after_step_hook_result
|
783
|
-
|
795
|
+
after_hook_results.accept(formatter)
|
784
796
|
@done = true
|
785
797
|
self
|
786
798
|
end
|
@@ -794,7 +806,7 @@ module Cucumber
|
|
794
806
|
|
795
807
|
class ExpandTableRowPrinter < TableRowPrinterBase
|
796
808
|
def before
|
797
|
-
|
809
|
+
before_hook_results.accept(formatter)
|
798
810
|
self
|
799
811
|
end
|
800
812
|
|
@@ -815,7 +827,7 @@ module Cucumber
|
|
815
827
|
return if @done
|
816
828
|
@child.after if @child
|
817
829
|
@after_step_hook_result.describe_exception_to formatter if @after_step_hook_result
|
818
|
-
|
830
|
+
after_hook_results.accept(formatter)
|
819
831
|
@done = true
|
820
832
|
self
|
821
833
|
end
|
@@ -889,7 +901,8 @@ module Cucumber
|
|
889
901
|
class LegacyResultBuilder
|
890
902
|
attr_reader :status
|
891
903
|
def initialize(result)
|
892
|
-
result
|
904
|
+
@result = result
|
905
|
+
@result.describe_to(self)
|
893
906
|
end
|
894
907
|
|
895
908
|
def passed
|
@@ -945,12 +958,8 @@ module Cucumber
|
|
945
958
|
def step_exception(step, configuration)
|
946
959
|
return filtered_step_exception(step) if @exception
|
947
960
|
return nil unless @status == :undefined && configuration.strict?
|
948
|
-
|
949
|
-
|
950
|
-
rescue => exception
|
951
|
-
@exception = exception
|
952
|
-
filtered_step_exception(step)
|
953
|
-
end
|
961
|
+
@exception = Cucumber::Undefined.from(@result, step.name)
|
962
|
+
filtered_step_exception(step)
|
954
963
|
end
|
955
964
|
|
956
965
|
def filtered_exception
|
@@ -1023,6 +1032,20 @@ module Cucumber
|
|
1023
1032
|
private :node
|
1024
1033
|
end
|
1025
1034
|
|
1035
|
+
class NodeCollection
|
1036
|
+
def initialize
|
1037
|
+
@children = []
|
1038
|
+
end
|
1039
|
+
|
1040
|
+
def accept(formatter)
|
1041
|
+
@children.each { |child| child.accept(formatter) }
|
1042
|
+
end
|
1043
|
+
|
1044
|
+
def <<(child)
|
1045
|
+
@children << child
|
1046
|
+
end
|
1047
|
+
end
|
1048
|
+
|
1026
1049
|
Comments = Struct.new(:comments) do
|
1027
1050
|
def accept(formatter)
|
1028
1051
|
return if comments.empty?
|
@@ -1033,7 +1056,7 @@ module Cucumber
|
|
1033
1056
|
end
|
1034
1057
|
end
|
1035
1058
|
|
1036
|
-
class
|
1059
|
+
class HookResult
|
1037
1060
|
def initialize(result)
|
1038
1061
|
@result = result
|
1039
1062
|
@already_accepted = false
|
@@ -22,7 +22,7 @@ module Cucumber
|
|
22
22
|
def step(step)
|
23
23
|
location = Cucumber::Core::Ast::Location.new(*caller[0].split(':')[0..1])
|
24
24
|
core_multiline_arg = Core::Ast::MultilineArgument.from(step.doc_string || step.rows, location)
|
25
|
-
@support_code.invoke(step.name, MultilineArgument.from(core_multiline_arg))
|
25
|
+
@support_code.invoke(step.name, MultilineArgument.from(core_multiline_arg), location)
|
26
26
|
end
|
27
27
|
|
28
28
|
def eof
|
@@ -55,15 +55,8 @@ module Cucumber
|
|
55
55
|
parser.parse(steps_text, file, line.to_i)
|
56
56
|
end
|
57
57
|
|
58
|
-
def invoke(step_name, multiline_argument)
|
59
|
-
|
60
|
-
location = Core::Ast::Location.new(file, line)
|
61
|
-
begin
|
62
|
-
step_match(step_name).invoke(multiline_argument)
|
63
|
-
rescue Exception => e
|
64
|
-
e.nested! if Undefined === e
|
65
|
-
raise e
|
66
|
-
end
|
58
|
+
def invoke(step_name, multiline_argument, location=nil)
|
59
|
+
step_match(step_name).invoke(multiline_argument)
|
67
60
|
end
|
68
61
|
|
69
62
|
# Loads and registers programming language implementation.
|
@@ -115,16 +108,6 @@ module Cucumber
|
|
115
108
|
end
|
116
109
|
end
|
117
110
|
|
118
|
-
def around(scenario, block)
|
119
|
-
@programming_languages.reverse.inject(block) do |blk, programming_language|
|
120
|
-
proc do
|
121
|
-
programming_language.around(scenario) do
|
122
|
-
blk.call(scenario)
|
123
|
-
end
|
124
|
-
end
|
125
|
-
end.call
|
126
|
-
end
|
127
|
-
|
128
111
|
def step_definitions
|
129
112
|
@programming_languages.map do |programming_language|
|
130
113
|
programming_language.step_definitions
|
@@ -3,6 +3,7 @@ require 'cucumber/formatter/spec_helper'
|
|
3
3
|
require 'cucumber/formatter/html'
|
4
4
|
require 'nokogiri'
|
5
5
|
require 'cucumber/rb_support/rb_language'
|
6
|
+
require 'rspec/mocks'
|
6
7
|
|
7
8
|
module Cucumber
|
8
9
|
module Formatter
|
@@ -245,7 +246,10 @@ module Cucumber
|
|
245
246
|
|
246
247
|
describe "with a step that embeds a snapshot" do
|
247
248
|
define_steps do
|
248
|
-
Given(/snap/) {
|
249
|
+
Given(/snap/) {
|
250
|
+
RSpec::Mocks.allow_message(File, :file?) { true }
|
251
|
+
embed('snapshot.jpeg', 'image/jpeg')
|
252
|
+
}
|
249
253
|
end
|
250
254
|
|
251
255
|
define_feature(<<-FEATURE)
|
@@ -271,6 +275,34 @@ module Cucumber
|
|
271
275
|
it { expect(@doc.at('a#text_0')['href'].to_s).to eq "log.txt" }
|
272
276
|
end
|
273
277
|
|
278
|
+
describe "with a step that embeds a snapshot content manually" do
|
279
|
+
define_steps do
|
280
|
+
Given(/snap/) { embed('', 'image/png') }
|
281
|
+
end
|
282
|
+
|
283
|
+
define_feature(<<-FEATURE)
|
284
|
+
Feature:
|
285
|
+
Scenario:
|
286
|
+
Given snap
|
287
|
+
FEATURE
|
288
|
+
|
289
|
+
it { expect(@doc.css('.embed img').first.attributes['src'].to_s).to eq "" }
|
290
|
+
end
|
291
|
+
|
292
|
+
describe "with a step that embeds a snapshot content" do
|
293
|
+
define_steps do
|
294
|
+
Given(/snap/) { embed('YWJj', 'image/png;base64') }
|
295
|
+
end
|
296
|
+
|
297
|
+
define_feature(<<-FEATURE)
|
298
|
+
Feature:
|
299
|
+
Scenario:
|
300
|
+
Given snap
|
301
|
+
FEATURE
|
302
|
+
|
303
|
+
it { expect(@doc.css('.embed img').first.attributes['src'].to_s).to eq "" }
|
304
|
+
end
|
305
|
+
|
274
306
|
describe "with an undefined Given step then an undefined And step" do
|
275
307
|
define_feature(<<-FEATURE)
|
276
308
|
Feature:
|
@@ -0,0 +1,51 @@
|
|
1
|
+
require_relative "../../lib/cucumber/mappings"
|
2
|
+
require 'cucumber/core'
|
3
|
+
require 'cucumber/core/gherkin/writer'
|
4
|
+
|
5
|
+
module Cucumber
|
6
|
+
class Mappings
|
7
|
+
describe Scenario do
|
8
|
+
include Core::Gherkin::Writer
|
9
|
+
include Core
|
10
|
+
let(:ruby) { double.as_null_object }
|
11
|
+
let(:runtime) do
|
12
|
+
double(
|
13
|
+
load_programming_language: ruby,
|
14
|
+
step_match: double
|
15
|
+
)
|
16
|
+
end
|
17
|
+
let(:mappings) { Mappings.new(runtime) }
|
18
|
+
let(:report) { double.as_null_object }
|
19
|
+
|
20
|
+
it "responds to #source_tag_names" do
|
21
|
+
gherkin_docs = [
|
22
|
+
gherkin do
|
23
|
+
feature 'test', tags: '@foo @bar' do
|
24
|
+
scenario 'test', tags: '@baz' do
|
25
|
+
step 'passing'
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
]
|
30
|
+
|
31
|
+
# TODO: the complexity of this stubbing shows we need to clean up the interface
|
32
|
+
scenario_spy = nil
|
33
|
+
allow(ruby).to receive(:hooks_for) do |phase, scenario|
|
34
|
+
if phase == :before
|
35
|
+
hook = double
|
36
|
+
expect(hook).to receive(:invoke) do |phase, scenario|
|
37
|
+
scenario_spy = scenario
|
38
|
+
end
|
39
|
+
[hook]
|
40
|
+
else
|
41
|
+
[]
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
execute gherkin_docs, mappings, report
|
46
|
+
|
47
|
+
expect(scenario_spy.source_tag_names).to eq %w(@foo @bar @baz)
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
@@ -1439,7 +1439,7 @@ module Cucumber
|
|
1439
1439
|
end
|
1440
1440
|
end
|
1441
1441
|
|
1442
|
-
context 'with exception in before
|
1442
|
+
context 'with exception in a single before hook' do
|
1443
1443
|
it 'prints the exception after the scenario name' do
|
1444
1444
|
define_steps do
|
1445
1445
|
Before do
|
@@ -1590,6 +1590,47 @@ module Cucumber
|
|
1590
1590
|
end
|
1591
1591
|
end
|
1592
1592
|
|
1593
|
+
context 'with exception in the first of several before hooks' do
|
1594
|
+
# This proves that the second before hook's result doesn't overwrite
|
1595
|
+
# the result of the first one.
|
1596
|
+
it 'prints the exception after the scenario name' do
|
1597
|
+
define_steps do
|
1598
|
+
Before { raise 'an exception' }
|
1599
|
+
Before { }
|
1600
|
+
end
|
1601
|
+
execute_gherkin do
|
1602
|
+
feature do
|
1603
|
+
scenario do
|
1604
|
+
step 'passing'
|
1605
|
+
end
|
1606
|
+
end
|
1607
|
+
end
|
1608
|
+
|
1609
|
+
expect( formatter.messages ).to eq([
|
1610
|
+
:before_features,
|
1611
|
+
:before_feature,
|
1612
|
+
:before_tags,
|
1613
|
+
:after_tags,
|
1614
|
+
:feature_name,
|
1615
|
+
:before_feature_element,
|
1616
|
+
:before_tags,
|
1617
|
+
:after_tags,
|
1618
|
+
:scenario_name,
|
1619
|
+
:exception,
|
1620
|
+
:before_steps,
|
1621
|
+
:before_step,
|
1622
|
+
:before_step_result,
|
1623
|
+
:step_name,
|
1624
|
+
:after_step_result,
|
1625
|
+
:after_step,
|
1626
|
+
:after_steps,
|
1627
|
+
:after_feature_element,
|
1628
|
+
:after_feature,
|
1629
|
+
:after_features
|
1630
|
+
])
|
1631
|
+
end
|
1632
|
+
end
|
1633
|
+
|
1593
1634
|
context 'with exception in after hooks' do
|
1594
1635
|
it 'prints the exception after the steps' do
|
1595
1636
|
define_steps do
|
@@ -1688,6 +1729,75 @@ module Cucumber
|
|
1688
1729
|
])
|
1689
1730
|
end
|
1690
1731
|
end
|
1732
|
+
|
1733
|
+
context 'with exception in the first of several after hooks' do
|
1734
|
+
it 'prints the exception after the steps' do
|
1735
|
+
define_steps do
|
1736
|
+
After { raise 'an exception' }
|
1737
|
+
After { }
|
1738
|
+
end
|
1739
|
+
execute_gherkin do
|
1740
|
+
feature do
|
1741
|
+
scenario do
|
1742
|
+
step 'passing'
|
1743
|
+
end
|
1744
|
+
end
|
1745
|
+
end
|
1746
|
+
|
1747
|
+
expect( formatter.messages ).to eq([
|
1748
|
+
:before_features,
|
1749
|
+
:before_feature,
|
1750
|
+
:before_tags,
|
1751
|
+
:after_tags,
|
1752
|
+
:feature_name,
|
1753
|
+
:before_feature_element,
|
1754
|
+
:before_tags,
|
1755
|
+
:after_tags,
|
1756
|
+
:scenario_name,
|
1757
|
+
:before_steps,
|
1758
|
+
:before_step,
|
1759
|
+
:before_step_result,
|
1760
|
+
:step_name,
|
1761
|
+
:after_step_result,
|
1762
|
+
:after_step,
|
1763
|
+
:after_steps,
|
1764
|
+
:exception,
|
1765
|
+
:after_feature_element,
|
1766
|
+
:after_feature,
|
1767
|
+
:after_features
|
1768
|
+
])
|
1769
|
+
end
|
1770
|
+
end
|
1771
|
+
|
1772
|
+
context 'with an exception in an after hook but no steps' do
|
1773
|
+
it 'prints the exception after the steps' do
|
1774
|
+
define_steps do
|
1775
|
+
After { fail }
|
1776
|
+
end
|
1777
|
+
execute_gherkin do
|
1778
|
+
feature do
|
1779
|
+
scenario do
|
1780
|
+
end
|
1781
|
+
end
|
1782
|
+
end
|
1783
|
+
|
1784
|
+
expect( formatter.messages ).to eq([
|
1785
|
+
:before_features,
|
1786
|
+
:before_feature,
|
1787
|
+
:before_tags,
|
1788
|
+
:after_tags,
|
1789
|
+
:feature_name,
|
1790
|
+
:before_feature_element,
|
1791
|
+
:before_tags,
|
1792
|
+
:after_tags,
|
1793
|
+
:scenario_name,
|
1794
|
+
:exception,
|
1795
|
+
:after_feature_element,
|
1796
|
+
:after_feature,
|
1797
|
+
:after_features
|
1798
|
+
])
|
1799
|
+
end
|
1800
|
+
end
|
1691
1801
|
end
|
1692
1802
|
|
1693
1803
|
it 'passes an object responding to failed? with the after_feature_element message' do
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: cucumber
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.0.0.beta.
|
4
|
+
version: 2.0.0.beta.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Aslak Hellesøy
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2014-08-
|
11
|
+
date: 2014-08-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: cucumber-core
|
@@ -16,14 +16,14 @@ dependencies:
|
|
16
16
|
requirements:
|
17
17
|
- - "~>"
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: 1.0.0.beta.
|
19
|
+
version: 1.0.0.beta.2
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
24
|
- - "~>"
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version: 1.0.0.beta.
|
26
|
+
version: 1.0.0.beta.2
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: builder
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -647,6 +647,7 @@ files:
|
|
647
647
|
- lib/autotest/cucumber_rspec2.rb
|
648
648
|
- lib/autotest/discover.rb
|
649
649
|
- lib/cucumber.rb
|
650
|
+
- lib/cucumber/ast.rb
|
650
651
|
- lib/cucumber/cli/configuration.rb
|
651
652
|
- lib/cucumber/cli/main.rb
|
652
653
|
- lib/cucumber/cli/options.rb
|
@@ -741,6 +742,7 @@ files:
|
|
741
742
|
- spec/cucumber/formatter/pretty_spec.rb
|
742
743
|
- spec/cucumber/formatter/progress_spec.rb
|
743
744
|
- spec/cucumber/formatter/spec_helper.rb
|
745
|
+
- spec/cucumber/mappings_spec.rb
|
744
746
|
- spec/cucumber/rake/forked_spec.rb
|
745
747
|
- spec/cucumber/rb_support/rb_language_spec.rb
|
746
748
|
- spec/cucumber/rb_support/rb_step_definition_spec.rb
|
@@ -787,10 +789,10 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
787
789
|
version: 1.3.1
|
788
790
|
requirements: []
|
789
791
|
rubyforge_project:
|
790
|
-
rubygems_version: 2.
|
792
|
+
rubygems_version: 2.0.14
|
791
793
|
signing_key:
|
792
794
|
specification_version: 4
|
793
|
-
summary: cucumber-2.0.0.beta.
|
795
|
+
summary: cucumber-2.0.0.beta.2
|
794
796
|
test_files:
|
795
797
|
- features/docs/api/list_step_defs_as_json.feature
|
796
798
|
- features/docs/api/run_cli_main_with_existing_runtime.feature
|
@@ -886,6 +888,7 @@ test_files:
|
|
886
888
|
- spec/cucumber/formatter/pretty_spec.rb
|
887
889
|
- spec/cucumber/formatter/progress_spec.rb
|
888
890
|
- spec/cucumber/formatter/spec_helper.rb
|
891
|
+
- spec/cucumber/mappings_spec.rb
|
889
892
|
- spec/cucumber/rake/forked_spec.rb
|
890
893
|
- spec/cucumber/rb_support/rb_language_spec.rb
|
891
894
|
- spec/cucumber/rb_support/rb_step_definition_spec.rb
|