File: stacktrace.t

package info (click to toggle)
libtype-tiny-perl 2.002001-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 3,948 kB
  • sloc: perl: 14,610; makefile: 2; sh: 1
file content (70 lines) | stat: -rw-r--r-- 1,179 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
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
68
69
70
=pod

=encoding utf-8

=head1 PURPOSE

Tests that L<Error::TypeTiny> is capable of providing stack traces.

=head1 DEPENDENCIES

Requires L<Devel::StackTrace>; skipped otherwise.

=head1 AUTHOR

Toby Inkster E<lt>tobyink@cpan.orgE<gt>.

=head1 COPYRIGHT AND LICENCE

This software is copyright (c) 2013-2014, 2017-2023 by Toby Inkster.

This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.

=cut

use strict;
use warnings;
use lib qw( ./lib ./t/lib ../inc ./inc );

use Error::TypeTiny ();
local $Error::TypeTiny::StackTrace;

use Test::More;
use Test::Fatal;
use Test::Requires { "Devel::StackTrace" => 0 };

use Types::Standard ();

{
	package Local::Guts;
	
	sub foo {
		local $Error::TypeTiny::StackTrace = 1;
		local $Error::TypeTiny::CarpInternal{'Local::Guts'} = 1;
		Types::Standard::Int->( @_ );
	}
}

sub bar {
	Local::Guts::foo( @_ );
}

sub baz {
	bar( @_ );
}

my $e = exception { baz(undef) };

my $subs = [
	map
		$e->stack_trace->frame( $_ )->subroutine,
		0 .. 2
];

is_deeply(
	$subs,
	[ 'Local::Guts::foo', 'main::bar', 'main::baz' ],
) or diag explain( $subs );

done_testing;