Class: RSpec::Mocks::ConstantMutator
- Inherits:
- 
      Object
        - Object
- RSpec::Mocks::ConstantMutator
 
- Extended by:
- Support::RecursiveConstMethods
- Defined in:
- lib/rspec/mocks/mutate_const.rb
Overview
Provides a means to stub constants.
Class Method Summary collapse
- 
  
      .hide(constant_name)  ⇒ Object 
  
    Hides a constant. 
- 
  
      .raise_on_invalid_const  ⇒ Object 
  
  private
    Used internally by the constant stubbing to raise a helpful error when a constant like “A::B::C” is stubbed and A::B is not a module (and thus, it's impossible to define “A::B::C” since only modules can have nested constants). 
- 
  
      .stub(constant_name, value, options = {})  ⇒ Object 
  
    Stubs a constant. 
Class Method Details
.hide(constant_name) ⇒ Object
It's recommended that you use hide_const in your examples. This is an alternate public API that is provided so you can hide constants in other contexts (e.g. helper classes).
Hides a constant.
| 131 132 133 134 | # File 'lib/rspec/mocks/mutate_const.rb', line 131 def self.hide(constant_name) mutate(ConstantHider.new(constant_name, nil, {})) nil end | 
.raise_on_invalid_const ⇒ Object
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.
Used internally by the constant stubbing to raise a helpful error when a constant like “A::B::C” is stubbed and A::B is not a module (and thus, it's impossible to define “A::B::C” since only modules can have nested constants).
| 331 332 333 334 335 336 | # File 'lib/rspec/mocks/mutate_const.rb', line 331 def self.raise_on_invalid_const lambda do |const_name, failed_name| raise "Cannot stub constant #{failed_name} on #{const_name} " \ "since #{const_name} is not a module." end end | 
.stub(constant_name, value, options = {}) ⇒ Object
It's recommended that you use stub_const in your examples. This is an alternate public API that is provided so you can stub constants in other contexts (e.g. helper classes).
Stubs a constant.
| 107 108 109 110 111 112 113 114 115 116 117 118 119 120 | # File 'lib/rspec/mocks/mutate_const.rb', line 107 def self.stub(constant_name, value, ={}) unless String === constant_name raise ArgumentError, "`stub_const` requires a String, but you provided a #{constant_name.class.name}" end mutator = if recursive_const_defined?(constant_name, &raise_on_invalid_const) DefinedConstantReplacer else UndefinedConstantSetter end mutate(mutator.new(constant_name, value, [:transfer_nested_constants])) value end |