cucumber 1.0.0 → 1.0.1

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.
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.1)
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.2)
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.1)
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.4.6)
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.1)
66
- childprocess (>= 0.1.7)
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.rc8)
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.1'
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
- JSON.parse(all_stdout).should == JSON.parse(json)
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
 
@@ -22,5 +22,5 @@ Before do
22
22
  # set_env('SIMPLECOV', 'true')
23
23
 
24
24
  # Set a longer timeout for aruba
25
- @aruba_timeout_seconds = 5
25
+ @aruba_timeout_seconds = 15
26
26
  end
@@ -3,7 +3,7 @@ Feature: undefined multiline args
3
3
  Scenario: pystring
4
4
  Given a pystring
5
5
  """
6
- example
6
+ example with <html> entities
7
7
  """
8
8
 
9
9
  Scenario: table
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 'Push yardoc to http://cukes.info/gherkin/api/#{GHERKIN_VERSION}'
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")
@@ -323,7 +323,7 @@ Feature: Cucumber command line
323
323
  Scenario: pystring
324
324
  Given a pystring
325
325
  \"\"\"
326
- example
326
+ example with <html> entities
327
327
  \"\"\"
328
328
 
329
329
  Scenario: table
@@ -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">&quot;</span><span class="string">We already have <span class="expr">#{@cukes}</span> cukes!</span><span class="punct">&quot;</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>&nbsp;
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 &lt;html&gt; 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>&nbsp;
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-some_subdirectory_one_passing_one_failing.xml" with junit duration "0.005" should contain
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 = filter_backtrace(e)
101
- e.set_backtrace([]) if clear_backtrace
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
- (e.backtrace || []).each{|line| line.gsub!(PWD_PATTERN, "./")}
127
+ e.backtrace.each{|line| line.gsub!(PWD_PATTERN, "./")}
116
128
 
117
129
  filtered = (e.backtrace || []).reject do |line|
118
- BACKTRACE_FILTER_PATTERNS.detect { |p| line =~ p }
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
- def backtrace
130
- @backtrace
131
- end
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