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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
|
#!perl -w
# $Id$
BEGIN {
if( $ENV{PERL_CORE} ) {
chdir 't';
@INC = '../lib';
}
}
use Test::More;
plan tests => 36;
$Why = 'Just testing the todo interface.';
my $is_todo;
TODO: {
local $TODO = $Why;
fail("Expected failure");
fail("Another expected failure");
$is_todo = Test::More->builder->todo;
}
pass("This is not todo");
ok( $is_todo, 'TB->todo' );
TODO: {
local $TODO = $Why;
fail("Yet another failure");
}
pass("This is still not todo");
TODO: {
local $TODO = "testing that error messages don't leak out of todo";
ok( 'this' eq 'that', 'ok' );
like( 'this', '/that/', 'like' );
is( 'this', 'that', 'is' );
isnt( 'this', 'this', 'isnt' );
can_ok('Fooble', 'yarble');
isa_ok('Fooble', 'yarble');
use_ok('Fooble');
require_ok('Fooble');
}
TODO: {
todo_skip "Just testing todo_skip", 2;
fail("Just testing todo");
die "todo_skip should prevent this";
pass("Again");
}
{
my $warning;
local $SIG{__WARN__} = sub { $warning = join "", @_ };
TODO: {
# perl gets the line number a little wrong on the first
# statement inside a block.
1 == 1;
#line 74
todo_skip "Just testing todo_skip";
fail("So very failed");
}
is( $warning, "todo_skip() needs to know \$how_many tests are in the ".
"block at $0 line 74\n",
'todo_skip without $how_many warning' );
}
my $builder = Test::More->builder;
my $exported_to = $builder->exported_to;
TODO: {
$builder->exported_to("Wibble");
local $TODO = "testing \$TODO with an incorrect exported_to()";
fail("Just testing todo");
}
$builder->exported_to($exported_to);
$builder->todo_start('Expected failures');
fail('Testing todo_start()');
ok 0, 'Testing todo_start() with more than one failure';
$is_todo = $builder->todo;
$builder->todo_end;
is $is_todo, 'Expected failures',
'todo_start should have the correct TODO message';
ok 1, 'todo_end() should not leak TODO behavior';
my @nested_todo;
my ( $level1, $level2 ) = ( 'failure level 1', 'failure_level 2' );
TODO: {
local $TODO = 'Nesting TODO';
fail('fail 1');
$builder->todo_start($level1);
fail('fail 2');
push @nested_todo => $builder->todo;
$builder->todo_start($level2);
fail('fail 3');
push @nested_todo => $builder->todo;
$builder->todo_end;
fail('fail 4');
push @nested_todo => $builder->todo;
$builder->todo_end;
$is_todo = $builder->todo;
fail('fail 4');
}
is_deeply \@nested_todo, [ $level1, $level2, $level1 ],
'Nested TODO message should be correct';
is $is_todo, 'Nesting TODO',
'... and original TODO message should be correct';
{
$builder->todo_start;
fail("testing todo_start() with no message");
my $reason = $builder->todo;
my $in_todo = $builder->in_todo;
$builder->todo_end;
is $reason, '', " todo() reports no reason";
ok $in_todo, " but we're in_todo()";
}
eval {
$builder->todo_end;
};
is $@, sprintf "todo_end() called without todo_start() at %s line %d.\n", $0, __LINE__ - 2;
{
my($reason, $in_todo);
TODO: {
local $TODO = '';
$reason = $builder->todo;
$in_todo = $builder->in_todo;
}
is $reason, '';
ok !$in_todo, '$TODO = "" is not considered TODO';
}
|