This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
6f9d634c025146d2fee48170ee6618e6337a74d0
[perl5.git] / lib / Test / Simple / t / fail-more.t
1 #!perl -w
2
3 BEGIN {
4     if( $ENV{PERL_CORE} ) {
5         chdir 't';
6         @INC = ('../lib', 'lib');
7     }
8     else {
9         unshift @INC, 't/lib';
10     }
11 }
12
13 use strict;
14
15 require Test::Simple::Catch;
16 my($out, $err) = Test::Simple::Catch::caught();
17 local $ENV{HARNESS_ACTIVE} = 0;
18
19
20 # Can't use Test.pm, that's a 5.005 thing.
21 package My::Test;
22
23 # This has to be a require or else the END block below runs before
24 # Test::Builder's own and the ending diagnostics don't come out right.
25 require Test::Builder;
26 my $TB = Test::Builder->create;
27 $TB->plan(tests => 17);
28
29 sub like ($$;$) {
30     $TB->like(@_);
31 }
32
33 sub is ($$;$) {
34     $TB->is_eq(@_);
35 }
36
37 sub main::err_ok ($) {
38     my($expect) = @_;
39     my $got = $err->read;
40
41     return $TB->is_eq( $got, $expect );
42 }
43
44
45 package main;
46
47 require Test::More;
48 my $Total = 28;
49 Test::More->import(tests => $Total);
50
51 my $tb = Test::More->builder;
52 $tb->use_numbers(0);
53
54 my $Filename = quotemeta $0;
55
56 # Preserve the line numbers.
57 #line 38
58 ok( 0, 'failing' );
59 err_ok( <<ERR );
60 #   Failed test 'failing'
61 #   in $0 at line 38.
62 ERR
63
64 #line 40
65 is( "foo", "bar", 'foo is bar?');
66 is( undef, '',    'undef is empty string?');
67 is( undef, 0,     'undef is 0?');
68 is( '',    0,     'empty string is 0?' );
69 err_ok( <<ERR );
70 #   Failed test 'foo is bar?'
71 #   in $0 at line 40.
72 #          got: 'foo'
73 #     expected: 'bar'
74 #   Failed test 'undef is empty string?'
75 #   in $0 at line 41.
76 #          got: undef
77 #     expected: ''
78 #   Failed test 'undef is 0?'
79 #   in $0 at line 42.
80 #          got: undef
81 #     expected: '0'
82 #   Failed test 'empty string is 0?'
83 #   in $0 at line 43.
84 #          got: ''
85 #     expected: '0'
86 ERR
87
88 #line 45
89 isnt("foo", "foo", 'foo isnt foo?' );
90 isn't("foo", "foo",'foo isn\'t foo?' );
91 isnt(undef, undef, 'undef isnt undef?');
92 err_ok( <<ERR );
93 #   Failed test 'foo isnt foo?'
94 #   in $0 at line 45.
95 #     'foo'
96 #         ne
97 #     'foo'
98 #   Failed test 'foo isn\'t foo?'
99 #   in $0 at line 46.
100 #     'foo'
101 #         ne
102 #     'foo'
103 #   Failed test 'undef isnt undef?'
104 #   in $0 at line 47.
105 #     undef
106 #         ne
107 #     undef
108 ERR
109
110 #line 48
111 like( "foo", '/that/',  'is foo like that' );
112 unlike( "foo", '/foo/', 'is foo unlike foo' );
113 err_ok( <<ERR );
114 #   Failed test 'is foo like that'
115 #   in $0 at line 48.
116 #                   'foo'
117 #     doesn't match '/that/'
118 #   Failed test 'is foo unlike foo'
119 #   in $0 at line 49.
120 #                   'foo'
121 #           matches '/foo/'
122 ERR
123
124 # Nick Clark found this was a bug.  Fixed in 0.40.
125 # line 60
126 like( "bug", '/(%)/',   'regex with % in it' );
127 err_ok( <<ERR );
128 #   Failed test 'regex with % in it'
129 #   in $0 at line 60.
130 #                   'bug'
131 #     doesn't match '/(%)/'
132 ERR
133
134 #line 67
135 fail('fail()');
136 err_ok( <<ERR );
137 #   Failed test 'fail()'
138 #   in $0 at line 67.
139 ERR
140
141 #line 52
142 can_ok('Mooble::Hooble::Yooble', qw(this that));
143 can_ok('Mooble::Hooble::Yooble', ());
144 err_ok( <<ERR );
145 #   Failed test 'Mooble::Hooble::Yooble->can(...)'
146 #   in $0 at line 52.
147 #     Mooble::Hooble::Yooble->can('this') failed
148 #     Mooble::Hooble::Yooble->can('that') failed
149 #   Failed test 'Mooble::Hooble::Yooble->can(...)'
150 #   in $0 at line 53.
151 #     can_ok() called with no methods
152 ERR
153
154 #line 55
155 isa_ok(bless([], "Foo"), "Wibble");
156 isa_ok(42,    "Wibble", "My Wibble");
157 isa_ok(undef, "Wibble", "Another Wibble");
158 isa_ok([],    "HASH");
159 err_ok( <<ERR );
160 #   Failed test 'The object isa Wibble'
161 #   in $0 at line 55.
162 #     The object isn't a 'Wibble' it's a 'Foo'
163 #   Failed test 'My Wibble isa Wibble'
164 #   in $0 at line 56.
165 #     My Wibble isn't a reference
166 #   Failed test 'Another Wibble isa Wibble'
167 #   in $0 at line 57.
168 #     Another Wibble isn't defined
169 #   Failed test 'The object isa HASH'
170 #   in $0 at line 58.
171 #     The object isn't a 'HASH' it's a 'ARRAY'
172 ERR
173
174 #line 68
175 cmp_ok( 'foo', 'eq', 'bar', 'cmp_ok eq' );
176 cmp_ok( 42.1,  '==', 23,  , '       ==' );
177 cmp_ok( 42,    '!=', 42   , '       !=' );
178 cmp_ok( 1,     '&&', 0    , '       &&' );
179 err_ok( <<ERR );
180 #   Failed test 'cmp_ok eq'
181 #   in $0 at line 68.
182 #          got: 'foo'
183 #     expected: 'bar'
184 #   Failed test '       =='
185 #   in $0 at line 69.
186 #          got: 42.1
187 #     expected: 23
188 #   Failed test '       !='
189 #   in $0 at line 70.
190 #     '42'
191 #         !=
192 #     '42'
193 #   Failed test '       &&'
194 #   in $0 at line 71.
195 #     '1'
196 #         &&
197 #     '0'
198 ERR
199
200
201 # line 196
202 cmp_ok( 42,    'eq', "foo", '       eq with numbers' );
203 err_ok( <<ERR );
204 #   Failed test '       eq with numbers'
205 #   in $0 at line 196.
206 #          got: '42'
207 #     expected: 'foo'
208 ERR
209
210
211 {
212     my $warnings;
213     local $SIG{__WARN__} = sub { $warnings .= join '', @_ };
214
215 # line 211
216     cmp_ok( 42,    '==', "foo", '       == with strings' );
217     err_ok( <<ERR );
218 #   Failed test '       == with strings'
219 #   in $0 at line 211.
220 #          got: 42
221 #     expected: foo
222 ERR
223     My::Test::like $warnings,
224      qq[/^Argument "foo" isn't numeric in .* at $Filename line 211\\\.\n\$/];
225
226 }
227
228
229 # generate a $!, it changes its value by context.
230 -e "wibblehibble";
231 my $Errno_Number = $!+0;
232 my $Errno_String = $!.'';
233 #line 80
234 cmp_ok( $!,    'eq', '',    '       eq with stringified errno' );
235 cmp_ok( $!,    '==', -1,    '       eq with numerified errno' );
236 err_ok( <<ERR );
237 #   Failed test '       eq with stringified errno'
238 #   in $0 at line 80.
239 #          got: '$Errno_String'
240 #     expected: ''
241 #   Failed test '       eq with numerified errno'
242 #   in $0 at line 81.
243 #          got: $Errno_Number
244 #     expected: -1
245 ERR
246
247 #line 84
248 use_ok('Hooble::mooble::yooble');
249
250 my $more_err_re = <<ERR;
251 #   Failed test 'use Hooble::mooble::yooble;'
252 #   in $Filename at line 84\\.
253 #     Tried to use 'Hooble::mooble::yooble'.
254 #     Error:  Can't locate Hooble.* in \\\@INC .*
255 # BEGIN failed--compilation aborted at $Filename line 84.
256 ERR
257
258 My::Test::like($err->read, "/^$more_err_re/");
259
260
261 #line 85
262 require_ok('ALL::YOUR::BASE::ARE::BELONG::TO::US::wibble');
263 $more_err_re = <<ERR;
264 #   Failed test 'require ALL::YOUR::BASE::ARE::BELONG::TO::US::wibble;'
265 #   in $Filename at line 85\\.
266 #     Tried to require 'ALL::YOUR::BASE::ARE::BELONG::TO::US::wibble'.
267 #     Error:  Can't locate ALL.* in \\\@INC .*
268 ERR
269
270 My::Test::like($err->read, "/^$more_err_re/");
271
272
273 #line 88
274 END {
275     $TB->is_eq($$out, <<OUT, 'failing output');
276 1..$Total
277 not ok - failing
278 not ok - foo is bar?
279 not ok - undef is empty string?
280 not ok - undef is 0?
281 not ok - empty string is 0?
282 not ok - foo isnt foo?
283 not ok - foo isn't foo?
284 not ok - undef isnt undef?
285 not ok - is foo like that
286 not ok - is foo unlike foo
287 not ok - regex with % in it
288 not ok - fail()
289 not ok - Mooble::Hooble::Yooble->can(...)
290 not ok - Mooble::Hooble::Yooble->can(...)
291 not ok - The object isa Wibble
292 not ok - My Wibble isa Wibble
293 not ok - Another Wibble isa Wibble
294 not ok - The object isa HASH
295 not ok - cmp_ok eq
296 not ok -        ==
297 not ok -        !=
298 not ok -        &&
299 not ok -        eq with numbers
300 not ok -        == with strings
301 not ok -        eq with stringified errno
302 not ok -        eq with numerified errno
303 not ok - use Hooble::mooble::yooble;
304 not ok - require ALL::YOUR::BASE::ARE::BELONG::TO::US::wibble;
305 OUT
306
307 err_ok( <<ERR );
308 # Looks like you failed $Total tests of $Total.
309 ERR
310
311     exit(0);
312 }