Class: Cucumber::Ast::Feature
Overview
Represents the root node of a parsed feature.
Instance Attribute Summary collapse
-
#features ⇒ Object
writeonly
Sets the attribute features.
-
#file ⇒ Object
Returns the value of attribute file.
-
#language ⇒ Object
:nodoc:.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
Instance Method Summary collapse
- #accept(visitor) ⇒ Object
- #accept_hook?(hook) ⇒ Boolean
- #backtrace_line(step_name, line) ⇒ Object
- #file_colon_line(line) ⇒ Object
-
#initialize(background, comment, tags, name, feature_elements) ⇒ Feature
constructor
A new instance of Feature.
- #next_feature_element(feature_element, &proc) ⇒ Object
- #short_name ⇒ Object
- #source_tag_names ⇒ Object
- #tag_locations(tag) ⇒ Object
- #to_sexp ⇒ Object
Constructor Details
#initialize(background, comment, tags, name, feature_elements) ⇒ Feature
Returns a new instance of Feature.
10 11 12 13 14 15 16 17 |
# File 'lib/cucumber/ast/feature.rb', line 10 def initialize(background, comment, , name, feature_elements) @background, @comment, @tags, @name, @feature_elements = background, comment, , name.strip, feature_elements background.feature = self if background @feature_elements.each do |feature_element| feature_element.feature = self end end |
Instance Attribute Details
#features=(value) ⇒ Object (writeonly)
Sets the attribute features
6 7 8 |
# File 'lib/cucumber/ast/feature.rb', line 6 def features=(value) @features = value end |
#file ⇒ Object
Returns the value of attribute file.
7 8 9 |
# File 'lib/cucumber/ast/feature.rb', line 7 def file @file end |
#language ⇒ Object
:nodoc:
5 6 7 |
# File 'lib/cucumber/ast/feature.rb', line 5 def language @language end |
#name ⇒ Object (readonly)
Returns the value of attribute name.
8 9 10 |
# File 'lib/cucumber/ast/feature.rb', line 8 def name @name end |
Instance Method Details
#accept(visitor) ⇒ Object
19 20 21 22 23 24 25 26 27 28 |
# File 'lib/cucumber/ast/feature.rb', line 19 def accept(visitor) return if Cucumber.wants_to_quit visitor.visit_comment(@comment) unless @comment.empty? visitor.(@tags) visitor.visit_feature_name(@name) visitor.visit_background(@background) if @background @feature_elements.each do |feature_element| visitor.visit_feature_element(feature_element) end end |
#accept_hook?(hook) ⇒ Boolean
34 35 36 |
# File 'lib/cucumber/ast/feature.rb', line 34 def accept_hook?(hook) @tags.accept_hook?(hook) end |
#backtrace_line(step_name, line) ⇒ Object
44 45 46 |
# File 'lib/cucumber/ast/feature.rb', line 44 def backtrace_line(step_name, line) "#{file_colon_line(line)}:in `#{step_name}'" end |
#file_colon_line(line) ⇒ Object
53 54 55 |
# File 'lib/cucumber/ast/feature.rb', line 53 def file_colon_line(line) "#{@file}:#{line}" end |
#next_feature_element(feature_element, &proc) ⇒ Object
38 39 40 41 42 |
# File 'lib/cucumber/ast/feature.rb', line 38 def next_feature_element(feature_element, &proc) index = @feature_elements.index(feature_element) next_one = @feature_elements[index+1] proc.call(next_one) if next_one end |
#short_name ⇒ Object
61 62 63 64 65 66 67 68 |
# File 'lib/cucumber/ast/feature.rb', line 61 def short_name first_line = name.split(/\n/)[0] if first_line =~ /#{language.keywords('feature', true)}:(.*)/ $1.strip else first_line end end |
#source_tag_names ⇒ Object
30 31 32 |
# File 'lib/cucumber/ast/feature.rb', line 30 def source_tag_names @tags.tag_names end |
#tag_locations(tag) ⇒ Object
57 58 59 |
# File 'lib/cucumber/ast/feature.rb', line 57 def tag_locations(tag) @feature_elements.select{|feature_element| feature_element.tagged_with?(tag)} end |
#to_sexp ⇒ Object
70 71 72 73 74 75 76 77 78 79 |
# File 'lib/cucumber/ast/feature.rb', line 70 def to_sexp sexp = [:feature, @file, @name] comment = @comment.to_sexp sexp += [comment] if comment = @tags.to_sexp sexp += if .any? sexp += [@background.to_sexp] if @background sexp += @feature_elements.map{|fe| fe.to_sexp} sexp end |