Class: AppMap::RSpec::ScopeExampleGroup

Inherits:
Struct
  • Object
show all
Defined in:
lib/appmap/rspec.rb

Overview

As you can see here, the way that RSpec stores the example description and represents the example group hierarchy is pretty weird.

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#example_groupObject Also known as: example_obj

Returns the value of attribute example_group

Returns:

  • (Object)

    the current value of example_group



36
37
38
# File 'lib/appmap/rspec.rb', line 36

def example_group
  @example_group
end

Instance Method Details

#descriptionObject



52
53
54
# File 'lib/appmap/rspec.rb', line 52

def description
  description? ? description_args.join(' ') : nil
end

#description?Boolean

Returns:

  • (Boolean)


44
45
46
47
48
49
50
# File 'lib/appmap/rspec.rb', line 44

def description?
  return true if example_group.respond_to?(:described_class) && example_group.described_class

  return true if example_group.respond_to?(:description) && !description_args.empty?

  false
end

#description_argsObject



39
40
41
42
# File 'lib/appmap/rspec.rb', line 39

def description_args
  # Don't stringify any hashes that RSpec considers part of the example group description.
  example_group.[:description_args].reject { |arg| arg.is_a?(Hash) }
end

#parentObject



56
57
58
59
60
61
62
63
64
65
66
67
68
69
# File 'lib/appmap/rspec.rb', line 56

def parent
  # An example group always has a parent; but it might be 'self'...

  # DEPRECATION WARNING: `Module#parent` has been renamed to `module_parent`. `parent` is deprecated and will be
  # removed in Rails 6.1. (called from parent at /Users/kgilpin/source/appland/appmap-ruby/lib/appmap/rspec.rb:110)
  example_group_parent = \
    if example_group.respond_to?(:module_parent)
      example_group.module_parent
    else
      example_group.parent
    end

  example_group_parent != example_group ? ScopeExampleGroup.new(example_group_parent) : nil
end