class CukeModeler::Outline

A class modeling an individual outline in a Cucumber suite.

Attributes

examples[RW]

The Example objects contained by the Outline

keyword[RW]

The outline's keyword

Public Class Methods

new(source_text = nil) click to toggle source

Creates a new Outline object and, if source_text is provided, populates the object.

Calls superclass method CukeModeler::Model::new
# File lib/cuke_modeler/models/outline.rb, line 24
def initialize(source_text = nil)
  @steps = []
  @tags = []
  @examples = []

  super(source_text)

  return unless source_text

  parsed_outline_data = parse_source(source_text)
  populate_outline(self, parsed_outline_data)
end

Public Instance Methods

==(other) click to toggle source

Returns true if the two models have equivalent steps and false otherwise.

# File lib/cuke_modeler/models/outline.rb, line 38
def ==(other)
  return false unless other.respond_to?(:steps)

  steps == other.steps
end
children() click to toggle source

Returns the model objects that belong to this model.

# File lib/cuke_modeler/models/outline.rb, line 45
def children
  examples + steps + tags
end
to_s() click to toggle source

Returns a string representation of this model. For an outline model, this will be Gherkin text that is equivalent to the outline being modeled.

# File lib/cuke_modeler/models/outline.rb, line 54
def to_s
  text = ''

  text << "#{tag_output_string}\n" unless tags.empty?
  text << "#{@keyword}:#{name_output_string}"
  text << "\n#{description_output_string}" unless no_description_to_output?
  text << "\n" unless steps.empty? || no_description_to_output?
  text << "\n#{steps_output_string}" unless steps.empty?
  text << "\n\n#{examples_output_string}" unless examples.empty?

  text
end

Private Instance Methods

examples_output_string() click to toggle source
# File lib/cuke_modeler/models/outline.rb, line 82
def examples_output_string
  examples.empty? ? '' : examples.join("\n\n")
end
parse_source(source_text) click to toggle source

rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity

# File lib/cuke_modeler/models/outline.rb, line 73
def parse_source(source_text)
  base_file_string = "# language: #{Parsing.dialect}\n#{dialect_feature_keyword}: Fake feature to parse\n"
  source_text = base_file_string + source_text

  parsed_file = Parsing.parse_text(source_text, 'cuke_modeler_stand_alone_outline.feature')

  parsed_file['feature']['elements'].first
end