Class: Spec::Mocks::Mock

Inherits:
Object show all
Includes:
Methods
Defined in:
lib/spec/mocks/mock.rb

Instance Method Summary collapse

Methods included from Methods

#as_null_object, #null_object?, #received_message?, #rspec_reset, #rspec_verify, #should_not_receive, #should_receive, #stub!

Constructor Details

#initialize(name, stubs_and_options = {}) ⇒ Mock

Creates a new mock with a name (that will be used in error messages only) == Options:

  • :null_object - if true, the mock object acts as a forgiving null object allowing any message to be sent to it.



10
11
12
13
14
# File 'lib/spec/mocks/mock.rb', line 10

def initialize(name, stubs_and_options={})
  @name = name
  @options = parse_options(stubs_and_options)
  assign_stubs(stubs_and_options)
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(sym, *args, &block) ⇒ Object



24
25
26
27
28
29
30
31
32
# File 'lib/spec/mocks/mock.rb', line 24

def method_missing(sym, *args, &block)
  __mock_proxy.record_message_received(sym, args, block)
  begin
    return self if __mock_proxy.null_object?
    super(sym, *args, &block)
  rescue NameError
    __mock_proxy.raise_unexpected_message_error sym, *args
  end
end

Instance Method Details

#==(other) ⇒ Object

This allows for comparing the mock to other objects that proxy such as ActiveRecords belongs_to proxy objects. By making the other object run the comparison, we’re sure the call gets delegated to the proxy target.



20
21
22
# File 'lib/spec/mocks/mock.rb', line 20

def ==(other)
  other == __mock_proxy
end

#inspectObject



34
35
36
# File 'lib/spec/mocks/mock.rb', line 34

def inspect
  "#<#{self.class}:#{sprintf '0x%x', self.object_id} @name=#{@name.inspect}>"
end

#to_sObject



38
39
40
# File 'lib/spec/mocks/mock.rb', line 38

def to_s
  inspect.gsub('<','[').gsub('>',']')
end