1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
|
use Test::More;
use strict;
use warnings;
use Plack::Test;
use HTTP::Request::Common;
use Capture::Tiny 'capture_stderr';
use Ref::Util qw<is_coderef>;
{
package App;
use Dancer2;
set logger => 'console';
hook 'before' => sub {
die 'test die inside a before hook';
print STDERR "error message not caught in the before hook\n";
};
get '/' => sub {
print STDERR "error message not caught in the route handler\n";
};
}
my $app = App->to_app;
ok( is_coderef($app), 'Got app' );
test_psgi $app, sub {
my $cb = shift;
my $message = capture_stderr { $cb->( GET '/' ) };
like
$message,
qr/test die inside a before hook/,
'Got error message when a before hook dies';
};
done_testing;
|