jeffrafter-cucumber 0.1.10
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/History.txt +262 -0
- data/License.txt +20 -0
- data/Manifest.txt +241 -0
- data/README.txt +41 -0
- data/Rakefile +8 -0
- data/TODO.txt +26 -0
- data/bin/cucumber +6 -0
- data/config/hoe.rb +69 -0
- data/config/requirements.rb +15 -0
- data/cucumber.yml +1 -0
- data/examples/calculator_ruby_features/Rakefile +6 -0
- data/examples/calculator_ruby_features/features/addition.rb +23 -0
- data/examples/calculator_ruby_features/features/step_definitons/calculator_steps.rb +43 -0
- data/examples/cs/README.textile +22 -0
- data/examples/cs/Rakefile +12 -0
- data/examples/cs/features/hello.feature +11 -0
- data/examples/cs/features/step_definitons/hello_steps.rb +25 -0
- data/examples/cs/features/step_definitons/tree_steps.rb +14 -0
- data/examples/cs/features/tree.feature +9 -0
- data/examples/cs/src/Hello.cs +18 -0
- data/examples/dos_line_endings/Rakefile +6 -0
- data/examples/dos_line_endings/features/dos_line_endings.feature +9 -0
- data/examples/i18n/README.textile +18 -0
- data/examples/i18n/Rakefile +16 -0
- data/examples/i18n/ar/Rakefile +6 -0
- data/examples/i18n/ar/features/addition.feature +17 -0
- data/examples/i18n/ar/features/step_definitons/calculator_steps.rb +32 -0
- data/examples/i18n/ar/lib/calculator.rb +10 -0
- data/examples/i18n/da/Rakefile +6 -0
- data/examples/i18n/da/features/step_definitons/kalkulator_steps.rb +22 -0
- data/examples/i18n/da/features/summering.feature +17 -0
- data/examples/i18n/da/lib/kalkulator.rb +11 -0
- data/examples/i18n/de/Rakefile +6 -0
- data/examples/i18n/de/features/addition.feature +17 -0
- data/examples/i18n/de/features/division.feature +10 -0
- data/examples/i18n/de/features/step_definitons/calculator_steps.rb +30 -0
- data/examples/i18n/de/lib/calculator.rb +14 -0
- data/examples/i18n/en/Rakefile +6 -0
- data/examples/i18n/en/features/addition.feature +17 -0
- data/examples/i18n/en/features/division.feature +10 -0
- data/examples/i18n/en/features/step_definitons/calculator_steps.rb +31 -0
- data/examples/i18n/en/lib/calculator.rb +14 -0
- data/examples/i18n/es/Rakefile +6 -0
- data/examples/i18n/es/features/adicion.feature +17 -0
- data/examples/i18n/es/features/step_definitons/calculador_steps.rb +22 -0
- data/examples/i18n/es/lib/calculador.rb +11 -0
- data/examples/i18n/et/Rakefile +6 -0
- data/examples/i18n/et/features/liitmine.feature +17 -0
- data/examples/i18n/et/features/step_definitions/kalkulaator_steps.rb +26 -0
- data/examples/i18n/et/lib/kalkulaator.rb +10 -0
- data/examples/i18n/fr/Rakefile +6 -0
- data/examples/i18n/fr/features/addition.feature +13 -0
- data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +22 -0
- data/examples/i18n/fr/lib/calculatrice.rb +10 -0
- data/examples/i18n/id/Rakefile +6 -0
- data/examples/i18n/id/features/addition.feature +17 -0
- data/examples/i18n/id/features/division.feature +10 -0
- data/examples/i18n/id/features/step_definitons/calculator_steps.rb +31 -0
- data/examples/i18n/id/lib/calculator.rb +14 -0
- data/examples/i18n/it/Rakefile +6 -0
- data/examples/i18n/it/features/somma.feature +10 -0
- data/examples/i18n/it/features/step_definitons/calcolatrice_steps.rb +22 -0
- data/examples/i18n/it/lib/calcolatrice.rb +11 -0
- data/examples/i18n/ja/README.txt +5 -0
- data/examples/i18n/ja/Rakefile +6 -0
- data/examples/i18n/ja/features/addition.feature +17 -0
- data/examples/i18n/ja/features/division.feature +10 -0
- data/examples/i18n/ja/features/step_definitons/calculator_steps.rb +30 -0
- data/examples/i18n/ja/lib/calculator.rb +14 -0
- data/examples/i18n/lt/Rakefile +6 -0
- data/examples/i18n/lt/features/addition.feature +17 -0
- data/examples/i18n/lt/features/division.feature +10 -0
- data/examples/i18n/lt/features/step_definitons/calculator_steps.rb +31 -0
- data/examples/i18n/lt/lib/calculator.rb +14 -0
- data/examples/i18n/no/Rakefile +6 -0
- data/examples/i18n/no/features/step_definitons/kalkulator_steps.rb +22 -0
- data/examples/i18n/no/features/summering.feature +17 -0
- data/examples/i18n/no/lib/kalkulator.rb +11 -0
- data/examples/i18n/pt/Rakefile +6 -0
- data/examples/i18n/pt/features/adicao.feature +10 -0
- data/examples/i18n/pt/features/step_definitions/calculadora_steps.rb +22 -0
- data/examples/i18n/pt/lib/calculadora.rb +10 -0
- data/examples/i18n/ro/Rakefile +6 -0
- data/examples/i18n/ro/features/step_definitons/calculator_steps.rb +22 -0
- data/examples/i18n/ro/features/suma.feature +10 -0
- data/examples/i18n/ro/lib/calculator.rb +11 -0
- data/examples/i18n/se/Rakefile +6 -0
- data/examples/i18n/se/features/step_definitons/kalkulator_steps.rb +22 -0
- data/examples/i18n/se/features/summering.feature +17 -0
- data/examples/i18n/se/lib/kalkulator.rb +11 -0
- data/examples/i18n/zh-CN/Rakefile +6 -0
- data/examples/i18n/zh-CN/features/addition.feature +17 -0
- data/examples/i18n/zh-CN/features/step_definitons/calculator_steps.rb +24 -0
- data/examples/i18n/zh-CN/lib/calculator.rb +10 -0
- data/examples/java/README.textile +22 -0
- data/examples/java/Rakefile +12 -0
- data/examples/java/features/hello.feature +11 -0
- data/examples/java/features/step_definitons/hello_steps.rb +25 -0
- data/examples/java/features/step_definitons/tree_steps.rb +14 -0
- data/examples/java/features/tree.feature +9 -0
- data/examples/java/src/cucumber/demo/Hello.java +16 -0
- data/examples/selenium/Rakefile +6 -0
- data/examples/selenium/features/search.feature +9 -0
- data/examples/selenium/features/step_definitons/stories_steps.rb +41 -0
- data/examples/test_unit/Rakefile +6 -0
- data/examples/test_unit/features/step_definitions/test_unit_steps.rb +26 -0
- data/examples/test_unit/features/test_unit.feature +9 -0
- data/examples/tickets/Rakefile +11 -0
- data/examples/tickets/cucumber.yml +2 -0
- data/examples/tickets/features/step_definitons/tickets_steps.rb +32 -0
- data/examples/tickets/features/tickets.feature +24 -0
- data/examples/watir/Rakefile +6 -0
- data/examples/watir/features/search.feature +9 -0
- data/examples/watir/features/step_definitons/stories_steps.rb +51 -0
- data/features/see_features.feature +8 -0
- data/features/steps/features_steps.rb +9 -0
- data/gem_tasks/deployment.rake +34 -0
- data/gem_tasks/environment.rake +7 -0
- data/gem_tasks/features.rake +6 -0
- data/gem_tasks/fix_cr_lf.rake +10 -0
- data/gem_tasks/flog.rake +4 -0
- data/gem_tasks/gemspec.rake +6 -0
- data/gem_tasks/rspec.rake +35 -0
- data/gem_tasks/treetop.rake +41 -0
- data/lib/autotest/cucumber.rb +6 -0
- data/lib/autotest/cucumber_mixin.rb +109 -0
- data/lib/autotest/cucumber_rails.rb +6 -0
- data/lib/autotest/cucumber_rails_rspec.rb +6 -0
- data/lib/autotest/cucumber_rspec.rb +6 -0
- data/lib/autotest/discover.rb +9 -0
- data/lib/cucumber/broadcaster.rb +20 -0
- data/lib/cucumber/cli.rb +303 -0
- data/lib/cucumber/core_ext/proc.rb +69 -0
- data/lib/cucumber/core_ext/string.rb +28 -0
- data/lib/cucumber/executor.rb +190 -0
- data/lib/cucumber/formatters/ansicolor.rb +109 -0
- data/lib/cucumber/formatters/autotest_formatter.rb +23 -0
- data/lib/cucumber/formatters/cucumber.css +132 -0
- data/lib/cucumber/formatters/cucumber.js +11 -0
- data/lib/cucumber/formatters/html_formatter.rb +128 -0
- data/lib/cucumber/formatters/jquery.js +32 -0
- data/lib/cucumber/formatters/pretty_formatter.rb +234 -0
- data/lib/cucumber/formatters/profile_formatter.rb +92 -0
- data/lib/cucumber/formatters/progress_formatter.rb +58 -0
- data/lib/cucumber/formatters.rb +1 -0
- data/lib/cucumber/languages.yml +258 -0
- data/lib/cucumber/model/table.rb +28 -0
- data/lib/cucumber/model.rb +1 -0
- data/lib/cucumber/platform.rb +12 -0
- data/lib/cucumber/rails/rspec.rb +12 -0
- data/lib/cucumber/rails/world.rb +73 -0
- data/lib/cucumber/rake/task.rb +101 -0
- data/lib/cucumber/step_methods.rb +49 -0
- data/lib/cucumber/step_mother.rb +95 -0
- data/lib/cucumber/tree/feature.rb +63 -0
- data/lib/cucumber/tree/features.rb +21 -0
- data/lib/cucumber/tree/given_scenario.rb +13 -0
- data/lib/cucumber/tree/scenario.rb +174 -0
- data/lib/cucumber/tree/step.rb +134 -0
- data/lib/cucumber/tree/table.rb +26 -0
- data/lib/cucumber/tree/top_down_visitor.rb +23 -0
- data/lib/cucumber/tree.rb +18 -0
- data/lib/cucumber/treetop_parser/feature.treetop.erb +206 -0
- data/lib/cucumber/treetop_parser/feature_ar.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_cy.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_da.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_de.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_en-tx.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_en.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_es.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_et.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_fr.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_id.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_it.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_ja.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_lt.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_nl.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_no.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_parser.rb +34 -0
- data/lib/cucumber/treetop_parser/feature_pl.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_pt.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_ro.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_ro2.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_ru.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_se.rb +1591 -0
- data/lib/cucumber/treetop_parser/feature_zh-CN.rb +1591 -0
- data/lib/cucumber/version.rb +9 -0
- data/lib/cucumber.rb +38 -0
- data/rails_generators/cucumber/USAGE +11 -0
- data/rails_generators/cucumber/cucumber_generator.rb +30 -0
- data/rails_generators/cucumber/templates/cucumber +7 -0
- data/rails_generators/cucumber/templates/cucumber.rake +7 -0
- data/rails_generators/cucumber/templates/env.rb +8 -0
- data/rails_generators/cucumber/templates/webrat_steps.rb +95 -0
- data/rails_generators/feature/USAGE +12 -0
- data/rails_generators/feature/feature_generator.rb +16 -0
- data/rails_generators/feature/templates/feature.erb +28 -0
- data/rails_generators/feature/templates/steps.erb +22 -0
- data/script/console +10 -0
- data/script/console.cmd +1 -0
- data/script/destroy +14 -0
- data/script/destroy.cmd +1 -0
- data/script/generate +14 -0
- data/script/generate.cmd +1 -0
- data/script/txt2html +74 -0
- data/script/txt2html.cmd +1 -0
- data/setup.rb +1585 -0
- data/spec/cucumber/broadcaster_spec.rb +27 -0
- data/spec/cucumber/cli_spec.rb +412 -0
- data/spec/cucumber/core_ext/proc_spec.rb +45 -0
- data/spec/cucumber/core_ext/string_spec.rb +34 -0
- data/spec/cucumber/executor_spec.rb +298 -0
- data/spec/cucumber/formatters/ansicolor_spec.rb +35 -0
- data/spec/cucumber/formatters/autotest_formatter_spec.rb +26 -0
- data/spec/cucumber/formatters/features.html +269 -0
- data/spec/cucumber/formatters/html_formatter_spec.rb +74 -0
- data/spec/cucumber/formatters/pretty_formatter_spec.rb +204 -0
- data/spec/cucumber/formatters/profile_formatter_spec.rb +192 -0
- data/spec/cucumber/formatters/progress_formatter_spec.rb +65 -0
- data/spec/cucumber/model/table_spec.rb +20 -0
- data/spec/cucumber/rails/stubs/mini_rails.rb +17 -0
- data/spec/cucumber/rails/stubs/test_help.rb +1 -0
- data/spec/cucumber/rails/world_spec.rb +11 -0
- data/spec/cucumber/sell_cucumbers.feature +19 -0
- data/spec/cucumber/step_mother_spec.rb +74 -0
- data/spec/cucumber/tree/feature_spec.rb +43 -0
- data/spec/cucumber/tree/row_scenario_spec.rb +55 -0
- data/spec/cucumber/tree/scenario_spec.rb +76 -0
- data/spec/cucumber/tree/step_spec.rb +50 -0
- data/spec/cucumber/treetop_parser/empty_feature.feature +4 -0
- data/spec/cucumber/treetop_parser/empty_scenario.feature +9 -0
- data/spec/cucumber/treetop_parser/feature_parser_spec.rb +98 -0
- data/spec/cucumber/treetop_parser/fit_scenario.feature +8 -0
- data/spec/cucumber/treetop_parser/given_scenario.feature +9 -0
- data/spec/cucumber/treetop_parser/multiline_steps.feature +17 -0
- data/spec/cucumber/treetop_parser/multiple_tables.feature +29 -0
- data/spec/cucumber/treetop_parser/spaces.feature +10 -0
- data/spec/cucumber/treetop_parser/test_dos.feature +25 -0
- data/spec/cucumber/treetop_parser/with_comments.feature +10 -0
- data/spec/spec.opts +2 -0
- data/spec/spec_helper.rb +20 -0
- metadata +335 -0
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
require File.dirname(__FILE__) + '/../spec_helper'
|
|
2
|
+
|
|
3
|
+
module Cucumber
|
|
4
|
+
describe Broadcaster do
|
|
5
|
+
|
|
6
|
+
it "should broadcast methods to registered objects" do
|
|
7
|
+
broadcaster = Broadcaster.new
|
|
8
|
+
mock_receiver = mock('receiver')
|
|
9
|
+
|
|
10
|
+
mock_receiver.should_receive(:konbanwa).with('good evening')
|
|
11
|
+
broadcaster.register(mock_receiver)
|
|
12
|
+
|
|
13
|
+
broadcaster.konbanwa('good evening')
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
it "should not call methods on registered objects if they dont support the method" do
|
|
17
|
+
broadcaster = Broadcaster.new
|
|
18
|
+
mock_receiver = mock('receiver', :respond_to? => false)
|
|
19
|
+
|
|
20
|
+
mock_receiver.should_not_receive(:konbanwa)
|
|
21
|
+
broadcaster.register(mock_receiver)
|
|
22
|
+
|
|
23
|
+
broadcaster.konbanwa()
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
end
|
|
27
|
+
end
|
|
@@ -0,0 +1,412 @@
|
|
|
1
|
+
require File.dirname(__FILE__) + '/../spec_helper'
|
|
2
|
+
require 'yaml'
|
|
3
|
+
|
|
4
|
+
module Cucumber
|
|
5
|
+
describe CLI do
|
|
6
|
+
|
|
7
|
+
def mock_executor(stubs = {})
|
|
8
|
+
stub('executor', {:visit_features => nil, :lines_for_features= => nil, :failed => false, :formatters= => nil}.merge(stubs))
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
def mock_broadcaster(stubs = {})
|
|
12
|
+
stub(Broadcaster, {:register => nil}.merge(stubs))
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def mock_features(stubs ={})
|
|
16
|
+
stub('features', {:<< => nil}.merge(stubs))
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
before(:each) do
|
|
20
|
+
Kernel.stub!(:exit)
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
def given_cucumber_yml_defined_as(hash)
|
|
24
|
+
File.stub!(:exist?).and_return(true)
|
|
25
|
+
cucumber_yml = hash.to_yaml
|
|
26
|
+
IO.stub!(:read).with('cucumber.yml').and_return(cucumber_yml)
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
it "should expand args from YAML file" do
|
|
30
|
+
cli = CLI.new
|
|
31
|
+
|
|
32
|
+
given_cucumber_yml_defined_as({'bongo' => '--require from/yml'})
|
|
33
|
+
|
|
34
|
+
cli.parse_options!(%w{--format progress --profile bongo})
|
|
35
|
+
cli.options[:formats].should == {'progress' => [STDOUT]}
|
|
36
|
+
cli.options[:require].should == ['from/yml']
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
it "should expand args from YAML file's default if there are no args" do
|
|
40
|
+
cli = CLI.new
|
|
41
|
+
|
|
42
|
+
given_cucumber_yml_defined_as({'default' => '--require from/yml'})
|
|
43
|
+
|
|
44
|
+
cli.parse_options!([])
|
|
45
|
+
cli.options[:require].should == ['from/yml']
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
it "should provide a helpful error message when a specified profile does not exists in YAML file" do
|
|
49
|
+
cli = CLI.new(StringIO.new, error = StringIO.new)
|
|
50
|
+
|
|
51
|
+
given_cucumber_yml_defined_as({'default' => '--require from/yml', 'html_report' => '--format html'})
|
|
52
|
+
|
|
53
|
+
cli.parse_options!(%w{--profile i_do_not_exist})
|
|
54
|
+
|
|
55
|
+
expected_message = <<-END_OF_MESSAGE
|
|
56
|
+
Could not find profile: 'i_do_not_exist'
|
|
57
|
+
|
|
58
|
+
Defined profiles in cucumber.yml:
|
|
59
|
+
* default
|
|
60
|
+
* html_report
|
|
61
|
+
END_OF_MESSAGE
|
|
62
|
+
|
|
63
|
+
error.string.should == expected_message
|
|
64
|
+
end
|
|
65
|
+
|
|
66
|
+
it "should provide a helpful error message when a specified profile is not a String" do
|
|
67
|
+
cli = CLI.new(StringIO.new, error = StringIO.new)
|
|
68
|
+
|
|
69
|
+
given_cucumber_yml_defined_as({'foo' => [1,2,3]})
|
|
70
|
+
|
|
71
|
+
cli.parse_options!(%w{--profile foo})
|
|
72
|
+
|
|
73
|
+
error.string.should == "Profiles must be defined as a String. The 'foo' profile was [1, 2, 3] (Array).\n"
|
|
74
|
+
end
|
|
75
|
+
|
|
76
|
+
it "should provide a helpful error message when no YAML file exists and a profile is specified" do
|
|
77
|
+
cli = CLI.new(StringIO.new, error = StringIO.new)
|
|
78
|
+
|
|
79
|
+
File.should_receive(:exist?).with('cucumber.yml').and_return(false)
|
|
80
|
+
|
|
81
|
+
cli.parse_options!(%w{--profile i_do_not_exist})
|
|
82
|
+
|
|
83
|
+
error.string.should match(/cucumber.yml was not found. Please define your 'i_do_not_exist' and other profiles in cucumber.yml./)
|
|
84
|
+
end
|
|
85
|
+
|
|
86
|
+
it "should accept --no-source option" do
|
|
87
|
+
cli = CLI.new
|
|
88
|
+
cli.parse_options!(%w{--no-source})
|
|
89
|
+
|
|
90
|
+
cli.options[:source].should be_false
|
|
91
|
+
end
|
|
92
|
+
|
|
93
|
+
it "should accept --no-snippets option" do
|
|
94
|
+
cli = CLI.new
|
|
95
|
+
cli.parse_options!(%w{--no-snippets})
|
|
96
|
+
|
|
97
|
+
cli.options[:snippets].should be_false
|
|
98
|
+
end
|
|
99
|
+
|
|
100
|
+
it "should accept --quiet option" do
|
|
101
|
+
cli = CLI.new
|
|
102
|
+
cli.parse_options!(%w{--quiet})
|
|
103
|
+
|
|
104
|
+
cli.options[:snippets].should be_false
|
|
105
|
+
cli.options[:source].should be_false
|
|
106
|
+
end
|
|
107
|
+
|
|
108
|
+
it "should accept --verbose option" do
|
|
109
|
+
cli = CLI.new
|
|
110
|
+
cli.parse_options!(%w{--verbose})
|
|
111
|
+
|
|
112
|
+
cli.options[:verbose].should be_true
|
|
113
|
+
end
|
|
114
|
+
|
|
115
|
+
describe "verbose mode" do
|
|
116
|
+
|
|
117
|
+
before(:each) do
|
|
118
|
+
@out = StringIO.new
|
|
119
|
+
@cli = CLI.new(@out)
|
|
120
|
+
@cli.stub!(:require)
|
|
121
|
+
Dir.stub!(:[])
|
|
122
|
+
end
|
|
123
|
+
|
|
124
|
+
it "should show ruby files required" do
|
|
125
|
+
@cli.parse_options!(%w{--verbose --require example.rb})
|
|
126
|
+
@cli.execute!(stub('step mother'), mock_executor, mock_features)
|
|
127
|
+
|
|
128
|
+
@out.string.should include('example.rb')
|
|
129
|
+
end
|
|
130
|
+
|
|
131
|
+
it "should show feature files parsed" do
|
|
132
|
+
TreetopParser::FeatureParser.stub!(:new).and_return(mock("feature parser", :parse_feature => nil))
|
|
133
|
+
|
|
134
|
+
@cli.parse_options!(%w{--verbose example.feature})
|
|
135
|
+
@cli.execute!(stub('step mother'), mock_executor, mock_features)
|
|
136
|
+
|
|
137
|
+
@out.string.should include('example.feature')
|
|
138
|
+
end
|
|
139
|
+
|
|
140
|
+
end
|
|
141
|
+
|
|
142
|
+
it "should accept --out option" do
|
|
143
|
+
cli = CLI.new
|
|
144
|
+
File.should_receive(:open).with('jalla.txt', 'w')
|
|
145
|
+
cli.parse_options!(%w{--out jalla.txt})
|
|
146
|
+
end
|
|
147
|
+
|
|
148
|
+
it "should accept multiple --out options" do
|
|
149
|
+
cli = CLI.new
|
|
150
|
+
mock_file1 = stub(File, :open => nil)
|
|
151
|
+
mock_file2 = stub(File, :open => nil)
|
|
152
|
+
File.stub!(:open).and_return(mock_file1, mock_file2)
|
|
153
|
+
|
|
154
|
+
cli.parse_options!(%w{--format progress --out file1 --out file2})
|
|
155
|
+
cli.options[:formats].should == {'progress' => [mock_file1, mock_file2]}
|
|
156
|
+
end
|
|
157
|
+
|
|
158
|
+
it "should accept multiple --format options" do
|
|
159
|
+
cli = CLI.new
|
|
160
|
+
cli.parse_options!(%w{--format pretty --format progress})
|
|
161
|
+
cli.options[:formats].should have_key('pretty')
|
|
162
|
+
cli.options[:formats].should have_key('progress')
|
|
163
|
+
end
|
|
164
|
+
|
|
165
|
+
it "should associate --out to previous --format" do
|
|
166
|
+
cli = CLI.new
|
|
167
|
+
mock_file1 = stub(File, :open => nil)
|
|
168
|
+
mock_file2 = stub(File, :open => nil)
|
|
169
|
+
File.stub!(:open).and_return(mock_file1, mock_file2)
|
|
170
|
+
|
|
171
|
+
cli.parse_options!(%w{--format progress --out file1 --format profile --out file2})
|
|
172
|
+
cli.options[:formats].should == {'progress' => [mock_file1], 'profile' => [mock_file2]}
|
|
173
|
+
end
|
|
174
|
+
|
|
175
|
+
it "should allow a single formatter to have STDOUT and a file" do
|
|
176
|
+
cli = CLI.new
|
|
177
|
+
mock_file = stub(File, :open => nil)
|
|
178
|
+
File.stub!(:open).and_return(mock_file)
|
|
179
|
+
|
|
180
|
+
cli.parse_options!(%w{--format progress --format progress --out file})
|
|
181
|
+
cli.options[:formats].should == {'progress' => [STDOUT, mock_file]}
|
|
182
|
+
end
|
|
183
|
+
|
|
184
|
+
it "should register --out files with an output broadcaster" do
|
|
185
|
+
cli = CLI.new
|
|
186
|
+
mock_file = stub(File)
|
|
187
|
+
File.stub!(:open).and_return(mock_file)
|
|
188
|
+
mock_output_broadcaster = mock_broadcaster
|
|
189
|
+
Broadcaster.stub!(:new).and_return(mock_broadcaster, mock_output_broadcaster)
|
|
190
|
+
|
|
191
|
+
mock_output_broadcaster.should_receive(:register).with(mock_file)
|
|
192
|
+
cli.parse_options!(%w{--out test.file})
|
|
193
|
+
|
|
194
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
195
|
+
end
|
|
196
|
+
|
|
197
|
+
it "should register --formatters with the formatter broadcaster" do
|
|
198
|
+
cli = CLI.new
|
|
199
|
+
mock_progress_formatter = stub(Formatters::ProgressFormatter)
|
|
200
|
+
Formatters::ProgressFormatter.stub!(:new).and_return(mock_progress_formatter)
|
|
201
|
+
mock_formatter_broadcaster = mock_broadcaster
|
|
202
|
+
Broadcaster.stub!(:new).and_return(mock_formatter_broadcaster, mock_broadcaster)
|
|
203
|
+
|
|
204
|
+
mock_formatter_broadcaster.should_receive(:register).with(mock_progress_formatter)
|
|
205
|
+
cli.parse_options!(%w{--format progress})
|
|
206
|
+
|
|
207
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
208
|
+
end
|
|
209
|
+
|
|
210
|
+
it "should setup the executor with the formatter broadcaster" do
|
|
211
|
+
cli = CLI.new
|
|
212
|
+
broadcaster = Broadcaster.new
|
|
213
|
+
Broadcaster.stub!(:new).and_return(broadcaster)
|
|
214
|
+
mock_executor = mock_executor()
|
|
215
|
+
mock_executor.should_receive(:formatters=).with(broadcaster)
|
|
216
|
+
cli.parse_options!(%w{--format progress})
|
|
217
|
+
|
|
218
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
219
|
+
end
|
|
220
|
+
|
|
221
|
+
describe "external formatter" do
|
|
222
|
+
|
|
223
|
+
describe "exists and valid constructor" do
|
|
224
|
+
|
|
225
|
+
before(:each) do
|
|
226
|
+
@mock_formatter_class = mock('formatter class')
|
|
227
|
+
Kernel.stub!(:const_get).and_return(@mock_formatter_class)
|
|
228
|
+
end
|
|
229
|
+
|
|
230
|
+
it "should create the formatter" do
|
|
231
|
+
cli = CLI.new
|
|
232
|
+
mock_formatter = mock('magical formatter')
|
|
233
|
+
cli.parse_options!(%w{--format magical})
|
|
234
|
+
|
|
235
|
+
@mock_formatter_class.should_receive(:new)
|
|
236
|
+
|
|
237
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
238
|
+
end
|
|
239
|
+
|
|
240
|
+
it "should register the formatter with broadcaster" do
|
|
241
|
+
cli = CLI.new
|
|
242
|
+
broadcaster = Broadcaster.new
|
|
243
|
+
mock_formatter = mock('magical formatter')
|
|
244
|
+
Broadcaster.stub!(:new).and_return(broadcaster, stub("output broadcaster", :register => nil))
|
|
245
|
+
@mock_formatter_class.stub!(:new).and_return(mock_formatter)
|
|
246
|
+
cli.parse_options!(%w{--format magical})
|
|
247
|
+
|
|
248
|
+
broadcaster.should_receive(:register).with(mock_formatter)
|
|
249
|
+
|
|
250
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
251
|
+
end
|
|
252
|
+
|
|
253
|
+
end
|
|
254
|
+
|
|
255
|
+
describe "exists but invalid constructor" do
|
|
256
|
+
|
|
257
|
+
before(:each) do
|
|
258
|
+
@out = StringIO.new
|
|
259
|
+
@error = StringIO.new
|
|
260
|
+
@cli = CLI.new(@out, @error)
|
|
261
|
+
|
|
262
|
+
mock_formatter_class = stub('formatter class')
|
|
263
|
+
mock_formatter_class.stub!(:new).and_raise("No such method")
|
|
264
|
+
Kernel.stub!(:const_get).and_return(mock_formatter_class)
|
|
265
|
+
|
|
266
|
+
@cli.parse_options!(%w{--format exists_but_evil})
|
|
267
|
+
end
|
|
268
|
+
|
|
269
|
+
it "should show exception" do
|
|
270
|
+
Kernel.stub!(:exit)
|
|
271
|
+
|
|
272
|
+
@cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
273
|
+
|
|
274
|
+
@error.string.should include("No such method")
|
|
275
|
+
end
|
|
276
|
+
|
|
277
|
+
it "should exit" do
|
|
278
|
+
Kernel.should_receive(:exit)
|
|
279
|
+
|
|
280
|
+
@cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
281
|
+
end
|
|
282
|
+
|
|
283
|
+
end
|
|
284
|
+
|
|
285
|
+
describe "non-existent" do
|
|
286
|
+
|
|
287
|
+
before(:each) do
|
|
288
|
+
@out = StringIO.new
|
|
289
|
+
@error = StringIO.new
|
|
290
|
+
@cli = CLI.new(@out, @error)
|
|
291
|
+
|
|
292
|
+
@cli.parse_options!(%w{--format invalid})
|
|
293
|
+
end
|
|
294
|
+
|
|
295
|
+
it "should display a format error" do
|
|
296
|
+
Kernel.stub!(:exit)
|
|
297
|
+
|
|
298
|
+
@cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
299
|
+
|
|
300
|
+
@error.string.should include("Invalid format: invalid\n")
|
|
301
|
+
end
|
|
302
|
+
|
|
303
|
+
it "should display --help" do
|
|
304
|
+
Kernel.stub!(:exit)
|
|
305
|
+
|
|
306
|
+
@cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
307
|
+
|
|
308
|
+
@out.string.should include("Usage: cucumber")
|
|
309
|
+
end
|
|
310
|
+
|
|
311
|
+
it "should exit" do
|
|
312
|
+
Kernel.should_receive(:exit)
|
|
313
|
+
|
|
314
|
+
@cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
315
|
+
end
|
|
316
|
+
|
|
317
|
+
end
|
|
318
|
+
|
|
319
|
+
end
|
|
320
|
+
|
|
321
|
+
it "should accept multiple --scenario options" do
|
|
322
|
+
cli = CLI.new
|
|
323
|
+
cli.parse_options!(['--scenario', "User logs in", '--scenario', "User signs up"])
|
|
324
|
+
cli.options[:scenario_names].should include("User logs in")
|
|
325
|
+
cli.options[:scenario_names].should include("User signs up")
|
|
326
|
+
end
|
|
327
|
+
|
|
328
|
+
it "should register --scenario options with the executor" do
|
|
329
|
+
cli = CLI.new
|
|
330
|
+
cli.parse_options!(['--scenario', "User logs in", '--scenario', "User signs up"])
|
|
331
|
+
executor = mock_executor
|
|
332
|
+
executor.should_receive(:scenario_names=).with(["User logs in", "User signs up"])
|
|
333
|
+
cli.execute!(stub('step mother'), executor, stub('features'))
|
|
334
|
+
end
|
|
335
|
+
|
|
336
|
+
it "should accept --color option" do
|
|
337
|
+
cli = CLI.new
|
|
338
|
+
cli.parse_options!(['--color'])
|
|
339
|
+
cli.options[:color].should == true
|
|
340
|
+
Term::ANSIColor.should_receive(:coloring=).with(true)
|
|
341
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
342
|
+
end
|
|
343
|
+
|
|
344
|
+
it "should accept --no-color option" do
|
|
345
|
+
cli = CLI.new
|
|
346
|
+
cli.parse_options!(['--no-color'])
|
|
347
|
+
cli.options[:color].should == false
|
|
348
|
+
Term::ANSIColor.should_receive(:coloring=).with(false)
|
|
349
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
350
|
+
end
|
|
351
|
+
|
|
352
|
+
it "should accept --color and --no-color and use the last one" do
|
|
353
|
+
cli = CLI.new
|
|
354
|
+
cli.parse_options!(['--color', '--no-color'])
|
|
355
|
+
cli.options[:color].should == false
|
|
356
|
+
Term::ANSIColor.should_receive(:coloring=).with(false)
|
|
357
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
358
|
+
end
|
|
359
|
+
|
|
360
|
+
it "should use a default color setting if no option is given" do
|
|
361
|
+
cli = CLI.new
|
|
362
|
+
cli.parse_options!(['--'])
|
|
363
|
+
cli.options[:color].should == nil
|
|
364
|
+
Term::ANSIColor.should_not_receive(:coloring=)
|
|
365
|
+
cli.execute!(stub('step mother'), mock_executor, stub('features'))
|
|
366
|
+
end
|
|
367
|
+
|
|
368
|
+
describe "example.feature:line file arguments" do
|
|
369
|
+
|
|
370
|
+
it "should extract line numbers" do
|
|
371
|
+
cli = CLI.new
|
|
372
|
+
cli.parse_options!(%w{example.feature:10})
|
|
373
|
+
|
|
374
|
+
cli.options[:lines_for_features]['example.feature'].should == [10]
|
|
375
|
+
end
|
|
376
|
+
|
|
377
|
+
it "should remove line numbers" do
|
|
378
|
+
cli = CLI.new
|
|
379
|
+
cli.parse_options!(%w{example.feature:10})
|
|
380
|
+
|
|
381
|
+
cli.paths.should == ["example.feature"]
|
|
382
|
+
end
|
|
383
|
+
|
|
384
|
+
it "should support multiple feature:line numbers" do
|
|
385
|
+
cli = CLI.new
|
|
386
|
+
cli.parse_options!(%w{example.feature:11 another_example.feature:12})
|
|
387
|
+
|
|
388
|
+
cli.options[:lines_for_features].should == {'another_example.feature' => [12], 'example.feature' => [11]}
|
|
389
|
+
end
|
|
390
|
+
|
|
391
|
+
it "should accept multiple line numbers for a single feature" do
|
|
392
|
+
cli = CLI.new
|
|
393
|
+
cli.parse_options!(%w{example.feature:11:12})
|
|
394
|
+
|
|
395
|
+
cli.options[:lines_for_features].should == {'example.feature' => [11, 12]}
|
|
396
|
+
end
|
|
397
|
+
|
|
398
|
+
end
|
|
399
|
+
|
|
400
|
+
it "should search for all features in the specified directory" do
|
|
401
|
+
cli = CLI.new
|
|
402
|
+
|
|
403
|
+
cli.parse_options!(%w{feature_directory/})
|
|
404
|
+
File.stub!(:directory?).and_return(true)
|
|
405
|
+
|
|
406
|
+
Dir.should_receive(:[]).with("feature_directory/**/*.feature").any_number_of_times.and_return([])
|
|
407
|
+
|
|
408
|
+
cli.execute!(stub('step mother'), mock_executor, mock_features)
|
|
409
|
+
end
|
|
410
|
+
|
|
411
|
+
end
|
|
412
|
+
end
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
require File.dirname(__FILE__) + '/../../spec_helper'
|
|
2
|
+
|
|
3
|
+
module Cucumber
|
|
4
|
+
module CoreExt
|
|
5
|
+
describe "proc extended with CallIn" do
|
|
6
|
+
it "should raise ArityMismatchError for too many args (expecting 0)" do
|
|
7
|
+
proc = lambda {}
|
|
8
|
+
proc.extend CallIn
|
|
9
|
+
lambda {
|
|
10
|
+
proc.call_in(Object.new, 1)
|
|
11
|
+
}.should raise_error(Cucumber::ArityMismatchError, "expected 0 block argument(s), got 1")
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
it "should raise ArityMismatchError for too many args (expecting 1)" do
|
|
15
|
+
proc = lambda {|a|}
|
|
16
|
+
proc.extend CallIn
|
|
17
|
+
lambda {
|
|
18
|
+
proc.call_in(Object.new, 1, 2)
|
|
19
|
+
}.should raise_error(Cucumber::ArityMismatchError, "expected 1 block argument(s), got 2")
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
it "should raise ArityMismatchError for too few args (expecting 1)" do
|
|
23
|
+
proc = lambda {|a|}
|
|
24
|
+
proc.extend CallIn
|
|
25
|
+
lambda {
|
|
26
|
+
proc.call_in(Object.new)
|
|
27
|
+
}.should raise_error(Cucumber::ArityMismatchError, "expected 1 block argument(s), got 0")
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
it "should raise ArityMismatchError for too few args (expecting 2)" do
|
|
31
|
+
proc = lambda {|a,b|}
|
|
32
|
+
proc.extend CallIn
|
|
33
|
+
lambda {
|
|
34
|
+
proc.call_in(Object.new, 1)
|
|
35
|
+
}.should raise_error(Cucumber::ArityMismatchError, "expected 2 block argument(s), got 1")
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
it "should remove extraneous path info for file" do
|
|
39
|
+
proc = lambda {|a,b|}
|
|
40
|
+
proc.extend CallIn
|
|
41
|
+
proc.file_colon_line.should == "spec/cucumber/core_ext/proc_spec.rb:39"
|
|
42
|
+
end
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
require File.dirname(__FILE__) + '/../../../lib/cucumber/core_ext/string'
|
|
2
|
+
|
|
3
|
+
describe String, "#gzub" do
|
|
4
|
+
it "should format groups with format string" do
|
|
5
|
+
"I ate 1 egg this morning".gzub(/I (\w+) (\d+) (\w+) this (\w+)/, "<span>%s</span>").should ==
|
|
6
|
+
"I <span>ate</span> <span>1</span> <span>egg</span> this <span>morning</span>"
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
it "should format groups with format string when there are dupes" do
|
|
10
|
+
"I bob 1 bo this bobs".gzub(/I (\w+) (\d+) (\w+) this (\w+)/, "<span>%s</span>").should ==
|
|
11
|
+
"I <span>bob</span> <span>1</span> <span>bo</span> this <span>bobs</span>"
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
it "should format groups with block" do
|
|
15
|
+
f = "I ate 1 egg this morning".gzub(/I (\w+) (\d+) (\w+) this (\w+)/) do |m|
|
|
16
|
+
"<span>#{m}</span>"
|
|
17
|
+
end
|
|
18
|
+
f.should == "I <span>ate</span> <span>1</span> <span>egg</span> this <span>morning</span>"
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
it "should format groups with block with not all placeholders having a value" do
|
|
22
|
+
f = "another member named Bob joins the group".gzub(/(a|another) (user|member) named ([^ ]+)( who is not logged in)?/) do |m|
|
|
23
|
+
"<span>#{m}</span>"
|
|
24
|
+
end
|
|
25
|
+
f.should == "<span>another</span> <span>member</span> named <span>Bob</span> joins the group"
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
it "should format match groups in a textile table row" do
|
|
29
|
+
f = "I ate 1 egg this morning".gzub(/I (\w+) (\d+) (\w+) this (\w+)/) do |m|
|
|
30
|
+
"<span>#{m}</span>"
|
|
31
|
+
end
|
|
32
|
+
f.should == "I <span>ate</span> <span>1</span> <span>egg</span> this <span>morning</span>"
|
|
33
|
+
end
|
|
34
|
+
end
|