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


version 0.10


    use Test::Magpie;

    # create the mock object and stub
    my $baker = mock;

    # 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');


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.



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

    $mock = mock;

$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 );


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

    stub($mock)->method(@args)->returns(1, 2, 3);


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.

    # 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)

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


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


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


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)


This module exports the following functions by default:

  • mock

  • stub

  • verify

All other functions need to be imported explicitly.


Bugs / Feature Requests

Please report any bugs or feature requests by email to bug-test-magpie at, or through the web interface at You will be automatically notified of any progress on the request by the system.

Source Code

This is open source software. The code repository is available for public review and contribution under the terms of the license.

  git clone


  • Oliver Charles <>

  • Steven Lee <>


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.