cucumber 1.0.0 → 1.0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile.lock +7 -7
- data/History.md +12 -0
- data/cucumber.gemspec +1 -1
- data/features/step_definitions/cucumber-features/cucumber_ruby_mappings.rb +168 -0
- data/features/step_definitions/cucumber_steps.rb +10 -1
- data/features/support/env.rb +1 -1
- data/fixtures/self_test/features/undefined_multiline_args.feature +1 -1
- data/gem_tasks/yard.rake +1 -1
- data/legacy_features/cucumber_cli.feature +1 -1
- data/legacy_features/html_formatter/a.html +1 -1
- data/legacy_features/junit_formatter.feature +7 -7
- data/legacy_features/rerun_formatter.feature +8 -1
- data/lib/cucumber/ast/step_invocation.rb +24 -19
- data/lib/cucumber/ast/tree_walker.rb +0 -1
- data/lib/cucumber/formatter/console.rb +2 -1
- data/lib/cucumber/formatter/gherkin_formatter_adapter.rb +5 -6
- data/lib/cucumber/formatter/html.rb +3 -3
- data/lib/cucumber/formatter/json.rb +7 -5
- data/lib/cucumber/formatter/junit.rb +1 -2
- data/lib/cucumber/formatter/rerun.rb +6 -4
- data/lib/cucumber/platform.rb +1 -1
- data/spec/cucumber/ast/scenario_outline_spec.rb +1 -1
- data/spec/cucumber/formatter/junit_spec.rb +1 -1
- metadata +13 -142
- data/features/step_definitions/cucumber-features/core_steps.rb +0 -224
- data/spec/cucumber/ast/scenario_spec.rb +0 -44
data/Gemfile.lock
CHANGED
@@ -4,14 +4,14 @@ PATH
|
|
4
4
|
cucumber (1.0.0)
|
5
5
|
builder (>= 2.1.2)
|
6
6
|
diff-lcs (>= 1.1.2)
|
7
|
-
gherkin (~> 2.4.
|
7
|
+
gherkin (~> 2.4.5)
|
8
8
|
json (>= 1.4.6)
|
9
9
|
term-ansicolor (>= 1.0.5)
|
10
10
|
|
11
11
|
GEM
|
12
12
|
remote: http://rubygems.org/
|
13
13
|
specs:
|
14
|
-
aruba (0.4.
|
14
|
+
aruba (0.4.3)
|
15
15
|
bcat (>= 0.6.1)
|
16
16
|
childprocess (>= 0.1.9)
|
17
17
|
cucumber (>= 0.10.7)
|
@@ -31,14 +31,14 @@ GEM
|
|
31
31
|
ffi (~> 1.0.6)
|
32
32
|
diff-lcs (1.1.2)
|
33
33
|
ffi (1.0.9)
|
34
|
-
gherkin (2.4.
|
34
|
+
gherkin (2.4.5)
|
35
35
|
json (>= 1.4.6)
|
36
36
|
innate (2011.04)
|
37
37
|
rack (>= 1.1.0)
|
38
38
|
json (1.5.3)
|
39
39
|
json_pure (1.5.3)
|
40
40
|
mime-types (1.16)
|
41
|
-
nokogiri (1.
|
41
|
+
nokogiri (1.5.0)
|
42
42
|
prawn (0.8.4)
|
43
43
|
prawn-core (< 0.9, >= 0.8.4)
|
44
44
|
prawn-layout (< 0.9, >= 0.8.4)
|
@@ -62,8 +62,8 @@ GEM
|
|
62
62
|
diff-lcs (~> 1.1.2)
|
63
63
|
rspec-mocks (2.6.0)
|
64
64
|
rubyzip (0.9.4)
|
65
|
-
selenium-webdriver (0.2.
|
66
|
-
childprocess (>= 0.1.
|
65
|
+
selenium-webdriver (0.2.2)
|
66
|
+
childprocess (>= 0.1.9)
|
67
67
|
ffi (>= 1.0.7)
|
68
68
|
json_pure
|
69
69
|
rubyzip
|
@@ -73,7 +73,7 @@ GEM
|
|
73
73
|
sinatra (1.2.6)
|
74
74
|
rack (~> 1.1)
|
75
75
|
tilt (< 2.0, >= 1.2.2)
|
76
|
-
spork (0.9.0.
|
76
|
+
spork (0.9.0.rc9)
|
77
77
|
syntax (1.0.0)
|
78
78
|
term-ansicolor (1.0.5)
|
79
79
|
tilt (1.3.2)
|
data/History.md
CHANGED
@@ -1,3 +1,15 @@
|
|
1
|
+
## [v1.0.1](https://github.com/cucumber/cucumber/compare/v1.0.0...v1.0.1)
|
2
|
+
|
3
|
+
### Bugfixes
|
4
|
+
* Removed extra colons emitted by rerun formatter ([#99](https://github.com/cucumber/cucumber/pull/99) Juan Manuel Barreneche)
|
5
|
+
* cucumber 1.0.0 wrong number of arguments error when generating json format on jruby for windows ([#97](https://github.com/cucumber/cucumber/issues/97) (Aslak Hellesøy)
|
6
|
+
* Recent change to junit.rb breaks on Windows ([#81](https://github.com/cucumber/cucumber/issues/81), [#86](https://github.com/cucumber/cucumber/pull/86) Johnlon, Aslak Hellesøy)
|
7
|
+
* Cucumber fails on nil and does not print out failed tests ([#95](https://github.com/cucumber/cucumber/pull/95) Nikita)
|
8
|
+
* Javascript code is not being displayed in HTML output ([#58](https://github.com/cucumber/cucumber/issues/58) Aslak Hellesøy)
|
9
|
+
|
10
|
+
### New Features
|
11
|
+
* If the CUCUMBER_TRUNCATE_OUTPUT environment variable is set, lines will be truncated. Used by the Cucumber book. (Aslak Hellesøy)
|
12
|
+
|
1
13
|
## [v1.0.0](https://github.com/cucumber/cucumber/compare/v0.10.6...v1.0.0)
|
2
14
|
|
3
15
|
Yipeeeeeeeee!
|
data/cucumber.gemspec
CHANGED
@@ -23,7 +23,7 @@ for important information about this release. Happy cuking!
|
|
23
23
|
|
24
24
|
}
|
25
25
|
|
26
|
-
s.add_dependency 'gherkin', '~> 2.4.
|
26
|
+
s.add_dependency 'gherkin', '~> 2.4.5'
|
27
27
|
s.add_dependency 'term-ansicolor', '>= 1.0.5'
|
28
28
|
s.add_dependency 'builder', '>= 2.1.2'
|
29
29
|
s.add_dependency 'diff-lcs', '>= 1.1.2'
|
@@ -0,0 +1,168 @@
|
|
1
|
+
module CucumberRubyMappings
|
2
|
+
def features_dir
|
3
|
+
'features'
|
4
|
+
end
|
5
|
+
|
6
|
+
def run_scenario(scenario_name)
|
7
|
+
run_simple "#{cucumber_bin} features/a_feature.feature --name '#{scenario_name}'", false
|
8
|
+
end
|
9
|
+
|
10
|
+
def run_feature
|
11
|
+
run_simple "#{cucumber_bin} features/a_feature.feature", false
|
12
|
+
end
|
13
|
+
|
14
|
+
def cucumber_bin
|
15
|
+
File.expand_path(File.dirname(__FILE__) + '/../../../bin/cucumber')
|
16
|
+
end
|
17
|
+
|
18
|
+
def write_passing_mapping(step_name)
|
19
|
+
erb = ERB.new(<<-EOF, nil, '-')
|
20
|
+
Given /<%= step_name -%>/ do
|
21
|
+
# ARUBA_IGNORE_START
|
22
|
+
File.open("<%= step_file(step_name) %>", "w")
|
23
|
+
# ARUBA_IGNORE_END
|
24
|
+
end
|
25
|
+
|
26
|
+
EOF
|
27
|
+
append_to_file("features/step_definitions/some_stepdefs.rb", erb.result(binding))
|
28
|
+
end
|
29
|
+
|
30
|
+
def write_pending_mapping(step_name)
|
31
|
+
erb = ERB.new(<<-EOF, nil, '-')
|
32
|
+
Given /<%= step_name -%>/ do
|
33
|
+
# ARUBA_IGNORE_START
|
34
|
+
File.open("<%= step_file(step_name) %>", "w")
|
35
|
+
# ARUBA_IGNORE_END
|
36
|
+
pending
|
37
|
+
end
|
38
|
+
|
39
|
+
EOF
|
40
|
+
append_to_file("features/step_definitions/some_stepdefs.rb", erb.result(binding))
|
41
|
+
end
|
42
|
+
|
43
|
+
def write_failing_mapping(step_name)
|
44
|
+
erb = ERB.new(<<-EOF, nil, '-')
|
45
|
+
Given /<%= step_name -%>/ do
|
46
|
+
# ARUBA_IGNORE_START
|
47
|
+
File.open("<%= step_file(step_name) %>", "w")
|
48
|
+
# ARUBA_IGNORE_END
|
49
|
+
raise "bang!"
|
50
|
+
end
|
51
|
+
|
52
|
+
EOF
|
53
|
+
append_to_file("features/step_definitions/some_stepdefs.rb", erb.result(binding))
|
54
|
+
end
|
55
|
+
|
56
|
+
def write_calculator_code
|
57
|
+
code = <<-EOF
|
58
|
+
# http://en.wikipedia.org/wiki/Reverse_Polish_notation
|
59
|
+
class RpnCalculator
|
60
|
+
def initialize
|
61
|
+
@stack = []
|
62
|
+
end
|
63
|
+
|
64
|
+
def push(arg)
|
65
|
+
if(%w{- + * /}.index(arg))
|
66
|
+
y, x = @stack.pop(2)
|
67
|
+
push(x.__send__(arg, y))
|
68
|
+
else
|
69
|
+
@stack.push(arg)
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
def PI
|
74
|
+
push(Math::PI)
|
75
|
+
end
|
76
|
+
|
77
|
+
def value
|
78
|
+
@stack[-1]
|
79
|
+
end
|
80
|
+
end
|
81
|
+
EOF
|
82
|
+
write_file("lib/rpn_calculator.rb", code)
|
83
|
+
end
|
84
|
+
|
85
|
+
def write_mappings_for_calculator
|
86
|
+
write_file("features/support/env.rb", "$LOAD_PATH.unshift(File.dirname(__FILE__) + '/../../lib')\n")
|
87
|
+
mapping_code = <<-EOF
|
88
|
+
require 'rpn_calculator'
|
89
|
+
|
90
|
+
Given /^a calculator$/ do
|
91
|
+
@calc = RpnCalculator.new
|
92
|
+
end
|
93
|
+
|
94
|
+
When /^the calculator computes PI$/ do
|
95
|
+
@calc.PI
|
96
|
+
end
|
97
|
+
|
98
|
+
When /^the calculator adds up ([\\d\\.]+) and ([\\d\\.]+)$/ do |n1, n2|
|
99
|
+
@calc.push(n1.to_f)
|
100
|
+
@calc.push(n2.to_f)
|
101
|
+
@calc.push('+')
|
102
|
+
end
|
103
|
+
|
104
|
+
When /^the calculator adds up "([^"]*)" and "([^"]*)"$/ do |n1, n2|
|
105
|
+
@calc.push(n1.to_i)
|
106
|
+
@calc.push(n2.to_i)
|
107
|
+
@calc.push('+')
|
108
|
+
end
|
109
|
+
|
110
|
+
When /^the calculator adds up "([^"]*)", "([^"]*)" and "([^"]*)"$/ do |n1, n2, n3|
|
111
|
+
@calc.push(n1.to_i)
|
112
|
+
@calc.push(n2.to_i)
|
113
|
+
@calc.push(n3.to_i)
|
114
|
+
@calc.push('+')
|
115
|
+
@calc.push('+')
|
116
|
+
end
|
117
|
+
|
118
|
+
When /^the calculator adds up the following numbers:$/ do |numbers|
|
119
|
+
pushed = 0
|
120
|
+
numbers.split("\\n").each do |n|
|
121
|
+
@calc.push(n.to_i)
|
122
|
+
pushed +=1
|
123
|
+
@calc.push('+') if pushed > 1
|
124
|
+
end
|
125
|
+
end
|
126
|
+
|
127
|
+
Then /^the calculator returns PI$/ do
|
128
|
+
@calc.value.to_f.should be_within(0.00001).of(Math::PI)
|
129
|
+
end
|
130
|
+
|
131
|
+
Then /^the calculator returns "([^"]*)"$/ do |expected|
|
132
|
+
@calc.value.to_f.should be_within(0.00001).of(expected.to_f)
|
133
|
+
end
|
134
|
+
|
135
|
+
Then /^the calculator does not return ([\\d\\.]+)$/ do |unexpected|
|
136
|
+
@calc.value.to_f.should_not be_within(0.00001).of(unexpected.to_f)
|
137
|
+
end
|
138
|
+
|
139
|
+
EOF
|
140
|
+
write_file("features/step_definitions/calculator_mappings.rb", mapping_code)
|
141
|
+
end
|
142
|
+
|
143
|
+
def assert_passing_scenario
|
144
|
+
assert_partial_output("1 scenario (1 passed)", all_output)
|
145
|
+
assert_success true
|
146
|
+
end
|
147
|
+
|
148
|
+
def assert_failing_scenario
|
149
|
+
assert_partial_output("1 scenario (1 failed)", all_output)
|
150
|
+
assert_success false
|
151
|
+
end
|
152
|
+
|
153
|
+
def assert_pending_scenario
|
154
|
+
assert_partial_output("1 scenario (1 pending)", all_output)
|
155
|
+
assert_success true
|
156
|
+
end
|
157
|
+
|
158
|
+
def assert_undefined_scenario
|
159
|
+
assert_partial_output("1 scenario (1 undefined)", all_output)
|
160
|
+
assert_success true
|
161
|
+
end
|
162
|
+
|
163
|
+
def failed_output
|
164
|
+
"failed"
|
165
|
+
end
|
166
|
+
end
|
167
|
+
|
168
|
+
World(CucumberRubyMappings)
|
@@ -3,7 +3,16 @@ When /^I run cucumber "(.+)"$/ do |cmd|
|
|
3
3
|
end
|
4
4
|
|
5
5
|
Then /^it should (pass|fail) with JSON:$/ do |pass_fail, json|
|
6
|
-
|
6
|
+
# Need to store it in a variable. With JRuby we can only do this once it seems :-/
|
7
|
+
stdout = all_stdout
|
8
|
+
|
9
|
+
# JRuby has weird traces sometimes (?)
|
10
|
+
stdout = stdout.gsub(/ `\(root\)':in/, '')
|
11
|
+
|
12
|
+
actual = JSON.parse(stdout)
|
13
|
+
expected = JSON.parse(json)
|
14
|
+
|
15
|
+
actual.should == expected
|
7
16
|
assert_success(pass_fail == 'pass')
|
8
17
|
end
|
9
18
|
|
data/features/support/env.rb
CHANGED
data/gem_tasks/yard.rake
CHANGED
@@ -8,7 +8,7 @@ YARD::Rake::YardocTask.new(:yard) do |t|
|
|
8
8
|
t.files = %w{lib - README.md History.md LICENSE}
|
9
9
|
end
|
10
10
|
|
11
|
-
desc
|
11
|
+
desc "Push yardoc to http://cukes.info/cucumber/api/#{Cucumber::VERSION}"
|
12
12
|
task :push_yard => :yard do
|
13
13
|
sh("tar czf api-#{Cucumber::VERSION}.tgz -C doc .")
|
14
14
|
sh("scp api-#{Cucumber::VERSION}.tgz cukes.info:/var/www/cucumber/api/ruby")
|
@@ -551,7 +551,7 @@ features/tons_of_cukes.feature:5:in `Given '2' cukes'</pre></div><pre class="rub
|
|
551
551
|
<span class="offending"><span class="linenum">28</span> <span class="keyword">raise</span> <span class="punct">"</span><span class="string">We already have <span class="expr">#{@cukes}</span> cukes!</span><span class="punct">"</span> <span class="keyword">if</span> <span class="attribute">@cukes</span></span>
|
552
552
|
<span class="linenum">29</span> <span class="attribute">@cukes</span> <span class="punct">=</span> <span class="ident">cukes</span>
|
553
553
|
<span class="linenum">30</span><span class="keyword">end</span></code></pre></li> <script type="text/javascript">moveProgressBar('50.9');</script><li id='features_tons_of_cukes_feature_6' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('51.9');</script><li id='features_tons_of_cukes_feature_7' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('52.8');</script><li id='features_tons_of_cukes_feature_8' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('53.8');</script><li id='features_tons_of_cukes_feature_9' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('54.8');</script><li id='features_tons_of_cukes_feature_10' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('55.7');</script><li id='features_tons_of_cukes_feature_11' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('56.7');</script><li id='features_tons_of_cukes_feature_12' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('57.6');</script><li id='features_tons_of_cukes_feature_13' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('58.6');</script><li id='features_tons_of_cukes_feature_14' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('59.6');</script><li id='features_tons_of_cukes_feature_15' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('60.5');</script><li id='features_tons_of_cukes_feature_16' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('61.5');</script><li id='features_tons_of_cukes_feature_17' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('62.5');</script><li id='features_tons_of_cukes_feature_18' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('63.4');</script><li id='features_tons_of_cukes_feature_19' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('64.4');</script><li id='features_tons_of_cukes_feature_20' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('65.3');</script><li id='features_tons_of_cukes_feature_21' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('66.3');</script><li id='features_tons_of_cukes_feature_22' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('67.3');</script><li id='features_tons_of_cukes_feature_23' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('68.2');</script><li id='features_tons_of_cukes_feature_24' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('69.2');</script><li id='features_tons_of_cukes_feature_25' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('70.1');</script><li id='features_tons_of_cukes_feature_26' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('71.1');</script><li id='features_tons_of_cukes_feature_27' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('72.1');</script><li id='features_tons_of_cukes_feature_28' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('73.0');</script><li id='features_tons_of_cukes_feature_29' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('74.0');</script><li id='features_tons_of_cukes_feature_30' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('75.0');</script><li id='features_tons_of_cukes_feature_31' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('75.9');</script><li id='features_tons_of_cukes_feature_32' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('76.9');</script><li id='features_tons_of_cukes_feature_33' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('77.8');</script><li id='features_tons_of_cukes_feature_34' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('78.8');</script><li id='features_tons_of_cukes_feature_35' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('79.8');</script><li id='features_tons_of_cukes_feature_36' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('80.7');</script><li id='features_tons_of_cukes_feature_37' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('81.7');</script><li id='features_tons_of_cukes_feature_38' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('82.6');</script><li id='features_tons_of_cukes_feature_39' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('83.6');</script><li id='features_tons_of_cukes_feature_40' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('84.6');</script><li id='features_tons_of_cukes_feature_41' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('85.5');</script><li id='features_tons_of_cukes_feature_42' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('86.5');</script><li id='features_tons_of_cukes_feature_43' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('87.5');</script><li id='features_tons_of_cukes_feature_44' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('88.4');</script><li id='features_tons_of_cukes_feature_45' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('89.4');</script><li id='features_tons_of_cukes_feature_46' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('90.3');</script><li id='features_tons_of_cukes_feature_47' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('91.3');</script><li id='features_tons_of_cukes_feature_48' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('92.3');</script><li id='features_tons_of_cukes_feature_49' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('93.2');</script><li id='features_tons_of_cukes_feature_50' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('94.2');</script><li id='features_tons_of_cukes_feature_51' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('95.1');</script><li id='features_tons_of_cukes_feature_52' class='step skipped'><div class="step_name"><span class="keyword">Given </span><span class="step val">'<span class="param">2</span>' cukes</span></div><div class="step_file"><span>features/step_definitions/sample_steps.rb:27</span></div></li> <script type="text/javascript">moveProgressBar('96.1');</script></ol><span class="embed"><a href="" onclick="img=document.getElementById('img_24'); img.style.display = (img.style.display == 'none' ? 'block' : 'none');return false">Screenshot</a><br>
|
554
|
-
<img id="img_24" style="display: none" src=""/></span></div></div><div class="feature"><h2><span class="val">Feature: undefined multiline args</span></h2><p class="narrative"></p><div class='scenario'><span class="scenario_file">features/undefined_multiline_args.feature:3</span><h3 id="scenario_22"><span class="keyword">Scenario:</span> <span class="val">pystring</span></h3><ol><script>makeYellow('scenario_22');</script><li id='features_undefined_multiline_args_feature_4' class='step undefined'><div class="step_name"><span class="keyword">Given </span><span class="step val">a pystring</span></div><div class="step_file"><span>features/undefined_multiline_args.feature:4</span></div><pre class="val"> example</pre><pre>Given /^a pystring$/ do |string|
|
554
|
+
<img id="img_24" style="display: none" src=""/></span></div></div><div class="feature"><h2><span class="val">Feature: undefined multiline args</span></h2><p class="narrative"></p><div class='scenario'><span class="scenario_file">features/undefined_multiline_args.feature:3</span><h3 id="scenario_22"><span class="keyword">Scenario:</span> <span class="val">pystring</span></h3><ol><script>makeYellow('scenario_22');</script><li id='features_undefined_multiline_args_feature_4' class='step undefined'><div class="step_name"><span class="keyword">Given </span><span class="step val">a pystring</span></div><div class="step_file"><span>features/undefined_multiline_args.feature:4</span></div><pre class="val"> example with <html> entities</pre><pre>Given /^a pystring$/ do |string|
|
555
555
|
pending # express the regexp above with the code you wish you had
|
556
556
|
end</pre></li> <script type="text/javascript">moveProgressBar('97.1');</script></ol><span class="embed"><a href="" onclick="img=document.getElementById('img_25'); img.style.display = (img.style.display == 'none' ? 'block' : 'none');return false">Screenshot</a><br>
|
557
557
|
<img id="img_25" style="display: none" src=""/></span></div><div class='scenario'><span class="scenario_file">features/undefined_multiline_args.feature:9</span><h3 id="scenario_23"><span class="keyword">Scenario:</span> <span class="val">table</span></h3><ol><script>makeYellow('scenario_23');</script><li id='features_undefined_multiline_args_feature_10' class='step undefined'><div class="step_name"><span class="keyword">Given </span><span class="step val">a table</span></div><div class="step_file"><span>features/undefined_multiline_args.feature:10</span></div><table><tr class='step' id='row_11'><td class="step" id="row_11_0"><div><span class="step param">table</span></div></td></tr> <script type="text/javascript">moveProgressBar('99.0');</script><tr class='step' id='row_12'><td class="step" id="row_12_0"><div><span class="step param">example</span></div></td></tr> <script type="text/javascript">moveProgressBar('100.0');</script></table><pre>Given /^a table$/ do |table|
|
@@ -12,7 +12,7 @@ Feature: JUnit output formatter
|
|
12
12
|
"""
|
13
13
|
|
14
14
|
"""
|
15
|
-
And "fixtures/junit/tmp/TEST-one_passing_one_failing.xml" with junit duration "0.005" should contain
|
15
|
+
And "fixtures/junit/tmp/TEST-features-one_passing_one_failing.xml" with junit duration "0.005" should contain
|
16
16
|
"""
|
17
17
|
<?xml version="1.0" encoding="UTF-8"?>
|
18
18
|
<testsuite errors="0" failures="1" name="One passing scenario, one failing scenario" skipped="0" tests="2" time="0.005">
|
@@ -40,7 +40,7 @@ Feature: JUnit output formatter
|
|
40
40
|
"""
|
41
41
|
|
42
42
|
"""
|
43
|
-
And "fixtures/junit/tmp/TEST-
|
43
|
+
And "fixtures/junit/tmp/TEST-features-some_subdirectory-one_passing_one_failing.xml" with junit duration "0.005" should contain
|
44
44
|
"""
|
45
45
|
<?xml version="1.0" encoding="UTF-8"?>
|
46
46
|
<testsuite errors="0" failures="1" name="Subdirectory - One passing scenario, one failing scenario" skipped="0" tests="2" time="0.005">
|
@@ -68,7 +68,7 @@ Feature: JUnit output formatter
|
|
68
68
|
"""
|
69
69
|
|
70
70
|
"""
|
71
|
-
And "fixtures/junit/tmp/TEST-pending.xml" with junit duration "0.009" should contain
|
71
|
+
And "fixtures/junit/tmp/TEST-features-pending.xml" with junit duration "0.009" should contain
|
72
72
|
"""
|
73
73
|
<?xml version="1.0" encoding="UTF-8"?>
|
74
74
|
<testsuite errors="0" failures="0" name="Pending step" skipped="2" tests="2" time="0.009">
|
@@ -88,7 +88,7 @@ Feature: JUnit output formatter
|
|
88
88
|
"""
|
89
89
|
|
90
90
|
"""
|
91
|
-
And "fixtures/junit/tmp/TEST-pending.xml" with junit duration "0.000160" should contain
|
91
|
+
And "fixtures/junit/tmp/TEST-features-pending.xml" with junit duration "0.000160" should contain
|
92
92
|
"""
|
93
93
|
<?xml version="1.0" encoding="UTF-8"?>
|
94
94
|
<testsuite errors="0" failures="2" name="Pending step" skipped="0" tests="2" time="0.000160">
|
@@ -120,8 +120,8 @@ Feature: JUnit output formatter
|
|
120
120
|
"""
|
121
121
|
|
122
122
|
"""
|
123
|
-
And "fixtures/junit/tmp/TEST-one_passing_one_failing.xml" should exist
|
124
|
-
And "fixtures/junit/tmp/TEST-pending.xml" should exist
|
123
|
+
And "fixtures/junit/tmp/TEST-features-one_passing_one_failing.xml" should exist
|
124
|
+
And "fixtures/junit/tmp/TEST-features-pending.xml" should exist
|
125
125
|
|
126
126
|
Scenario: show correct error message if no --out is passed
|
127
127
|
When I run cucumber --format junit features
|
@@ -140,7 +140,7 @@ You \*must\* specify \-\-out DIR for the junit formatter
|
|
140
140
|
"""
|
141
141
|
|
142
142
|
"""
|
143
|
-
And "fixtures/junit/tmp/TEST-scenario_outline.xml" with junit duration "0.005" should contain
|
143
|
+
And "fixtures/junit/tmp/TEST-features-scenario_outline.xml" with junit duration "0.005" should contain
|
144
144
|
"""
|
145
145
|
<?xml version="1.0" encoding="UTF-8"?>
|
146
146
|
<testsuite errors="0" failures="1" name="Scenario outlines" skipped="0" tests="2" time="0.005">
|
@@ -20,6 +20,13 @@ Feature: Rerun Debugger
|
|
20
20
|
Scenario: Pending
|
21
21
|
Given pending
|
22
22
|
|
23
|
+
Scenario: Passing
|
24
|
+
Given passing
|
25
|
+
"""
|
26
|
+
And a file named "features/all_good.feature" with:
|
27
|
+
"""
|
28
|
+
Feature: Rerun
|
29
|
+
|
23
30
|
Scenario: Passing
|
24
31
|
Given passing
|
25
32
|
"""
|
@@ -37,7 +44,7 @@ Feature: Rerun Debugger
|
|
37
44
|
end
|
38
45
|
"""
|
39
46
|
|
40
|
-
When I run cucumber -f rerun features/sample.feature
|
47
|
+
When I run cucumber -f rerun features/sample.feature features/all_good.feature
|
41
48
|
Then it should fail with
|
42
49
|
"""
|
43
50
|
features/sample.feature:3:6:9
|
@@ -8,10 +8,6 @@ module Cucumber
|
|
8
8
|
class StepInvocation #:nodoc:
|
9
9
|
include Gherkin::Rubify
|
10
10
|
|
11
|
-
BACKTRACE_FILTER_PATTERNS = [
|
12
|
-
/vendor\/rails|lib\/cucumber|bin\/cucumber:|lib\/rspec|gems\//
|
13
|
-
]
|
14
|
-
|
15
11
|
attr_writer :step_collection, :background
|
16
12
|
attr_reader :name, :matched_cells, :status, :reported_exception
|
17
13
|
attr_accessor :exception
|
@@ -97,9 +93,23 @@ module Cucumber
|
|
97
93
|
end
|
98
94
|
|
99
95
|
def failed(configuration, e, clear_backtrace)
|
100
|
-
e
|
101
|
-
|
96
|
+
if Cucumber::JRUBY && e.class.name == 'NativeException'
|
97
|
+
# JRuby's NativeException ignores #set_backtrace.
|
98
|
+
# We're fixing it.
|
99
|
+
e.instance_eval do
|
100
|
+
def set_backtrace(backtrace)
|
101
|
+
@backtrace = backtrace
|
102
|
+
end
|
103
|
+
|
104
|
+
def backtrace
|
105
|
+
@backtrace
|
106
|
+
end
|
107
|
+
end
|
108
|
+
end
|
109
|
+
|
110
|
+
e.set_backtrace([]) if e.backtrace.nil? || clear_backtrace
|
102
111
|
e.backtrace << @step.backtrace_line unless @step.backtrace_line.nil?
|
112
|
+
e = filter_backtrace(e)
|
103
113
|
@exception = e
|
104
114
|
if(configuration.strict? || !(Undefined === e) || e.nested?)
|
105
115
|
@reported_exception = e
|
@@ -109,28 +119,23 @@ module Cucumber
|
|
109
119
|
end
|
110
120
|
|
111
121
|
PWD_PATTERN = /#{Regexp.escape(Dir.pwd)}\//m
|
122
|
+
BACKTRACE_FILTER_PATTERN = /vendor\/rails|lib\/cucumber|bin\/cucumber:|lib\/rspec|gems\/|minitest|test\/unit/
|
123
|
+
IN_PATTERN = /(.*):in `/
|
112
124
|
|
113
125
|
def filter_backtrace(e)
|
114
126
|
return e if Cucumber.use_full_backtrace
|
115
|
-
|
127
|
+
e.backtrace.each{|line| line.gsub!(PWD_PATTERN, "./")}
|
116
128
|
|
117
129
|
filtered = (e.backtrace || []).reject do |line|
|
118
|
-
|
130
|
+
line =~ BACKTRACE_FILTER_PATTERN
|
119
131
|
end
|
120
|
-
|
121
|
-
if Cucumber::JRUBY && e.class.name == 'NativeException'
|
122
|
-
# JRuby's NativeException ignores #set_backtrace.
|
123
|
-
# We're fixing it.
|
124
|
-
e.instance_eval do
|
125
|
-
def set_backtrace(backtrace)
|
126
|
-
@backtrace = backtrace
|
127
|
-
end
|
128
132
|
|
129
|
-
|
130
|
-
|
131
|
-
|
133
|
+
if ENV['CUCUMBER_TRUNCATE_OUTPUT']
|
134
|
+
filtered = filtered.map do |line|
|
135
|
+
line =~ IN_PATTERN ? $1 : line
|
132
136
|
end
|
133
137
|
end
|
138
|
+
|
134
139
|
e.set_backtrace(filtered)
|
135
140
|
e
|
136
141
|
end
|