File: trace.t

package info (click to toggle)
libbadger-perl 0.16-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,400 kB
  • sloc: perl: 11,004; makefile: 9
file content (67 lines) | stat: -rw-r--r-- 1,483 bytes parent folder | download
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#============================================================= -*-perl-*-
#
# t/exception.t
#
# Test the Badger::Exception module.
#
# Written by Andy Wardley <abw@wardley.org>
#
# This is free software; you can redistribute it and/or modify it
# under the same terms as Perl itself.
#
#========================================================================

use strict;
use warnings;

use lib qw( ./lib ../lib ../../lib );
use Badger::Test 
    tests => 11,
    args  => \@ARGV;

use Badger::Exception trace => 1;

sub baz {
    shift->throw;
}

sub bar {
    baz(@_);
}

sub foo {
    bar(
        Badger::Exception->new(
            type  => 'food', 
            info  => 'bread is not fresh',
        )
    );
}

eval { foo() };
my $catch = $@;

like( $catch, qr/called from/, 'stack trace in text' );
my $stack = $catch->stack;
ok( $stack, 'got stack' );
is( scalar(@$stack), 4, 'stack has four frames' );
like( $stack->[0]->[1], qr/trace\.t/, 'called from trace.t' );
is( $stack->[0]->[2],  29, 'called from line 29' );
is( $stack->[0]->[3], 'main::baz', 'called from baz' );
is( $stack->[1]->[2], 33, 'called from line 33' );
is( $stack->[1]->[3], 'main::bar', 'called from bar' );
is( $stack->[2]->[2], 41, 'called from line 41' );
is( $stack->[2]->[3], 'main::foo', 'called from foo' );
is( $stack->[3]->[3], '(eval)', 'called from eval' );



__END__

# Local Variables:
# mode: perl
# perl-indent-level: 4
# indent-tabs-mode: nil
# End:
#
# vim: expandtab shiftwidth=4: