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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
use strict;
use warnings;
use B;
use Test::Stream;
use Test::MostlyLike;
use Test::More tests => 9;
use Test::Builder; # Not loaded by default in modern mode
my $orig = Test::Builder->can('ok');
{
package MyModernTester;
use Test::Stream;
use Test::MostlyLike;
use Test::More;
no warnings 'redefine';
local *Test::Builder::ok = sub {
my $self = shift;
my ($bool, $name) = @_;
$name = __PACKAGE__ . ": $name";
return $self->$orig($bool, $name);
};
use warnings;
my $file = __FILE__;
# Line number is tricky, just use what B says The sub may not actually think it
# is on the line it is may be off by 1.
my $line = B::svref_2object(\&Test::Builder::ok)->START->line;
my @warnings;
{
local $SIG{__WARN__} = sub { push @warnings => @_ };
ok(1, "fred");
ok(2, "barney");
}
mostly_like(
\@warnings,
[
qr{The new sub is 'MyModernTester::__ANON__' defined in $file around line $line},
undef, #Only 1 warning
],
"Found expected warning, just the one"
);
}
{
package MyModernTester2;
use Test::Stream;
use Test::MostlyLike;
use Test::More;
no warnings 'redefine';
local *Test::Builder::ok = sub {
my $self = shift;
my ($bool, $name) = @_;
$name = __PACKAGE__ . ": $name";
return $self->$orig($bool, $name);
};
use warnings;
my $file = __FILE__;
# Line number is tricky, just use what B says The sub may not actually think it
# is on the line it is may be off by 1.
my $line = B::svref_2object(\&Test::Builder::ok)->START->line;
my @warnings;
{
local $SIG{__WARN__} = sub { push @warnings => @_ };
ok(1, "fred");
ok(2, "barney");
}
mostly_like(
\@warnings,
[
qr{The new sub is 'MyModernTester2::__ANON__' defined in $file around line $line},
undef, #Only 1 warning
],
"new override, new warning"
);
}
{
package MyLegacyTester;
use Test::More;
no warnings 'redefine';
local *Test::Builder::ok = sub {
my $self = shift;
my ($bool, $name) = @_;
$name = __PACKAGE__ . ": $name";
return $self->$orig($bool, $name);
};
use warnings;
my $file = __FILE__;
# Line number is tricky, just use what B says The sub may not actually think it
# is on the line it is may be off by 1.
my $line = B::svref_2object(\&Test::Builder::ok)->START->line;
my @warnings;
{
local $SIG{__WARN__} = sub { push @warnings => @_ };
ok(1, "fred");
ok(2, "barney");
}
is(@warnings, 0, "no warnings for a legacy tester");
}
|