Class: Cucumber::Ast::Scenario
- Includes:
- FeatureElement
- Defined in:
- lib/cucumber/ast/scenario.rb
Overview
:nodoc:
Defined Under Namespace
Classes: EmptyBackground
Instance Attribute Summary collapse
-
#line ⇒ Object
readonly
Returns the value of attribute line.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
Attributes included from FeatureElement
Instance Method Summary collapse
- #accept(visitor) ⇒ Object
-
#exception ⇒ Object
Returns the first exception (if any).
- #fail!(exception) ⇒ Object
-
#failed? ⇒ Boolean
Returns true if one or more steps failed.
-
#initialize(background, comment, tags, line, keyword, name, steps) ⇒ Scenario
constructor
A new instance of Scenario.
-
#passed? ⇒ Boolean
Returns true if all steps passed.
- #skip_invoke! ⇒ Object
-
#status ⇒ Object
Returns the status.
- #to_sexp ⇒ Object
- #with_visitor(visitor) ⇒ Object
Methods included from FeatureElement
#accept_hook?, #attach_steps, #backtrace_line, #file_colon_line, #first_line_length, #language, #matches_scenario_names?, #max_line_length, #name_line_lengths, #source_indent, #source_tag_names, #tagged_with?, #text_length
Constructor Details
#initialize(background, comment, tags, line, keyword, name, steps) ⇒ Scenario
Returns a new instance of Scenario.
24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/cucumber/ast/scenario.rb', line 24 def initialize(background, comment, , line, keyword, name, steps) @background = background || EmptyBackground.new @comment, @tags, @line, @keyword, @name = comment, , line, keyword, name attach_steps(steps) step_invocations = steps.map{|step| step.step_invocation} @steps = @background.step_collection(step_invocations) @background.feature_elements << self @exception = @executed = nil end |
Instance Attribute Details
#line ⇒ Object (readonly)
Returns the value of attribute line.
8 9 10 |
# File 'lib/cucumber/ast/scenario.rb', line 8 def line @line end |
#name ⇒ Object (readonly)
Returns the value of attribute name.
8 9 10 |
# File 'lib/cucumber/ast/scenario.rb', line 8 def name @name end |
Instance Method Details
#accept(visitor) ⇒ Object
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
# File 'lib/cucumber/ast/scenario.rb', line 36 def accept(visitor) return if Cucumber.wants_to_quit with_visitor(visitor) do visitor.visit_comment(@comment) unless @comment.empty? visitor.(@tags) visitor.visit_scenario_name(@keyword, @name, file_colon_line(@line), source_indent(first_line_length)) skip_invoke! if @background.failed? visitor.step_mother.before_and_after(self, skip_hooks?) do skip_invoke! if failed? visitor.visit_steps(@steps) end @executed = true end end |
#exception ⇒ Object
Returns the first exception (if any)
69 70 71 |
# File 'lib/cucumber/ast/scenario.rb', line 69 def exception @exception || @steps.exception end |
#fail!(exception) ⇒ Object
58 59 60 61 |
# File 'lib/cucumber/ast/scenario.rb', line 58 def fail!(exception) @exception = exception @current_visitor.visit_exception(@exception, :failed) end |
#failed? ⇒ Boolean
Returns true if one or more steps failed
54 55 56 |
# File 'lib/cucumber/ast/scenario.rb', line 54 def failed? @steps.failed? || !!@exception end |
#passed? ⇒ Boolean
Returns true if all steps passed
64 65 66 |
# File 'lib/cucumber/ast/scenario.rb', line 64 def passed? !failed? end |
#skip_invoke! ⇒ Object
79 80 81 82 83 84 |
# File 'lib/cucumber/ast/scenario.rb', line 79 def skip_invoke! @steps.each{|step_invocation| step_invocation.skip_invoke!} @feature.next_feature_element(self) do |next_one| next_one.skip_invoke! end end |
#status ⇒ Object
Returns the status
74 75 76 77 |
# File 'lib/cucumber/ast/scenario.rb', line 74 def status return :failed if @exception @steps.status end |
#to_sexp ⇒ Object
86 87 88 89 90 91 92 93 94 95 |
# File 'lib/cucumber/ast/scenario.rb', line 86 def to_sexp sexp = [:scenario, @line, @keyword, @name] comment = @comment.to_sexp sexp += [comment] if comment = @tags.to_sexp sexp += if .any? steps = @steps.to_sexp sexp += steps if steps.any? sexp end |
#with_visitor(visitor) ⇒ Object
98 99 100 101 102 |
# File 'lib/cucumber/ast/scenario.rb', line 98 def with_visitor(visitor) @current_visitor = visitor yield @current_visitor = nil end |