Sha256: 5beb9b59e732764acc53d07bf59edbc9dfeef3112a74a18a827a12b219f80be7
Contents?: true
Size: 1.18 KB
Versions: 2
Compression:
Stored size: 1.18 KB
Contents
class FlexMock # Expectations on mocks with a base class can only be defined on # methods supported by the base class. Attempting to add an stub to # a method not defined on the base class will cause the expectation # to be wrapped in an ExplicitNeeded wrapper. The wrapper will throw # an exception unless the explicitly method is immediately called on # the expectation. # class ExplicitNeeded def initialize(expectation, method_name, base_class) @expectation = expectation @explicit = false @method_name = method_name @base_class = base_class end def explicitly @explicit = true self end def explicit? @explicit end def mock=(m) @expectation.mock = m end WHITELIST = [:with_signature_matching] def method_missing(sym, *args, **kw, &block) if explicit? || WHITELIST.include?(sym) @expectation.send(sym, *args, **kw, &block) else fail NoMethodError, "Cannot stub methods not defined by the base class\n" + " Method: #{@method_name}\n" + " Base Class: #{@base_class}\n" + " (Use 'explicitly' to override)" end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
flexmock-3.0.1 | lib/flexmock/explicit_needed.rb |
flexmock-3.0.0 | lib/flexmock/explicit_needed.rb |