aslakhellesoy-cucumber 0.1.99.3 → 0.1.99.4
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/Manifest.txt +6 -0
- metadata +1 -1
- data/cucumber.yml +0 -1
- data/examples/cs/README.textile +0 -1
- data/examples/cs/Rakefile +0 -12
- data/examples/cs/compile.bat +0 -1
- data/examples/cs/features/addition.feature +0 -16
- data/examples/cs/features/step_definitons/calculator_steps.rb +0 -19
- data/examples/cs/src/demo/Calculator.cs +0 -20
- data/examples/dos_line_endings/Rakefile +0 -6
- data/examples/dos_line_endings/features/dos_line_endings.feature +0 -9
- data/examples/i18n/README.textile +0 -18
- data/examples/i18n/Rakefile +0 -32
- data/examples/i18n/ar/Rakefile +0 -6
- data/examples/i18n/ar/features/addition.feature +0 -17
- data/examples/i18n/ar/features/step_definitons/calculator_steps.rb +0 -28
- data/examples/i18n/ar/lib/calculator.rb +0 -10
- data/examples/i18n/da/Rakefile +0 -6
- data/examples/i18n/da/features/step_definitons/kalkulator_steps.rb +0 -24
- data/examples/i18n/da/features/summering.feature +0 -17
- data/examples/i18n/da/lib/kalkulator.rb +0 -11
- data/examples/i18n/de/Rakefile +0 -6
- data/examples/i18n/de/features/addition.feature +0 -16
- data/examples/i18n/de/features/division.feature +0 -9
- data/examples/i18n/de/features/step_definitons/calculator_steps.rb +0 -24
- data/examples/i18n/de/lib/calculator.rb +0 -14
- data/examples/i18n/en/Rakefile +0 -6
- data/examples/i18n/en/features/addition.feature +0 -16
- data/examples/i18n/en/features/division.feature +0 -9
- data/examples/i18n/en/features/step_definitons/calculator_steps.rb +0 -24
- data/examples/i18n/en/lib/calculator.rb +0 -14
- data/examples/i18n/es/Rakefile +0 -6
- data/examples/i18n/es/features/adicion.feature +0 -17
- data/examples/i18n/es/features/step_definitons/calculador_steps.rb +0 -24
- data/examples/i18n/es/lib/calculador.rb +0 -11
- data/examples/i18n/et/Rakefile +0 -6
- data/examples/i18n/et/features/liitmine.feature +0 -17
- data/examples/i18n/et/features/step_definitions/kalkulaator_steps.rb +0 -24
- data/examples/i18n/et/lib/kalkulaator.rb +0 -10
- data/examples/i18n/fi/Rakefile +0 -6
- data/examples/i18n/fi/features/jakolasku.feature +0 -9
- data/examples/i18n/fi/features/step_definitons/laskin_steps.rb +0 -24
- data/examples/i18n/fi/features/yhteenlasku.feature +0 -16
- data/examples/i18n/fi/lib/laskin.rb +0 -14
- data/examples/i18n/fr/Rakefile +0 -6
- data/examples/i18n/fr/features/addition.feature +0 -15
- data/examples/i18n/fr/features/step_definitions/calculatrice_steps.rb +0 -27
- data/examples/i18n/fr/lib/calculatrice.rb +0 -10
- data/examples/i18n/id/Rakefile +0 -6
- data/examples/i18n/id/features/addition.feature +0 -16
- data/examples/i18n/id/features/division.feature +0 -9
- data/examples/i18n/id/features/step_definitons/calculator_steps.rb +0 -24
- data/examples/i18n/id/lib/calculator.rb +0 -14
- data/examples/i18n/it/Rakefile +0 -6
- data/examples/i18n/it/features/somma.feature +0 -10
- data/examples/i18n/it/features/step_definitons/calcolatrice_steps.rb +0 -24
- data/examples/i18n/it/lib/calcolatrice.rb +0 -11
- data/examples/i18n/ja/README.txt +0 -5
- data/examples/i18n/ja/Rakefile +0 -6
- data/examples/i18n/ja/features/addition.feature +0 -16
- data/examples/i18n/ja/features/division.feature +0 -9
- data/examples/i18n/ja/features/step_definitons/calculator_steps.rb +0 -24
- data/examples/i18n/ja/lib/calculator.rb +0 -14
- data/examples/i18n/ko/Rakefile +0 -6
- data/examples/i18n/ko/features/addition.feature +0 -16
- data/examples/i18n/ko/features/division.feature +0 -10
- data/examples/i18n/ko/features/step_definitons/calculator_steps.rb +0 -24
- data/examples/i18n/ko/lib/calculator.rb +0 -14
- data/examples/i18n/lt/Rakefile +0 -6
- data/examples/i18n/lt/features/addition.feature +0 -17
- data/examples/i18n/lt/features/division.feature +0 -9
- data/examples/i18n/lt/features/step_definitons/calculator_steps.rb +0 -24
- data/examples/i18n/lt/lib/calculator.rb +0 -14
- data/examples/i18n/no/Rakefile +0 -6
- data/examples/i18n/no/features/step_definitons/kalkulator_steps.rb +0 -24
- data/examples/i18n/no/features/summering.feature +0 -18
- data/examples/i18n/no/lib/kalkulator.rb +0 -11
- data/examples/i18n/pt/Rakefile +0 -6
- data/examples/i18n/pt/features/adicao.feature +0 -10
- data/examples/i18n/pt/features/step_definitions/calculadora_steps.rb +0 -24
- data/examples/i18n/pt/lib/calculadora.rb +0 -10
- data/examples/i18n/ro/Rakefile +0 -6
- data/examples/i18n/ro/features/step_definitons/calculator_steps.rb +0 -24
- data/examples/i18n/ro/features/suma.feature +0 -10
- data/examples/i18n/ro/lib/calculator.rb +0 -11
- data/examples/i18n/se/Rakefile +0 -6
- data/examples/i18n/se/features/step_definitons/kalkulator_steps.rb +0 -24
- data/examples/i18n/se/features/summering.feature +0 -17
- data/examples/i18n/se/lib/kalkulator.rb +0 -11
- data/examples/i18n/zh-CN/Rakefile +0 -6
- data/examples/i18n/zh-CN/features/addition.feature +0 -17
- data/examples/i18n/zh-CN/features/step_definitons/calculator_steps.rb +0 -26
- data/examples/i18n/zh-CN/lib/calculator.rb +0 -10
- data/examples/java/README.textile +0 -22
- data/examples/java/Rakefile +0 -12
- data/examples/java/features/hello.feature +0 -11
- data/examples/java/features/step_definitons/hello_steps.rb +0 -25
- data/examples/java/features/step_definitons/tree_steps.rb +0 -14
- data/examples/java/features/tree.feature +0 -9
- data/examples/jbehave/README.textile +0 -17
- data/examples/jbehave/features/support/env.rb +0 -7
- data/examples/jbehave/features/trading.feature +0 -24
- data/examples/jbehave/pom.xml +0 -48
- data/examples/selenium/Rakefile +0 -6
- data/examples/selenium/features/search.feature +0 -9
- data/examples/selenium/features/step_definitons/stories_steps.rb +0 -40
- data/examples/self_test/README.textile +0 -6
- data/examples/self_test/features/call_undefined_step_from_step_def.feature +0 -7
- data/examples/self_test/features/lots_of_undefined.feature +0 -8
- data/examples/self_test/features/outline_sample.feature +0 -12
- data/examples/self_test/features/sample.feature +0 -16
- data/examples/self_test/features/step_definitions/sample_steps.rb +0 -25
- data/examples/test_unit/Rakefile +0 -6
- data/examples/test_unit/features/step_definitions/test_unit_steps.rb +0 -26
- data/examples/test_unit/features/test_unit.feature +0 -9
- data/examples/tickets/Rakefile +0 -11
- data/examples/tickets/cucumber.yml +0 -2
- data/examples/tickets/features/lib/eatting_machine.rb +0 -18
- data/examples/tickets/features/lib/pantry.rb +0 -20
- data/examples/tickets/features/scenario_outline.feature +0 -90
- data/examples/tickets/features/step_definitons/scenario_outline_steps.rb +0 -42
- data/examples/tickets/features/step_definitons/tickets_steps.rb +0 -61
- data/examples/tickets/features/tickets.feature +0 -28
- data/examples/watir/README.textile +0 -16
- data/examples/watir/Rakefile +0 -6
- data/examples/watir/features/search.feature +0 -9
- data/examples/watir/features/step_definitons/search_steps.rb +0 -24
- data/examples/watir/features/support/env.rb +0 -32
- data/features/cucumber_cli.feature +0 -327
- data/features/cucumber_cli_outlines.feature +0 -81
- data/features/report_called_undefined_steps.feature +0 -32
- data/features/step_definitions/cucumber_steps.rb +0 -31
- data/features/step_definitions/extra_steps.rb +0 -2
- data/features/support/env.rb +0 -7
- data/gem_tasks/deployment.rake +0 -11
- data/gem_tasks/environment.rake +0 -7
- data/gem_tasks/features.rake +0 -6
- data/gem_tasks/fix_cr_lf.rake +0 -10
- data/gem_tasks/flog.rake +0 -4
- data/gem_tasks/gemspec.rake +0 -10
- data/gem_tasks/rspec.rake +0 -35
- data/gem_tasks/yard.rake +0 -8
- data/lib/autotest/cucumber.rb +0 -6
- data/lib/autotest/cucumber_mixin.rb +0 -124
- data/lib/autotest/cucumber_rails.rb +0 -6
- data/lib/autotest/cucumber_rails_rspec.rb +0 -6
- data/lib/autotest/cucumber_rspec.rb +0 -6
- data/lib/autotest/discover.rb +0 -9
- data/lib/cucumber/ast/comment.rb +0 -26
- data/lib/cucumber/ast/examples.rb +0 -22
- data/lib/cucumber/ast/feature.rb +0 -60
- data/lib/cucumber/ast/features.rb +0 -39
- data/lib/cucumber/ast/filter.rb +0 -22
- data/lib/cucumber/ast/outline_table.rb +0 -49
- data/lib/cucumber/ast/py_string.rb +0 -52
- data/lib/cucumber/ast/scenario.rb +0 -95
- data/lib/cucumber/ast/scenario_outline.rb +0 -83
- data/lib/cucumber/ast/step.rb +0 -139
- data/lib/cucumber/ast/table.rb +0 -214
- data/lib/cucumber/ast/tags.rb +0 -33
- data/lib/cucumber/ast/visitor.rb +0 -93
- data/lib/cucumber/ast.rb +0 -27
- data/lib/cucumber/broadcaster.rb +0 -15
- data/lib/cucumber/cli.rb +0 -410
- data/lib/cucumber/core_ext/exception.rb +0 -53
- data/lib/cucumber/core_ext/instance_exec.rb +0 -54
- data/lib/cucumber/core_ext/proc.rb +0 -33
- data/lib/cucumber/core_ext/string.rb +0 -48
- data/lib/cucumber/formatter/ansicolor.rb +0 -106
- data/lib/cucumber/formatter/console.rb +0 -116
- data/lib/cucumber/formatter/pretty.rb +0 -158
- data/lib/cucumber/formatter/profile.rb +0 -77
- data/lib/cucumber/formatter/progress.rb +0 -68
- data/lib/cucumber/formatter/rerun.rb +0 -35
- data/lib/cucumber/formatter.rb +0 -1
- data/lib/cucumber/formatters/autotest_formatter.rb +0 -21
- data/lib/cucumber/formatters/cucumber.css +0 -132
- data/lib/cucumber/formatters/cucumber.js +0 -11
- data/lib/cucumber/formatters/html_formatter.rb +0 -152
- data/lib/cucumber/formatters/jquery.js +0 -32
- data/lib/cucumber/formatters/pretty_formatter.rb +0 -285
- data/lib/cucumber/formatters/unicode.rb +0 -35
- data/lib/cucumber/jbehave.rb +0 -104
- data/lib/cucumber/languages.yml +0 -314
- data/lib/cucumber/parser/basic.rb +0 -0
- data/lib/cucumber/parser/feature.rb +0 -1315
- data/lib/cucumber/parser/feature.tt +0 -160
- data/lib/cucumber/parser/i18n.tt +0 -27
- data/lib/cucumber/parser/table.rb +0 -396
- data/lib/cucumber/parser/table.tt +0 -53
- data/lib/cucumber/parser/treetop_ext.rb +0 -67
- data/lib/cucumber/parser.rb +0 -24
- data/lib/cucumber/platform.rb +0 -18
- data/lib/cucumber/rails/rspec.rb +0 -5
- data/lib/cucumber/rails/world.rb +0 -73
- data/lib/cucumber/rake/task.rb +0 -106
- data/lib/cucumber/step_definition.rb +0 -87
- data/lib/cucumber/step_mother.rb +0 -164
- data/lib/cucumber/treetop_parser/feature_fi.rb +0 -1951
- data/lib/cucumber/version.rb +0 -10
- data/lib/cucumber.rb +0 -72
- data/pretty.txt +0 -486
- data/rails_generators/cucumber/USAGE +0 -11
- data/rails_generators/cucumber/cucumber_generator.rb +0 -31
- data/rails_generators/cucumber/templates/cucumber +0 -8
- data/rails_generators/cucumber/templates/cucumber.rake +0 -7
- data/rails_generators/cucumber/templates/env.rb +0 -16
- data/rails_generators/cucumber/templates/paths.rb +0 -12
- data/rails_generators/cucumber/templates/webrat_steps.rb +0 -99
- data/rails_generators/feature/USAGE +0 -12
- data/rails_generators/feature/feature_generator.rb +0 -36
- data/rails_generators/feature/templates/feature.erb +0 -31
- data/rails_generators/feature/templates/steps.erb +0 -24
- data/spec/cucumber/ast/feature_factory.rb +0 -54
- data/spec/cucumber/ast/feature_spec.rb +0 -60
- data/spec/cucumber/ast/py_string_spec.rb +0 -40
- data/spec/cucumber/ast/scenario_outline_spec.rb +0 -64
- data/spec/cucumber/ast/scenario_spec.rb +0 -82
- data/spec/cucumber/ast/step_spec.rb +0 -45
- data/spec/cucumber/ast/table_spec.rb +0 -81
- data/spec/cucumber/broadcaster_spec.rb +0 -14
- data/spec/cucumber/cli_spec.rb +0 -416
- data/spec/cucumber/core_ext/proc_spec.rb +0 -37
- data/spec/cucumber/core_ext/string_spec.rb +0 -42
- data/spec/cucumber/formatter/ansicolor_spec.rb +0 -35
- data/spec/cucumber/formatter/html/cucumber.css +0 -37
- data/spec/cucumber/formatter/html/cucumber.js +0 -11
- data/spec/cucumber/formatter/html/index.html +0 -45
- data/spec/cucumber/formatter/html/jquery-1.3.min.js +0 -19
- data/spec/cucumber/formatter/html/jquery.uitableedit.js +0 -100
- data/spec/cucumber/formatters/autotest_formatter_spec.rb +0 -27
- data/spec/cucumber/formatters/features.html +0 -269
- data/spec/cucumber/formatters/profile_formatter_spec.rb +0 -198
- data/spec/cucumber/parser/feature_parser_spec.rb +0 -247
- data/spec/cucumber/parser/table_parser_spec.rb +0 -48
- data/spec/cucumber/rails/stubs/mini_rails.rb +0 -18
- data/spec/cucumber/rails/stubs/test_help.rb +0 -1
- data/spec/cucumber/rails/world_spec.rb +0 -11
- data/spec/cucumber/sell_cucumbers.feature +0 -19
- data/spec/cucumber/step_definition_spec.rb +0 -62
- data/spec/cucumber/step_mom_spec.rb +0 -49
- data/spec/cucumber/treetop_parser/empty_feature.feature +0 -4
- data/spec/cucumber/treetop_parser/empty_scenario.feature +0 -9
- data/spec/cucumber/treetop_parser/empty_scenario_outline.feature +0 -3
- data/spec/cucumber/treetop_parser/fit_scenario.feature +0 -8
- data/spec/cucumber/treetop_parser/given_scenario.feature +0 -9
- data/spec/cucumber/treetop_parser/invalid_scenario_outlines.feature +0 -7
- data/spec/cucumber/treetop_parser/multiline_steps.feature +0 -17
- data/spec/cucumber/treetop_parser/multiple_tables.feature +0 -27
- data/spec/cucumber/treetop_parser/scenario_outline.feature +0 -16
- data/spec/cucumber/treetop_parser/spaces.feature +0 -12
- data/spec/cucumber/treetop_parser/test_dos.feature +0 -25
- data/spec/cucumber/treetop_parser/with_comments.feature +0 -10
- data/spec/cucumber/treetop_parser/with_tags.feature +0 -18
- data/spec/cucumber/world/pending_spec.rb +0 -47
- data/spec/spec.opts +0 -2
- data/spec/spec_helper.rb +0 -21
@@ -1,83 +0,0 @@
|
|
1
|
-
module Cucumber
|
2
|
-
module Ast
|
3
|
-
class ScenarioOutline < Scenario
|
4
|
-
# The +example_sections+ argument must be an Array where each element is another array representing
|
5
|
-
# an Examples section. This array has 3 elements:
|
6
|
-
#
|
7
|
-
# * Examples keyword
|
8
|
-
# * Examples section name
|
9
|
-
# * Raw matrix
|
10
|
-
def initialize(comment, tags, line, keyword, name, steps, example_sections)
|
11
|
-
super(comment, tags, line, keyword, name, steps)
|
12
|
-
steps.each {|step| step.status = :outline}
|
13
|
-
|
14
|
-
@examples_array = example_sections.map do |example_section|
|
15
|
-
examples_line = example_section[0]
|
16
|
-
examples_keyword = example_section[1]
|
17
|
-
examples_name = example_section[2]
|
18
|
-
examples_matrix = example_section[3]
|
19
|
-
|
20
|
-
examples_table = OutlineTable.new(examples_matrix, self)
|
21
|
-
Examples.new(examples_line, examples_keyword, examples_name, examples_table)
|
22
|
-
end
|
23
|
-
end
|
24
|
-
|
25
|
-
def at_lines?(lines)
|
26
|
-
super || @examples_array.detect { |examples| examples.at_lines?(lines) }
|
27
|
-
end
|
28
|
-
|
29
|
-
def accept(visitor)
|
30
|
-
visitor.visit_comment(@comment)
|
31
|
-
visitor.visit_tags(@tags)
|
32
|
-
visitor.visit_scenario_name(@keyword, @name, file_line(@line), source_indent(text_length))
|
33
|
-
@steps.each do |step|
|
34
|
-
visitor.visit_step(step)
|
35
|
-
end
|
36
|
-
@examples_array.each do |examples|
|
37
|
-
visitor.visit_examples(examples)
|
38
|
-
end
|
39
|
-
end
|
40
|
-
|
41
|
-
def execute_row(cells, visitor, &proc)
|
42
|
-
exception = nil
|
43
|
-
visitor.world(self) do |world|
|
44
|
-
previous_status = :passed
|
45
|
-
argument_hash = cells.to_hash
|
46
|
-
cell_index = 0
|
47
|
-
@steps.each do |step|
|
48
|
-
executed_step, previous_status, matched_args =
|
49
|
-
step.execute_with_arguments(argument_hash, world, previous_status, visitor, cells[0].line)
|
50
|
-
# There might be steps that don't have any arguments
|
51
|
-
# If there are no matched args, we'll still iterate once
|
52
|
-
matched_args = [nil] if matched_args.empty?
|
53
|
-
|
54
|
-
matched_args.each do
|
55
|
-
cell = cells[cell_index]
|
56
|
-
if cell
|
57
|
-
proc.call(cell, previous_status)
|
58
|
-
cell_index += 1
|
59
|
-
end
|
60
|
-
end
|
61
|
-
exception ||= executed_step.exception
|
62
|
-
end
|
63
|
-
end
|
64
|
-
@feature.scenario_executed(self) if @feature
|
65
|
-
exception
|
66
|
-
end
|
67
|
-
|
68
|
-
def pending? ; false ; end
|
69
|
-
|
70
|
-
def to_sexp
|
71
|
-
sexp = [:scenario_outline, @keyword, @name]
|
72
|
-
comment = @comment.to_sexp
|
73
|
-
sexp += [comment] if comment
|
74
|
-
tags = @tags.to_sexp
|
75
|
-
sexp += tags if tags.any?
|
76
|
-
steps = @steps.map{|step| step.to_sexp}
|
77
|
-
sexp += steps if steps.any?
|
78
|
-
sexp += @examples_array.map{|e| e.to_sexp}
|
79
|
-
sexp
|
80
|
-
end
|
81
|
-
end
|
82
|
-
end
|
83
|
-
end
|
data/lib/cucumber/ast/step.rb
DELETED
@@ -1,139 +0,0 @@
|
|
1
|
-
require 'cucumber/step_definition'
|
2
|
-
require 'cucumber/core_ext/string'
|
3
|
-
|
4
|
-
module Cucumber
|
5
|
-
module Ast
|
6
|
-
class Step
|
7
|
-
attr_reader :keyword, :name
|
8
|
-
attr_writer :world, :previous, :options
|
9
|
-
attr_accessor :status, :scenario, :exception
|
10
|
-
|
11
|
-
def initialize(line, keyword, name, *multiline_args)
|
12
|
-
@line, @keyword, @name, @multiline_args = line, keyword, name, multiline_args
|
13
|
-
end
|
14
|
-
|
15
|
-
def execute_with_arguments(argument_hash, world, previous, visitor, row_line)
|
16
|
-
delimited_arguments = delimit_argument_names(argument_hash)
|
17
|
-
name = replace_name_arguments(delimited_arguments)
|
18
|
-
multiline_args = replace_multiline_args_arguments(delimited_arguments)
|
19
|
-
|
20
|
-
execute_twin(world, previous, visitor, row_line, name, *multiline_args)
|
21
|
-
end
|
22
|
-
|
23
|
-
def accept(visitor)
|
24
|
-
execute(visitor)
|
25
|
-
visitor.visit_step_name(@keyword, @name, @status, @step_definition, source_indent)
|
26
|
-
@multiline_args.each do |multiline_arg|
|
27
|
-
visitor.visit_multiline_arg(multiline_arg, @status)
|
28
|
-
end
|
29
|
-
@exception
|
30
|
-
end
|
31
|
-
|
32
|
-
def to_sexp
|
33
|
-
[:step, @line, @keyword, @name, *@multiline_args.map{|arg| arg.to_sexp}]
|
34
|
-
end
|
35
|
-
|
36
|
-
def at_lines?(lines)
|
37
|
-
lines.empty? || lines.index(@line) || @multiline_args.detect{|a| a.at_lines?(lines)}
|
38
|
-
end
|
39
|
-
|
40
|
-
def source_indent
|
41
|
-
@scenario.source_indent(text_length)
|
42
|
-
end
|
43
|
-
|
44
|
-
def text_length
|
45
|
-
@keyword.jlength + @name.jlength + 2 # Add 2 because steps get indented 2 more than scenarios
|
46
|
-
end
|
47
|
-
|
48
|
-
def backtrace_line
|
49
|
-
@backtrace_line ||= @scenario.backtrace_line("#{@keyword} #{@name}", @line) unless @scenario.nil?
|
50
|
-
end
|
51
|
-
|
52
|
-
def file_line
|
53
|
-
@file_line ||= @scenario.file_line(@line) unless @scenario.nil?
|
54
|
-
end
|
55
|
-
|
56
|
-
def actual_keyword
|
57
|
-
if [Cucumber.keyword_hash['and'], Cucumber.keyword_hash['but']].index(@keyword) && previous_step
|
58
|
-
previous_step.actual_keyword
|
59
|
-
else
|
60
|
-
@keyword
|
61
|
-
end
|
62
|
-
end
|
63
|
-
|
64
|
-
protected
|
65
|
-
|
66
|
-
def previous_step
|
67
|
-
@scenario.previous_step(self)
|
68
|
-
end
|
69
|
-
|
70
|
-
private
|
71
|
-
|
72
|
-
def execute(visitor)
|
73
|
-
matched_args = []
|
74
|
-
if @status.nil?
|
75
|
-
begin
|
76
|
-
@step_definition = visitor.step_definition(@name)
|
77
|
-
matched_args = @step_definition.matched_args(@name)
|
78
|
-
if @previous == :passed && !visitor.options[:dry_run]
|
79
|
-
@world.__cucumber_current_step = self
|
80
|
-
@step_definition.execute(@name, @world, *(matched_args + @multiline_args))
|
81
|
-
@status = :passed
|
82
|
-
else
|
83
|
-
@status = :skipped
|
84
|
-
end
|
85
|
-
rescue StepMother::Undefined => exception
|
86
|
-
if visitor.options[:strict]
|
87
|
-
exception.set_backtrace([])
|
88
|
-
failed(exception)
|
89
|
-
else
|
90
|
-
@status = :undefined
|
91
|
-
end
|
92
|
-
rescue StepMother::Pending => exception
|
93
|
-
visitor.options[:strict] ? failed(exception) : @status = :pending
|
94
|
-
rescue Exception => exception
|
95
|
-
failed(exception)
|
96
|
-
end
|
97
|
-
@scenario.step_executed(self) if @scenario
|
98
|
-
end
|
99
|
-
[self, @status, matched_args]
|
100
|
-
end
|
101
|
-
|
102
|
-
def execute_twin(world, previous, visitor, line, name, *multiline_args)
|
103
|
-
# We'll create a new step and execute that
|
104
|
-
step = Step.new(line, @keyword, name, *multiline_args)
|
105
|
-
step.scenario = @scenario
|
106
|
-
step.world = world
|
107
|
-
step.previous = previous
|
108
|
-
step.__send__(:execute, visitor)
|
109
|
-
end
|
110
|
-
|
111
|
-
ARGUMENT_START = '<'
|
112
|
-
ARGUMENT_END = '>'
|
113
|
-
|
114
|
-
def delimit_argument_names(argument_hash)
|
115
|
-
argument_hash.inject({}) { |h,(k,v)| h["#{ARGUMENT_START}#{k}#{ARGUMENT_END}"] = v; h }
|
116
|
-
end
|
117
|
-
|
118
|
-
def replace_name_arguments(argument_hash)
|
119
|
-
name_with_arguments_replaced = @name
|
120
|
-
argument_hash.each do |name, value|
|
121
|
-
name_with_arguments_replaced = name_with_arguments_replaced.gsub(name, value)
|
122
|
-
end
|
123
|
-
name_with_arguments_replaced
|
124
|
-
end
|
125
|
-
|
126
|
-
def replace_multiline_args_arguments(arguments)
|
127
|
-
@multiline_args.map do |arg|
|
128
|
-
arg.arguments_replaced(arguments)
|
129
|
-
end
|
130
|
-
end
|
131
|
-
|
132
|
-
def failed(exception)
|
133
|
-
@status = :failed
|
134
|
-
@exception = exception
|
135
|
-
@exception.backtrace << backtrace_line unless backtrace_line.nil?
|
136
|
-
end
|
137
|
-
end
|
138
|
-
end
|
139
|
-
end
|
data/lib/cucumber/ast/table.rb
DELETED
@@ -1,214 +0,0 @@
|
|
1
|
-
module Cucumber
|
2
|
-
module Ast
|
3
|
-
# Holds the data of a table parsed from a feature file:
|
4
|
-
#
|
5
|
-
# | a | b |
|
6
|
-
# | c | d |
|
7
|
-
#
|
8
|
-
# This gets parsed into a Table holding the values <tt>[['a', 'b'], ['c', 'd']]</tt>
|
9
|
-
#
|
10
|
-
class Table
|
11
|
-
attr_accessor :file
|
12
|
-
|
13
|
-
def initialize(raw)
|
14
|
-
# Verify that it's square
|
15
|
-
raw.transpose
|
16
|
-
@raw = raw
|
17
|
-
@cells_class = Cells
|
18
|
-
@cell_class = Cell
|
19
|
-
end
|
20
|
-
|
21
|
-
def at_lines?(lines)
|
22
|
-
rows.detect { |row| row.at_lines?(lines) }
|
23
|
-
end
|
24
|
-
|
25
|
-
def accept(visitor, status)
|
26
|
-
rows.each do |row|
|
27
|
-
visitor.visit_table_row(row, status)
|
28
|
-
end
|
29
|
-
nil
|
30
|
-
end
|
31
|
-
|
32
|
-
# Converts this table into an Array of Hash where the keys of each
|
33
|
-
# Hash are the headers in the table. For example, a Table built from
|
34
|
-
# the following plain text:
|
35
|
-
#
|
36
|
-
# | a | b | sum |
|
37
|
-
# | 2 | 3 | 5 |
|
38
|
-
# | 7 | 9 | 16 |
|
39
|
-
#
|
40
|
-
# Gets converted into the following:
|
41
|
-
#
|
42
|
-
# [{'a' => '2', 'b' => '3', 'sum' => '5'}, {'a' => '7', 'b' => '9', 'sum' => '16'}]
|
43
|
-
#
|
44
|
-
def hashes
|
45
|
-
@hashes ||= rows[1..-1].map do |row|
|
46
|
-
row.to_hash
|
47
|
-
end
|
48
|
-
end
|
49
|
-
|
50
|
-
# Gets the raw data of this table. For example, a Table built from
|
51
|
-
# the following plain text:
|
52
|
-
#
|
53
|
-
# | a | b |
|
54
|
-
# | c | d |
|
55
|
-
#
|
56
|
-
# Get converted into the following:
|
57
|
-
#
|
58
|
-
# [['a', 'b], ['c', 'd']]
|
59
|
-
#
|
60
|
-
def raw
|
61
|
-
@raw
|
62
|
-
end
|
63
|
-
|
64
|
-
# Same as #raw, but skips the first (header) row
|
65
|
-
def rows
|
66
|
-
@raw[1..-1]
|
67
|
-
end
|
68
|
-
|
69
|
-
# For testing only
|
70
|
-
def to_sexp #:nodoc:
|
71
|
-
[:table, *rows.map{|row| row.to_sexp}]
|
72
|
-
end
|
73
|
-
|
74
|
-
def to_hash(cells) #:nodoc:
|
75
|
-
hash = {}
|
76
|
-
@raw[0].each_with_index do |key, n|
|
77
|
-
hash[key] = cells.value(n)
|
78
|
-
end
|
79
|
-
hash
|
80
|
-
end
|
81
|
-
|
82
|
-
def index(cells) #:nodoc:
|
83
|
-
rows.index(cells)
|
84
|
-
end
|
85
|
-
|
86
|
-
def arguments_replaced(arguments) #:nodoc:
|
87
|
-
raw_with_replaced_args = raw.map do |row|
|
88
|
-
row.map do |cell|
|
89
|
-
cell_with_replaced_args = cell
|
90
|
-
arguments.each do |name, value|
|
91
|
-
cell_with_replaced_args = cell_with_replaced_args.gsub(name, value)
|
92
|
-
end
|
93
|
-
cell_with_replaced_args
|
94
|
-
end
|
95
|
-
end
|
96
|
-
|
97
|
-
Table.new(raw_with_replaced_args)
|
98
|
-
end
|
99
|
-
|
100
|
-
def at_lines?(lines)
|
101
|
-
rows.detect{|row| row.at_lines?(lines)}
|
102
|
-
end
|
103
|
-
|
104
|
-
private
|
105
|
-
|
106
|
-
def col_width(col)
|
107
|
-
columns[col].__send__(:width)
|
108
|
-
end
|
109
|
-
|
110
|
-
def rows
|
111
|
-
@rows ||= cell_matrix.map do |cell_row|
|
112
|
-
@cells_class.new(self, cell_row)
|
113
|
-
end
|
114
|
-
end
|
115
|
-
|
116
|
-
def columns
|
117
|
-
@columns ||= cell_matrix.transpose.map do |cell_row|
|
118
|
-
@cells_class.new(self, cell_row)
|
119
|
-
end
|
120
|
-
end
|
121
|
-
|
122
|
-
def cell_matrix
|
123
|
-
row = -1
|
124
|
-
@cell_matrix ||= @raw.map do |raw_row|
|
125
|
-
line = raw_row.line rescue -1
|
126
|
-
row += 1
|
127
|
-
col = -1
|
128
|
-
raw_row.map do |raw_cell|
|
129
|
-
col += 1
|
130
|
-
@cell_class.new(raw_cell, self, row, col, line)
|
131
|
-
end
|
132
|
-
end
|
133
|
-
end
|
134
|
-
|
135
|
-
# Represents a row of cells or columns of cells
|
136
|
-
class Cells
|
137
|
-
include Enumerable
|
138
|
-
|
139
|
-
def initialize(table, cells)
|
140
|
-
@table, @cells = table, cells
|
141
|
-
end
|
142
|
-
|
143
|
-
def accept(visitor, status)
|
144
|
-
each do |cell|
|
145
|
-
visitor.visit_table_cell(cell, status)
|
146
|
-
end
|
147
|
-
nil
|
148
|
-
end
|
149
|
-
|
150
|
-
# For testing only
|
151
|
-
def to_sexp #:nodoc:
|
152
|
-
[:row, *@cells.map{|cell| cell.to_sexp}]
|
153
|
-
end
|
154
|
-
|
155
|
-
def to_hash #:nodoc:
|
156
|
-
@to_hash ||= @table.to_hash(self)
|
157
|
-
end
|
158
|
-
|
159
|
-
def value(n) #:nodoc:
|
160
|
-
self[n].value
|
161
|
-
end
|
162
|
-
|
163
|
-
def [](n)
|
164
|
-
@cells[n]
|
165
|
-
end
|
166
|
-
|
167
|
-
def line
|
168
|
-
@cells[0].line
|
169
|
-
end
|
170
|
-
|
171
|
-
def at_lines?(lines)
|
172
|
-
lines.empty? || lines.index(line)
|
173
|
-
end
|
174
|
-
|
175
|
-
private
|
176
|
-
|
177
|
-
def index
|
178
|
-
@table.index(self)
|
179
|
-
end
|
180
|
-
|
181
|
-
def width
|
182
|
-
map{|cell| cell.value ? cell.value.jlength : 0}.max
|
183
|
-
end
|
184
|
-
|
185
|
-
def each(&proc)
|
186
|
-
@cells.each(&proc)
|
187
|
-
end
|
188
|
-
end
|
189
|
-
|
190
|
-
class Cell
|
191
|
-
attr_reader :value, :line
|
192
|
-
|
193
|
-
def initialize(value, table, row, col, line)
|
194
|
-
@value, @table, @row, @col, @line = value, table, row, col, line
|
195
|
-
end
|
196
|
-
|
197
|
-
def accept(visitor, status)
|
198
|
-
visitor.visit_table_cell_value(@value, col_width, status)
|
199
|
-
end
|
200
|
-
|
201
|
-
# For testing only
|
202
|
-
def to_sexp #:nodoc:
|
203
|
-
[:cell, @value]
|
204
|
-
end
|
205
|
-
|
206
|
-
private
|
207
|
-
|
208
|
-
def col_width
|
209
|
-
@col_width ||= @table.__send__(:col_width, @col)
|
210
|
-
end
|
211
|
-
end
|
212
|
-
end
|
213
|
-
end
|
214
|
-
end
|
data/lib/cucumber/ast/tags.rb
DELETED
@@ -1,33 +0,0 @@
|
|
1
|
-
module Cucumber
|
2
|
-
module Ast
|
3
|
-
# Holds the names of tags parsed from a feature file:
|
4
|
-
#
|
5
|
-
# @invoice @release_2
|
6
|
-
#
|
7
|
-
# This gets stored internally as <tt>["invoice", "release_2"]</tt>
|
8
|
-
#
|
9
|
-
class Tags
|
10
|
-
def initialize(line, tag_names)
|
11
|
-
@line, @tag_names = line, tag_names
|
12
|
-
end
|
13
|
-
|
14
|
-
def among?(tag_names)
|
15
|
-
(@tag_names & tag_names).any?
|
16
|
-
end
|
17
|
-
|
18
|
-
def at_lines?(lines)
|
19
|
-
lines.empty? || lines.index(@line)
|
20
|
-
end
|
21
|
-
|
22
|
-
def accept(visitor)
|
23
|
-
@tag_names.each do |tag_name|
|
24
|
-
visitor.visit_tag_name(tag_name)
|
25
|
-
end
|
26
|
-
end
|
27
|
-
|
28
|
-
def to_sexp
|
29
|
-
@tag_names.map{|tag_name| [:tag, tag_name]}
|
30
|
-
end
|
31
|
-
end
|
32
|
-
end
|
33
|
-
end
|
data/lib/cucumber/ast/visitor.rb
DELETED
@@ -1,93 +0,0 @@
|
|
1
|
-
module Cucumber
|
2
|
-
module Ast
|
3
|
-
# A dumb visitor that implements the whole Visitor API and just walks the tree.
|
4
|
-
class Visitor
|
5
|
-
attr_accessor :options
|
6
|
-
|
7
|
-
def initialize(step_mother)
|
8
|
-
@step_mother = step_mother
|
9
|
-
end
|
10
|
-
|
11
|
-
def world(scenario, &proc)
|
12
|
-
@step_mother.world(scenario, &proc)
|
13
|
-
end
|
14
|
-
|
15
|
-
def step_definition(step_name)
|
16
|
-
@step_mother.step_definition(step_name)
|
17
|
-
end
|
18
|
-
|
19
|
-
def current_feature_lines=(lines)
|
20
|
-
@current_feature_lines = lines
|
21
|
-
end
|
22
|
-
|
23
|
-
def current_feature_lines
|
24
|
-
@current_feature_lines || []
|
25
|
-
end
|
26
|
-
|
27
|
-
def visit_features(features)
|
28
|
-
features.accept(self)
|
29
|
-
end
|
30
|
-
|
31
|
-
def visit_feature(feature)
|
32
|
-
feature.accept(self)
|
33
|
-
end
|
34
|
-
|
35
|
-
def visit_comment(comment)
|
36
|
-
comment.accept(self)
|
37
|
-
end
|
38
|
-
|
39
|
-
def visit_comment_line(comment_line)
|
40
|
-
end
|
41
|
-
|
42
|
-
def visit_tags(tags)
|
43
|
-
tags.accept(self)
|
44
|
-
end
|
45
|
-
|
46
|
-
def visit_tag_name(tag_name)
|
47
|
-
end
|
48
|
-
|
49
|
-
def visit_feature_name(name)
|
50
|
-
end
|
51
|
-
|
52
|
-
# +feature_element+ is either Scenario or ScenarioOutline
|
53
|
-
def visit_feature_element(feature_element)
|
54
|
-
feature_element.accept(self)
|
55
|
-
end
|
56
|
-
|
57
|
-
def visit_examples(examples)
|
58
|
-
examples.accept(self)
|
59
|
-
end
|
60
|
-
|
61
|
-
def visit_examples_name(keyword, name)
|
62
|
-
end
|
63
|
-
|
64
|
-
def visit_scenario_name(keyword, name, file_line, source_indent)
|
65
|
-
end
|
66
|
-
|
67
|
-
def visit_step(step)
|
68
|
-
step.accept(self)
|
69
|
-
end
|
70
|
-
|
71
|
-
def visit_step_name(keyword, step_name, status, step_definition, source_indent)
|
72
|
-
end
|
73
|
-
|
74
|
-
def visit_multiline_arg(multiline_arg, status)
|
75
|
-
multiline_arg.accept(self, status)
|
76
|
-
end
|
77
|
-
|
78
|
-
def visit_py_string(string, status)
|
79
|
-
end
|
80
|
-
|
81
|
-
def visit_table_row(table_row, status)
|
82
|
-
table_row.accept(self, status)
|
83
|
-
end
|
84
|
-
|
85
|
-
def visit_table_cell(table_cell, status)
|
86
|
-
table_cell.accept(self, status)
|
87
|
-
end
|
88
|
-
|
89
|
-
def visit_table_cell_value(value, width, status)
|
90
|
-
end
|
91
|
-
end
|
92
|
-
end
|
93
|
-
end
|
data/lib/cucumber/ast.rb
DELETED
@@ -1,27 +0,0 @@
|
|
1
|
-
require 'cucumber/ast/comment'
|
2
|
-
require 'cucumber/ast/tags'
|
3
|
-
require 'cucumber/ast/features'
|
4
|
-
require 'cucumber/ast/feature'
|
5
|
-
require 'cucumber/ast/scenario'
|
6
|
-
require 'cucumber/ast/scenario_outline'
|
7
|
-
require 'cucumber/ast/step'
|
8
|
-
require 'cucumber/ast/table'
|
9
|
-
require 'cucumber/ast/py_string'
|
10
|
-
require 'cucumber/ast/outline_table'
|
11
|
-
require 'cucumber/ast/examples'
|
12
|
-
require 'cucumber/ast/visitor'
|
13
|
-
require 'cucumber/ast/filter'
|
14
|
-
|
15
|
-
module Cucumber
|
16
|
-
# Classes in this module represent the Abstract Syntax Tree (AST)
|
17
|
-
# that gets built when feature files are parsed.
|
18
|
-
#
|
19
|
-
# AST classes don't expose any internal data directly. This is
|
20
|
-
# in order to encourage a less coupled design in the classes
|
21
|
-
# that operate on the AST. The only public method is #accept.
|
22
|
-
#
|
23
|
-
# The AST can be traversed with a visitor. See Cucumber::Format::Pretty
|
24
|
-
# for an example.
|
25
|
-
module Ast
|
26
|
-
end
|
27
|
-
end
|
data/lib/cucumber/broadcaster.rb
DELETED