forked from PerlDancer/Dancer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
06_stack_trace.t
51 lines (44 loc) · 2.38 KB
/
06_stack_trace.t
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
39
40
41
42
43
44
45
46
47
48
49
50
51
use strict;
use warnings;
use Test::More tests => 16, import => ['!pass'];
use Dancer ':syntax';
use Dancer::Template::TemplateToolkit;
# scoping for $Carp::Verbose localization
{
# first of all, test without verbose Carp
local $Carp::Verbose = 0;
eval { Dancer::Template::TemplateToolkit->render('/not/a/valid/file'); };
my @error_lines = split(/\n/, $@);
is(scalar(@error_lines), 1, "test non verbose croak");
like($error_lines[0], qr!^'/not/a/valid/file' doesn\'t exist or not a regular file at!, "test non verbose croak");
}
{
# same with verbose Carp
local $Carp::Verbose = 1;
eval { Dancer::Template::TemplateToolkit->render('/not/a/valid/file'); };
my @error_lines = split(/\n/, $@);
is(scalar(@error_lines), 3, "test verbose croak");
like($error_lines[0], qr!^'/not/a/valid/file' doesn\'t exist or not a regular file at!, "test verbose croak");
like($error_lines[1], qr!^\s*Dancer::Template::TemplateToolkit::render\('Dancer::Template::TemplateToolkit', '/not/a/valid/file'\) called at!, "test verbose croak stack trace");
like($error_lines[2], qr!^\s*eval {...} called at (?:[.]/)?t/01_config/06_stack_trace.t!, "test verbose croak stack trace");
}
{
# test that default Dancer traces setting is no verbose
is(setting('traces'), 0, "default 'traces' option set to 0");
is($Carp::Verbose, 0, "default Carp verbose is 0");
eval { Dancer::Template::TemplateToolkit->render('/not/a/valid/file'); };
my @error_lines = split(/\n/, $@);
is(scalar(@error_lines), 1, "test non verbose croak 2");
like($error_lines[0], qr!^'/not/a/valid/file' doesn\'t exist or not a regular file at!, "test non verbose croak 2");
}
{
# test setting traces to 1
ok(setting(traces => 1), 'can set traces');
is($Carp::Verbose, 1, "new Carp verbose is 1");
eval { Dancer::Template::TemplateToolkit->render('/not/a/valid/file'); };
my @error_lines = split(/\n/, $@);
is(scalar(@error_lines), 3, "test verbose croak");
like($error_lines[0], qr!^'/not/a/valid/file' doesn\'t exist or not a regular file at!, "test verbose croak");
like($error_lines[1], qr!^\s*Dancer::Template::TemplateToolkit::render\('Dancer::Template::TemplateToolkit', '/not/a/valid/file'\) called at!, "test verbose croak stack trace");
like($error_lines[2], qr!^\s*eval {...} called at (?:[.]/)?t/01_config/06_stack_trace.t!, "test verbose croak stack trace");
}