NAME

Test::Magpie - Mocking framework with method stubs and behaviour verification

SYNOPSIS

use Test::Magpie;

# create the mock object and stub
my $baker = mock;
when($mock)->bake_loaf('white')->then_return($bread);

# execute the code under test
my $bakery = Bakery->new( bakers => [ $baker ] );
my @loaves = $bakery->buy_loaf( amount => 2, type => 'white' );

# verify the interactions with the mock object
verify($baker, times => 2)->bake_loaf('white');

DESCRIPTION

Test::Magpie is a test double framework heavily inspired by the Mockito framework for Java, and also the Python-Mockito project. In Mockito, you "spy" on objects for their behaviour, rather than being upfront about what should happen. I find this approach to be significantly more flexible and easier to work with than mocking systems like EasyMock, so I created a Perl implementation.

Mock objects

Mock objects, represented by Test::Magpie::Mock objects, are objects that pretend to be everything you could ever want them to be. A mock object can have any method called on it, does every roles, and isa subclass of any superclass. This allows you to easily throw a mock object around it will be treated as though it was a real object.

Method stubbing

Any method can be called on a mock object, and it will be logged as an invocation. By default, method calls return undef in scalar context or an empty list in list context. Often, though, clients will be interested in the result of calling a method with some arguments. So you may specify how a method stub should respond when it is called.

Verify interactions

After calling your concrete code (the code under test) you may want to check that the code did operate correctly on the mock. To do this, you can use verifications to make sure code was called, with correct parameters and the correct amount of times.

Argument matching

Magpie gives you some helpful methods to validate arguments passed in to calls. You can check equality between arguments, or consume a general type of argument, or consume multiple arguments. See Test::Magpie::ArgumentMatcher for the juicy details.

FUNCTIONS

mock

mock() constructs a new instance of a mock object.

$mock = mock;
$mock->method(@args);

$class is an optional argument to set the type that the mock object is blessed into. This value will be returned when ref() is called on the object.

$mock = mock($class);
is( ref($mock), $class );

when

when() is used to tell the method stub to return some value(s) or to raise an exception.

when($mock)->method(@args)->then_return(1, 2, 3);
when($mock)->invalid(@args)->then_die('exception');

verify

verify() is used to check the interactions on your mock object and prints the test result. verify() plays nicely with Test::Simple and Co - it depends on them for setting a test plan and its calls are counted in the test plan.

verify($mock)->method(@args)
# prints: ok 1 - method("foo") was called 1 time(s)

verify() accepts an optional $test_name to print a custom name for the test instead of the default.

verify($mock, $test_name)->method(@args)
# prints: ok 1 - record inserted into database'

verify() accepts a few options to help your verifications:

verify( $mock, times    => 3,     )->method(@args)
verify( $mock, at_least => 3      )->method(@args)
verify( $mock, at_most  => 5      )->method(@args)
verify( $mock, between  => [3, 5] )->method(@args)
times

Specifies the number of times the given method is expected to be called. The default is 1 if no other option is specified.

at_least

Specifies the minimum number of times the given method is expected to be called.

at_most

Specifies the maximum number of times the given method is expected to be called.

between

Specifies the minimum and maximum number of times the given method is expected to be called.

A $test_name may also be supplied after the option.

verify($mock, times => 3, $test_name)->method(@args)

inspect

Inspect method invocations on a mock object.

$invocation = inspect($mock)->method(@args);
is( $invocation->method_name, 'foo' );
is_deeply( [$invocation->arguments], [qw( bar baz )] );

at_least (deprecated)

Used with verify() to verify that a method was invoked at least $n times.

verify($mock, times => at_least($n))->method(@args);

This function has been deprecated. Use the at_least option for verify() instead.

at_most (deprecated)

Used with verify() to verify that a method was invoked at most $n times.

verify($mock, times => at_most($n))->method(@args);

This function has been deprecated. Use the at_most option for verify() instead.

EXPORTS

This module exports the following functions by default:

  • mock

  • when

  • verify

All other functions need to be imported explicitly.

AUTHORS

  • Oliver Charles <oliver.g.charles@googlemail.com>

  • Steven Lee <stevenwh.lee@gmail.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2013 by Oliver Charles.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.