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 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