1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
#!/usr/bin/env ruby
#---
# Copyright 2003-2013 by Jim Weirich (jim.weirich@gmail.com).
# All rights reserved.
# Permission is granted for use, copying, modification, distribution,
# and distribution of modified versions of this work as long as the
# above copyright notice is included.
#+++
require 'flexmock/argument_matchers'
class FlexMock
# Include this module in your test class if you wish to use the +eq+
# and +any+ argument matching methods without a prefix. (Otherwise
# use <tt>FlexMock.any</tt> and <tt>FlexMock.eq(obj)</tt>.
#
module ArgumentTypes
# Return an argument matcher that matches any argument.
def any
ANY
end
# Return an argument matcher that only matches things equal to
# (==) the given object.
def eq(obj)
EqualMatcher.new(obj)
end
# Return an argument matcher that matches any object, that when
# passed to the supplied block, will cause the block to return
# true.
def on(&block)
ProcMatcher.new(&block)
end
# Return an argument matcher that matches a hash with the given
# entries.
def hsh(hash)
HashMatcher.new(hash)
end
# Return an argument matcher that matches any object that
# implementes (i.e. responds to) the given method list.
def ducktype(*methods)
DuckMatcher.new(methods)
end
end
extend ArgumentTypes
end
|