Class: RSpec::Mocks::Constant

Inherits:
Object
  • Object
show all
Extended by:
Support::RecursiveConstMethods
Defined in:
lib/rspec/mocks/mutate_const.rb

Overview

Provides information about constants that may (or may not) have been mutated by rspec-mocks.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name) {|_self| ... } ⇒ Constant

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns a new instance of Constant.

Yields:

  • (_self)

Yield Parameters:

11
12
13
14
15
16
17
18
# File 'lib/rspec/mocks/mutate_const.rb', line 11
def initialize(name)
  @name = name
  @previously_defined = false
  @stubbed = false
  @hidden = false
  @valid_name = true
  yield self if block_given?
end

Instance Attribute Details

#nameString (readonly)

Returns The fully qualified name of the constant.

Returns:

  • (String)

    The fully qualified name of the constant.

21
22
23
# File 'lib/rspec/mocks/mutate_const.rb', line 21
def name
  @name
end

#original_valueObject?

Returns The original value (e.g. before it was mutated by rspec-mocks) of the constant, or nil if the constant was not previously defined.

Returns:

  • (Object, nil)

    The original value (e.g. before it was mutated by rspec-mocks) of the constant, or nil if the constant was not previously defined.

26
27
28
# File 'lib/rspec/mocks/mutate_const.rb', line 26
def original_value
  @original_value
end

Class Method Details

.original(name) ⇒ Constant

Queries rspec-mocks to find out information about the named constant.

Parameters:

  • name (String)

    the name of the constant

Returns:

  • (Constant)

    an object containing information about the named constant.

86
87
88
89
# File 'lib/rspec/mocks/mutate_const.rb', line 86
def self.original(name)
  mutator = ::RSpec::Mocks.space.constant_mutator_for(name)
  mutator ? mutator.to_constant : unmutated(name)
end

Instance Method Details

#hidden?Boolean

Returns Whether or not rspec-mocks has hidden this constant.

Returns:

  • (Boolean)

    Whether or not rspec-mocks has hidden this constant.

51
52
53
# File 'lib/rspec/mocks/mutate_const.rb', line 51
def hidden?
  @hidden
end

#mutated?Boolean

Returns Whether or not rspec-mocks has mutated (stubbed or hidden) this constant.

Returns:

  • (Boolean)

    Whether or not rspec-mocks has mutated (stubbed or hidden) this constant.

39
40
41
# File 'lib/rspec/mocks/mutate_const.rb', line 39
def mutated?
  @stubbed || @hidden
end

#previously_defined?Boolean

Returns Whether or not the constant was defined before the current example.

Returns:

  • (Boolean)

    Whether or not the constant was defined before the current example.

33
34
35
# File 'lib/rspec/mocks/mutate_const.rb', line 33
def previously_defined?
  @previously_defined
end

#stubbed?Boolean

Returns Whether or not rspec-mocks has stubbed this constant.

Returns:

  • (Boolean)

    Whether or not rspec-mocks has stubbed this constant.

45
46
47
# File 'lib/rspec/mocks/mutate_const.rb', line 45
def stubbed?
  @stubbed
end

#to_sObject Also known as: inspect

The default to_s isn't very useful, so a custom version is provided.

62
63
64
# File 'lib/rspec/mocks/mutate_const.rb', line 62
def to_s
  "#<#{self.class.name} #{name}>"
end

#valid_name?Boolean

Returns Whether or not the provided constant name is a valid Ruby constant name.

Returns:

  • (Boolean)

    Whether or not the provided constant name is a valid Ruby constant name.

57
58
59
# File 'lib/rspec/mocks/mutate_const.rb', line 57
def valid_name?
  @valid_name
end