Class: Cucumber::Ast::Feature

Inherits:
Object
  • Object
show all
Defined in:
lib/cucumber/ast/feature.rb

Overview

Represents the root node of a parsed feature.

Instance Attribute Summary collapse

Instance Method Summary collapse

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, tags, name, feature_elements)
  @background, @comment, @tags, @name, @feature_elements = background, comment, tags, 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

Parameters:

  • value

    the value to set the attribute features to.



6
7
8
# File 'lib/cucumber/ast/feature.rb', line 6

def features=(value)
  @features = value
end

#fileObject

Returns the value of attribute file.



7
8
9
# File 'lib/cucumber/ast/feature.rb', line 7

def file
  @file
end

#languageObject

:nodoc:



5
6
7
# File 'lib/cucumber/ast/feature.rb', line 5

def language
  @language
end

#nameObject (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.visit_tags(@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

Returns:

  • (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_nameObject



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_namesObject



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_sexpObject



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 = @tags.to_sexp
  sexp += tags if tags.any?
  sexp += [@background.to_sexp] if @background
  sexp += @feature_elements.map{|fe| fe.to_sexp}
  sexp
end