class CukeModeler::Outline
A class modeling an individual outline in a Cucumber suite.
Attributes
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