The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#============================================================= -*-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: