NAME Test::Fatal::matchfor - match exceptions by class name or regexp SYNOPSIS Let's say you're testing the following Moose class... package Goose { use Moose; has feather_count => (is => 'rw', isa => 'Int'); } In Moose 2.1102 and above, exception objects are thrown, but in earlier versions of Moose, only string errors are given. So we might want to test it something like this: use Test::More; use Test::Fatal; use Goose; my $e = exception { Goose->new(feather_count => 3.1) }; ref($e) ? isa_ok($e, 'Moose::Exception::ValidationFailedForTypeConstraint') : like($e, qr{does not pass the type constraint}) This module provides a small shortcut for that pattern: use Test::More; use Test::Fatal; use Test::Fatal::matchfor; use Goose; my $e = exception { Goose->new(feather_count => 3.1) }; is( $e, matchfor( 'Moose::Exception::ValidationFailedForTypeConstraint', qr{does not pass the type constraint}, ), ); DESCRIPTION Test::Fatal::matchfor exports the `matchfor` function which accepts a list of class/role names and regular expressions, and constructs an object overloading `==` and `eq` to return true if compared for equality against a string that matches one of those regular expressions, or an object that isa/does one of those class/role names. So for example, to check a type constraint error in Moose, you might use: my $tc_err = matchfor( 'Moose::Exception::ValidationFailedForTypeConstraint', 'Moose::Exception::ValidationFailedForInlinedTypeConstraint', qr{does not pass the type constraint}, ), is($exception, $tc_err, "encountered error as expected"); BUGS Please report any bugs to <http://rt.cpan.org/Dist/Display.html?Queue=Test-Fatal-matchfor>. SEE ALSO Test::Fatal, Moose::Exception. AUTHOR Toby Inkster <tobyink@cpan.org>. COPYRIGHT AND LICENCE This software is copyright (c) 2013 by Toby Inkster. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. DISCLAIMER OF WARRANTIES THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.