Main entry point into the flexmock API.
This function is used to either generate a new fake object or take an existing object (or class or module) and use it as a basis for a partial mock. In case of a partial mock, the passed in object is modified to support basic Mock class functionality making it unnecessary to make successive flexmock() calls on the same objects to generate new expectations.
>>> flexmock(SomeClass)
>>> SomeClass.should_receive('some_method')
NOTE: it’s safe to call flexmock() on the same object, it will detect when an object has already been partially mocked and return it each time.
Fake object class returned by the flexmock() function.
Replaces the specified attribute with a fake.
Creates a spy.
This means that the original method will be called rather than the fake version. However, we can still keep track of how many times it’s called and with what arguments, and apply expectations accordingly.
should_call is meaningless/not allowed for non-callable attributes.
Holds expectations about methods.
The information contained in the Expectation object includes method name, its argument list, return values, and any exceptions that the method might raise.
Override the arguments used to match this expectation’s method.
Override the return value of this expectation’s method.
When and_return is given multiple times, each value provided is returned on successive invocations of the method. It is also possible to mix and_return with and_raise in the same manner to alternate between returning a value and raising and exception on different method invocations.
When combined with the one_by_one property, value is treated as a list of values to be returned in the order specified by successive calls to this method rather than a single list to be returned each time.
Specifies the exception to be raised when this expectation is met.
Gives a function to run instead of the mocked out one.
Specifies the list of items to be yielded on successive method calls.
In effect, the mocked object becomes a generator.
Sets an outside resource to be checked before executing the method.
Number of times this expectation’s method is expected to be called.
There are also 3 aliases for the times() method:
- once() -> times(1)
- twice() -> times(2)
- never() -> times(0)
Modifies the associated times() expectation.
When given, an exception will only be raised if the method is called less than times() specified. Does nothing if times() is not given.
Modifies the associated “times” expectation.
When given, an exception will only be raised if the method is called more than times() specified. Does nothing if times() is not given.
Makes the expectation respect the order of should_receive statements.
An exception will be raised if methods are called out of order, determined by order of should_receive calls in the test.