Module: RSpec::Mocks::Methods
Instance Method Summary collapse
- #as_null_object ⇒ Object
 - #null_object? ⇒ Boolean
 - 
  
    
      #received_message?(sym, *args, &block)  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    
:nodoc:.
 - 
  
    
      #rspec_reset  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
:nodoc:.
 - 
  
    
      #rspec_verify  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
:nodoc:.
 - #should_not_receive(sym, &block) ⇒ Object
 - #should_receive(sym, opts = {}, &block) ⇒ Object
 - #stub(sym_or_hash, opts = {}, &block) ⇒ Object (also: #stub!)
 - 
  
    
      #stub_chain(*chain, &blk)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
:call-seq: double.stub_chain(“foo.bar”) { :baz } double.stub_chain(:foo, :bar) { :baz }.
 - #unstub(sym) ⇒ Object (also: #unstub!)
 
Instance Method Details
#as_null_object ⇒ Object
      65 66 67  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 65 def as_null_object __mock_proxy.as_null_object end  | 
  
#null_object? ⇒ Boolean
      69 70 71  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 69 def null_object? __mock_proxy.null_object? end  | 
  
#received_message?(sym, *args, &block) ⇒ Boolean
:nodoc:
      53 54 55  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 53 def (sym, *args, &block) #:nodoc: __mock_proxy.(sym.to_sym, *args, &block) end  | 
  
#rspec_reset ⇒ Object
:nodoc:
      61 62 63  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 61 def rspec_reset #:nodoc: __mock_proxy.reset end  | 
  
#rspec_verify ⇒ Object
:nodoc:
      57 58 59  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 57 def rspec_verify #:nodoc: __mock_proxy.verify end  | 
  
#should_not_receive(sym, &block) ⇒ Object
      8 9 10  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 8 def should_not_receive(sym, &block) __mock_proxy.(caller(1)[0], sym.to_sym, &block) end  | 
  
#should_receive(sym, opts = {}, &block) ⇒ Object
      4 5 6  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 4 def should_receive(sym, opts={}, &block) __mock_proxy.(opts[:expected_from] || caller(1)[0], sym.to_sym, opts, &block) end  | 
  
#stub(sym_or_hash, opts = {}, &block) ⇒ Object Also known as: stub!
      12 13 14 15 16 17 18  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 12 def stub(sym_or_hash, opts={}, &block) if Hash === sym_or_hash sym_or_hash.each {|method, value| stub!(method).and_return value } else __mock_proxy.add_stub(caller(1)[0], sym_or_hash.to_sym, opts, &block) end end  | 
  
#stub_chain(*chain, &blk) ⇒ Object
:call-seq:
double.stub_chain("foo.bar") { :baz }
double.stub_chain(:foo, :bar) { :baz }
Stubs a chain of methods. Especially useful with fluent and/or composable interfaces.
Examples
Article.stub_chain("recent.published") { [Article.new] }
  
      37 38 39 40 41 42 43 44 45 46 47 48 49 50 51  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 37 def stub_chain(*chain, &blk) chain, blk = format_chain(*chain, &blk) if chain.length > 1 if matching_stub = __mock_proxy.__send__(:find_matching_method_stub, chain[0].to_sym) chain.shift matching_stub.invoke.stub_chain(*chain) else next_in_chain = Object.new stub(chain.shift) { next_in_chain } next_in_chain.stub_chain(*chain, &blk) end else stub(chain.shift, &blk) end end  | 
  
#unstub(sym) ⇒ Object Also known as: unstub!
      20 21 22  | 
    
      # File 'lib/rspec/mocks/methods.rb', line 20 def unstub(sym) __mock_proxy.remove_stub(sym) end  |