Class: Cucumber::Ast::StepInvocation
- Defined in:
- lib/cucumber/ast/step_invocation.rb
Overview
:nodoc:
Constant Summary collapse
- BACKTRACE_FILTER_PATTERNS =
[ /vendor\/rails|lib\/cucumber|bin\/cucumber:|lib\/rspec|gems\// ]
Instance Attribute Summary collapse
-
#background ⇒ Object
writeonly
Sets the attribute background.
-
#exception ⇒ Object
Returns the value of attribute exception.
-
#matched_cells ⇒ Object
readonly
Returns the value of attribute matched_cells.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
-
#reported_exception ⇒ Object
readonly
Returns the value of attribute reported_exception.
-
#status ⇒ Object
readonly
Returns the value of attribute status.
-
#step_collection ⇒ Object
writeonly
Sets the attribute step_collection.
Instance Method Summary collapse
- #accept(visitor) ⇒ Object
- #actual_keyword ⇒ Object
- #background? ⇒ Boolean
- #backtrace_line ⇒ Object
- #dom_id ⇒ Object
- #failed(options, e, clear_backtrace) ⇒ Object
- #file_colon_line ⇒ Object
- #filter_backtrace(e) ⇒ Object
- #find_step_match!(step_mother) ⇒ Object
-
#initialize(step, name, multiline_arg, matched_cells) ⇒ StepInvocation
constructor
A new instance of StepInvocation.
- #invoke(step_mother, options) ⇒ Object
- #keyword ⇒ Object
- #language ⇒ Object
- #multiline_arg ⇒ Object
- #previous ⇒ Object
- #skip_invoke! ⇒ Object
- #source_indent ⇒ Object
- #status!(status) ⇒ Object
- #text_length ⇒ Object
- #to_sexp ⇒ Object
- #visit_step_result(visitor) ⇒ Object
Constructor Details
#initialize(step, name, multiline_arg, matched_cells) ⇒ StepInvocation
Returns a new instance of StepInvocation.
14 15 16 17 |
# File 'lib/cucumber/ast/step_invocation.rb', line 14 def initialize(step, name, multiline_arg, matched_cells) @step, @name, @multiline_arg, @matched_cells = step, name, multiline_arg, matched_cells status!(:skipped) end |
Instance Attribute Details
#background=(value) ⇒ Object (writeonly)
Sets the attribute background
10 11 12 |
# File 'lib/cucumber/ast/step_invocation.rb', line 10 def background=(value) @background = value end |
#exception ⇒ Object
Returns the value of attribute exception.
12 13 14 |
# File 'lib/cucumber/ast/step_invocation.rb', line 12 def exception @exception end |
#matched_cells ⇒ Object (readonly)
Returns the value of attribute matched_cells.
11 12 13 |
# File 'lib/cucumber/ast/step_invocation.rb', line 11 def matched_cells @matched_cells end |
#name ⇒ Object (readonly)
Returns the value of attribute name.
11 12 13 |
# File 'lib/cucumber/ast/step_invocation.rb', line 11 def name @name end |
#reported_exception ⇒ Object (readonly)
Returns the value of attribute reported_exception.
11 12 13 |
# File 'lib/cucumber/ast/step_invocation.rb', line 11 def reported_exception @reported_exception end |
#status ⇒ Object (readonly)
Returns the value of attribute status.
11 12 13 |
# File 'lib/cucumber/ast/step_invocation.rb', line 11 def status @status end |
#step_collection=(value) ⇒ Object (writeonly)
Sets the attribute step_collection
10 11 12 |
# File 'lib/cucumber/ast/step_invocation.rb', line 10 def step_collection=(value) @step_collection = value end |
Instance Method Details
#accept(visitor) ⇒ Object
27 28 29 30 31 |
# File 'lib/cucumber/ast/step_invocation.rb', line 27 def accept(visitor) return if $cucumber_interrupted invoke(visitor.step_mother, visitor.) visit_step_result(visitor) end |
#actual_keyword ⇒ Object
120 121 122 123 124 125 126 127 |
# File 'lib/cucumber/ast/step_invocation.rb', line 120 def actual_keyword repeat_keywords = [language.but_keywords, language.and_keywords].flatten if repeat_keywords.index(@step.keyword) && previous previous.actual_keyword else keyword end end |
#background? ⇒ Boolean
19 20 21 |
# File 'lib/cucumber/ast/step_invocation.rb', line 19 def background? @background end |
#backtrace_line ⇒ Object
153 154 155 |
# File 'lib/cucumber/ast/step_invocation.rb', line 153 def backtrace_line @step.backtrace_line end |
#dom_id ⇒ Object
149 150 151 |
# File 'lib/cucumber/ast/step_invocation.rb', line 149 def dom_id @step.dom_id end |
#failed(options, e, clear_backtrace) ⇒ Object
74 75 76 77 78 79 80 81 82 83 84 |
# File 'lib/cucumber/ast/step_invocation.rb', line 74 def failed(, e, clear_backtrace) e = filter_backtrace(e) e.set_backtrace([]) if clear_backtrace e.backtrace << @step.backtrace_line unless @step.backtrace_line.nil? @exception = e if([:strict] || !(Undefined === e) || e.nested?) @reported_exception = e else @reported_exception = nil end end |
#file_colon_line ⇒ Object
145 146 147 |
# File 'lib/cucumber/ast/step_invocation.rb', line 145 def file_colon_line @step.file_colon_line end |
#filter_backtrace(e) ⇒ Object
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 |
# File 'lib/cucumber/ast/step_invocation.rb', line 86 def filter_backtrace(e) return e if Cucumber.use_full_backtrace filtered = (e.backtrace || []).reject do |line| BACKTRACE_FILTER_PATTERNS.detect { |p| line =~ p } end if Cucumber::JRUBY && e.class.name == 'NativeException' # JRuby's NativeException ignores #set_backtrace. # We're fixing it. e.instance_eval do def set_backtrace(backtrace) @backtrace = backtrace end def backtrace @backtrace end end end e.set_backtrace(filtered) e end |
#find_step_match!(step_mother) ⇒ Object
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 |
# File 'lib/cucumber/ast/step_invocation.rb', line 58 def find_step_match!(step_mother) return if @step_match begin @step_match = step_mother.step_match(@name) rescue Undefined => e failed(step_mother., e, true) status!(:undefined) @step_match = NoStepMatch.new(@step, @name) rescue Ambiguous => e failed(step_mother., e, false) status!(:failed) @step_match = NoStepMatch.new(@step, @name) end step_mother.step_visited(self) end |
#invoke(step_mother, options) ⇒ Object
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
# File 'lib/cucumber/ast/step_invocation.rb', line 37 def invoke(step_mother, ) find_step_match!(step_mother) unless @skip_invoke || [:dry_run] || @exception || @step_collection.exception @skip_invoke = true begin @step_match.invoke(@multiline_arg) step_mother.after_step status!(:passed) rescue Pending => e failed(, e, false) status!(:pending) rescue Undefined => e failed(, e, false) status!(:undefined) rescue Exception => e failed(, e, false) status!(:failed) end end end |
#keyword ⇒ Object
137 138 139 |
# File 'lib/cucumber/ast/step_invocation.rb', line 137 def keyword @step.keyword end |
#language ⇒ Object
157 158 159 |
# File 'lib/cucumber/ast/step_invocation.rb', line 157 def language @step.language end |
#multiline_arg ⇒ Object
141 142 143 |
# File 'lib/cucumber/ast/step_invocation.rb', line 141 def multiline_arg @step.multiline_arg end |
#previous ⇒ Object
116 117 118 |
# File 'lib/cucumber/ast/step_invocation.rb', line 116 def previous @step_collection.previous_step(self) end |
#skip_invoke! ⇒ Object
23 24 25 |
# File 'lib/cucumber/ast/step_invocation.rb', line 23 def skip_invoke! @skip_invoke = true end |
#source_indent ⇒ Object
129 130 131 |
# File 'lib/cucumber/ast/step_invocation.rb', line 129 def source_indent @step.feature_element.source_indent(text_length) end |
#status!(status) ⇒ Object
109 110 111 112 113 114 |
# File 'lib/cucumber/ast/step_invocation.rb', line 109 def status!(status) @status = status @matched_cells.each do |cell| cell.status = status end end |
#text_length ⇒ Object
133 134 135 |
# File 'lib/cucumber/ast/step_invocation.rb', line 133 def text_length @step.text_length(@name) end |
#to_sexp ⇒ Object
161 162 163 |
# File 'lib/cucumber/ast/step_invocation.rb', line 161 def to_sexp [:step_invocation, @step.line, @step.keyword, @name, (@multiline_arg.nil? ? nil : @multiline_arg.to_sexp)].compact end |
#visit_step_result(visitor) ⇒ Object
33 34 35 |
# File 'lib/cucumber/ast/step_invocation.rb', line 33 def visit_step_result(visitor) visitor.visit_step_result(keyword, @step_match, @multiline_arg, @status, @reported_exception, source_indent, @background) end |