class Cucumber::Core::Test::Case
def ==(other)
def ==(other) eql?(other) end
def all_locations
def all_locations @all_locations ||= Ast::Location.merge(all_source.map(&:all_locations).flatten) end
def all_source
def all_source @all_source ||= (source + test_steps.map(&:source)).flatten.uniq end
def compose_around_hooks(visitor, *args, &block)
def compose_around_hooks(visitor, *args, &block) around_hooks.reverse.reduce(block) do |continue, hook| -> { hook.describe_to(visitor, *args, &continue) } end.call end
def describe_source_to(visitor, *args)
def describe_source_to(visitor, *args) source.reverse.each do |node| node.describe_to(visitor, *args) end self end
def describe_to(visitor, *args)
def describe_to(visitor, *args) visitor.test_case(self, *args) do |child_visitor| compose_around_hooks(child_visitor, *args) do test_steps.each do |test_step| test_step.describe_to(child_visitor, *args) end end end self end
def eql?(other)
def eql?(other) other.hash == hash end
def feature
def feature source.first end
def hash
def hash location.hash end
def initialize(test_steps, source, around_hooks = [])
def initialize(test_steps, source, around_hooks = []) raise ArgumentError.new("test_steps should be an Array but is a #{test_steps.class}") unless test_steps.kind_of?(Array) @test_steps = test_steps @source = source @around_hooks = around_hooks end
def inspect
def inspect "#<#{self.class}: #{location}>" end
def keyword
def keyword @keyword ||= NameBuilder.new(self).keyword end
def language
def language feature.language end
def location
def location source.last.location end
def match_locations?(queried_locations)
def match_locations?(queried_locations) queried_locations.any? { |queried_location| all_source.any? { |node| node.all_locations.any? { |location| queried_location.match? location } } } end
def match_name?(name_regexp)
def match_name?(name_regexp) source.any? { |node| node.respond_to?(:name) && node.name =~ name_regexp } end
def match_single_tag_expression?(expression)
def match_single_tag_expression?(expression) if old_style_tag_expression?(expression) Cucumber::Core::Gherkin::TagExpression.new([expression]).evaluate(tags) else Cucumber::TagExpressions::Parser.new.parse(expression).evaluate(tags.map(&:name)) end end
def match_tags?(*expressions)
def match_tags?(*expressions) expressions.flatten.all? { |expression| match_single_tag_expression?(expression) } end
def name
def name @name ||= NameBuilder.new(self).result end
def old_style_tag_expression?(expression)
def old_style_tag_expression?(expression) expression.include?(',') || expression.include?('~') end
def step_count
def step_count test_steps.count end
def tags
def tags @tags ||= TagCollector.new(self).result end
def with_around_hooks(around_hooks)
def with_around_hooks(around_hooks) self.class.new(test_steps, source, around_hooks) end
def with_steps(test_steps)
def with_steps(test_steps) self.class.new(test_steps, source, around_hooks) end