File: log_die_before_hook.t

package info (click to toggle)
libdancer2-perl 0.152000%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 1,820 kB
  • ctags: 536
  • sloc: perl: 8,034; sh: 51; makefile: 2
file content (37 lines) | stat: -rw-r--r-- 746 bytes parent folder | download | duplicates (2)
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
use Test::More;
use strict;
use warnings;
use Plack::Test;
use HTTP::Request::Common;
use Capture::Tiny 'capture_stderr';

{
    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;
is( ref $app, 'CODE', '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;