Sha256: 671fc8e700fca151e2ba17a7cf5b460824fadf076d17433cb37abb8b5c78e391

Contents?: true

Size: 1.64 KB

Versions: 2

Compression:

Stored size: 1.64 KB

Contents

module Spec
  module Mocks
    class Mock
      include Methods

      # Creates a new mock with a +name+ (that will be used in error messages
      # only) == Options:
      # * <tt>:null_object</tt> - if true, the mock object acts as a forgiving
      #   null object allowing any message to be sent to it.
      def initialize(name, stubs_and_options={})
        @name = name
        @options = parse_options(stubs_and_options)
        assign_stubs(stubs_and_options)
      end
      
      # 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.
      def ==(other)
        other == __mock_proxy
      end

      def inspect
        "#<#{self.class}:#{sprintf '0x%x', self.object_id} @name=#{@name.inspect}>"
      end
      
      def to_s
        inspect.gsub('<','[').gsub('>',']')
      end
      
      private

        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
      
        def parse_options(options)
          options.has_key?(:null_object) ? {:null_object => options.delete(:null_object)} : {}
        end
        
        def assign_stubs(stubs)
          stubs.each_pair do |message, response|
            stub!(message).and_return(response)
          end
        end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
rspec-1.2.3 lib/spec/mocks/mock.rb
rspec-1.2.4 lib/spec/mocks/mock.rb