NAME
Test::Stream::Plugin::Exception - Simple tools to help test exceptions.
EXPERIMENTAL CODE WARNING
This is an experimental release! Test-Stream, and all its components are still in an experimental phase. This dist has been released to cpan in order to allow testers and early adopters the chance to write experimental new tools with it, or to add experimental support for it into old tools.
PLEASE DO NOT COMPLETELY CONVERT OLD TOOLS YET. This experimental release is very likely to see a lot of code churn. API's may break at any time. Test-Stream should NOT be depended on by any toolchain level tools until the experimental phase is over.
SYNOPSIS
# Loads Exception, we also need 'More', so load that as well.
use Test::Stream qw/More Exception/;
ok(lives { ... }, "codeblock did not die");
like(dies { die 'xxx' }, qr/xxx/, "codeblock threw expected exception");
EXPORTS
- $bool = lives { ... }
-
If the codeblock does not throw any exception this will return true. If the codeblock does throw an exception this will return false, after printing the exception as a warning.
ok(lives { ... }, "codeblock did not die");
- $error = dies { ... }
-
This will return undef if the codeblock does not throw an exception, otherwise it returns the exception. Note, if your exception is an empty string or 0 it is your responsibility to check that the error is defined instead of using a simple boolean check.
ok( defined dies { die 0 }, "died" ); like(dies { die 'xxx' }, qr/xxx/, "codeblock threw expected exception");
SOURCE
The source code repository for Test::Stream can be found at http://github.com/Test-More/Test-Stream/.
MAINTAINERS
AUTHORS
COPYRIGHT
Copyright 2015 Chad Granum <exodist7@gmail.com>.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
See http://www.perl.com/perl/misc/Artistic.html