1Test::Output(3) User Contributed Perl Documentation Test::Output(3)
2
3
4
6 Test::Output - Utilities to test STDOUT and STDERR messages.
7
9 Version 0.12
10
12 use Test::More tests => 4;
13 use Test::Output;
14
15 sub writer {
16 print "Write out.\n";
17 print STDERR "Error out.\n";
18 }
19
20 stdout_is(\&writer,"Write out.\n",'Test STDOUT');
21
22 stderr_isnt(\&writer,"No error out.\n",'Test STDERR');
23
24 combined_is(
25 \&writer,
26 "Write out.\nError out.\n",
27 'Test STDOUT & STDERR combined'
28 );
29
30 output_is(
31 \&writer,
32 "Write out.\n",
33 "Error out.\n",
34 'Test STDOUT & STDERR'
35 );
36
37 # Use bare blocks.
38
39 stdout_is { print "test" } "test" "Test STDOUT";
40 stderr_isnt { print "bad test" } "test" "Test STDERR";
41 output_is { print 'STDOUT'; print STDERR 'STDERR' }
42 "STDOUT", "STDERR", "Test output";
43
45 Test::Output provides a simple interface for testing output sent to
46 STDOUT or STDERR. A number of different utilities are included to try
47 and be as flexible as possible to the tester.
48
49 Originally this module was designed not to have external requirements,
50 however, the features provided by Sub::Exporter over what Exporter
51 provides is just to great to pass up.
52
53 Test::Output ties STDOUT and STDERR using Test::Output::Tie.
54
56 STDOUT
57 stdout_is
58 stdout_isnt
59 stdout_is ( $coderef, $expected, 'description' );
60 stdout_is { ... } $expected, 'description';
61 stdout_isnt( $coderef, $expected, 'description' );
62 stdout_isnt { ... } $expected, 'description';
63
64 stdout_is() captures output sent to STDOUT from $coderef and
65 compares it against $expected. The test passes if equal.
66
67 stdout_isnt() passes if STDOUT is not equal to $expected.
68
69 stdout_like
70 stdout_unlike
71 stdout_like ( $coderef, qr/$expected/, 'description' );
72 stdout_like { ... } qr/$expected/, 'description';
73 stdout_unlike( $coderef, qr/$expected/, 'description' );
74 stdout_unlike { ... } qr/$expected/, 'description';
75
76 stdout_like() captures the output sent to STDOUT from $coderef and
77 compares it to the regex in $expected. The test passes if the regex
78 matches.
79
80 stdout_unlike() passes if STDOUT does not match the regex.
81
82 STDERR
83 stderr_is
84 stderr_isnt
85 stderr_is ( $coderef, $expected, 'description' );
86 stderr_is {... } $expected, 'description';
87 stderr_isnt( $coderef, $expected, 'description' );
88 stderr_isnt {... } $expected, 'description';
89
90 stderr_is() is similar to stdout_is, except that it captures
91 STDERR. The test passes if STDERR from $coderef equals $expected.
92
93 stderr_isnt() passes if STDERR is not equal to $expected.
94
95 stderr_like
96 stderr_unlike
97 stderr_like ( $coderef, qr/$expected/, 'description' );
98 stderr_like { ...} qr/$expected/, 'description';
99 stderr_unlike( $coderef, qr/$expected/, 'description' );
100 stderr_unlike { ...} qr/$expected/, 'description';
101
102 stderr_like() is similar to stdout_like() except that it compares
103 the regex $expected to STDERR captured from $codref. The test
104 passes if the regex matches.
105
106 stderr_unlike() passes if STDERR does not match the regex.
107
108 COMBINED OUTPUT
109 combined_is
110 combined_isnt
111 combined_is ( $coderef, $expected, 'description' );
112 combined_is {... } $expected, 'description';
113 combined_isnt ( $coderef, $expected, 'description' );
114 combined_isnt {... } $expected, 'description';
115
116 combined_is() directs STDERR to STDOUT then captures STDOUT. This
117 is equivalent to UNIXs 2>&1. The test passes if the combined STDOUT
118 and STDERR from $coderef equals $expected.
119
120 combined_isnt() passes if combined STDOUT and STDERR are not equal
121 to $expected.
122
123 combined_like
124 combined_unlike
125 combined_like ( $coderef, qr/$expected/, 'description' );
126 combined_like { ...} qr/$expected/, 'description';
127 combined_unlike ( $coderef, qr/$expected/, 'description' );
128 combined_unlike { ...} qr/$expected/, 'description';
129
130 combined_like() is similar to combined_is() except that it compares
131 a regex ($expected) to STDOUT and STDERR captured from $codref. The
132 test passes if the regex matches.
133
134 combined_unlike() passes if the combined STDOUT and STDERR does not
135 match the regex.
136
137 OUTPUT
138 output_is
139 output_isnt
140 output_is ( $coderef, $expected_stdout, $expected_stderr, 'description' );
141 output_is {... } $expected_stdout, $expected_stderr, 'description';
142 output_isnt( $coderef, $expected_stdout, $expected_stderr, 'description' );
143 output_isnt {... } $expected_stdout, $expected_stderr, 'description';
144
145 The output_is() function is a combination of the stdout_is() and
146 stderr_is() functions. For example:
147
148 output_is(sub {print "foo"; print STDERR "bar";},'foo','bar');
149
150 is functionally equivalent to
151
152 stdout_is(sub {print "foo";},'foo')
153 && stderr_is(sub {print STDERR "bar";'bar');
154
155 except that $coderef is only executed once.
156
157 Unlike, stdout_is() and stderr_is() which ignore STDERR and STDOUT
158 repectively, output_is() requires both STDOUT and STDERR to match
159 in order to pass. Setting either $expected_stdout or
160 $expected_stderr to "undef" ignores STDOUT or STDERR respectively.
161
162 output_is(sub {print "foo"; print STDERR "bar";},'foo',undef);
163
164 is the same as
165
166 stdout_is(sub {print "foo";},'foo')
167
168 output_isnt() provides the opposite function of output_is(). It is
169 a combination of stdout_isnt() and stderr_isnt().
170
171 output_isnt(sub {print "foo"; print STDERR "bar";},'bar','foo');
172
173 is functionally equivalent to
174
175 stdout_is(sub {print "foo";},'bar')
176 && stderr_is(sub {print STDERR "bar";'foo');
177
178 As with output_is(), setting either $expected_stdout or
179 $expected_stderr to "undef" ignores the output to that facility.
180
181 output_isnt(sub {print "foo"; print STDERR "bar";},undef,'foo');
182
183 is the same as
184
185 stderr_is(sub {print STDERR "bar";},'foo')
186
187 output_like
188 output_unlike
189 output_like ( $coderef, $regex_stdout, $regex_stderr, 'description' );
190 output_like { ... } $regex_stdout, $regex_stderr, 'description';
191 output_unlike( $coderef, $regex_stdout, $regex_stderr, 'description' );
192 output_unlike { ... } $regex_stdout, $regex_stderr, 'description';
193
194 output_like() and output_unlike() follow the same principles as
195 output_is() and output_isnt() except they use a regular expression
196 for matching.
197
198 output_like() attempts to match $regex_stdout and $regex_stderr
199 against STDOUT and STDERR produced by $coderef. The test passes if
200 both match.
201
202 output_like(sub {print "foo"; print STDERR "bar";},qr/foo/,qr/bar/);
203
204 The above test is successful.
205
206 Like output_is(), setting either $regex_stdout or $regex_stderr to
207 "undef" ignores the output to that facility.
208
209 output_like(sub {print "foo"; print STDERR "bar";},qr/foo/,undef);
210
211 is the same as
212
213 stdout_like(sub {print "foo"; print STDERR "bar";},qr/foo/);
214
215 output_unlike() test pass if output from $coderef doesn't match
216 $regex_stdout and $regex_stderr.
217
219 By default, all tests are exported, however with the switch to
220 Sub::Exporter export groups are now available to better limit imports.
221
222 To import tests for STDOUT:
223
224 use Test::Output qw(:stdout);
225
226 To import tests STDERR:
227
228 use Test::Output qw(:stderr);
229
230 To import just the functions:
231
232 use Test::Output qw(:functions);
233
234 And to import all tests:
235
236 use Test::Output;
237
238 The following is a list of group names and which functions are
239 exported:
240
241 stdout
242 stdout_is stdout_isnt stdout_like stdout_unlike
243
244 stderr
245 stderr_is stderr_isnt stderr_like stderr_unlike
246
247 output
248 output_is output_isnt output_like output_unlike
249
250 combined
251 combined_is combined_isnt combined_like combined_unlike
252
253 tests
254 All of the above, this is the default when no options are given.
255
256 Sub::Exporter allows for many other options, I encourage reading its
257 documentation.
258
260 stdout_from
261 my $stdout = stdout_from($coderef)
262 my $stdout = stdout_from { ... };
263
264 stdout_from() executes $coderef and captures STDOUT.
265
266 stderr_from
267 my $stderr = stderr_from($coderef)
268 my $stderr = stderr_from { ... };
269
270 stderr_from() executes $coderef and captures STDERR.
271
272 output_from
273 my ($stdout, $stderr) = output_from($coderef)
274 my ($stdout, $stderr) = output_from {...};
275
276 output_from() executes $coderef one time capturing both STDOUT and
277 STDERR.
278
279 combined_from
280 my $combined = combined_from($coderef);
281 my $combined = combined_from {...};
282
283 combined_from() executes $coderef one time combines STDOUT and STDERR,
284 and captures them. combined_from() is equivalent to using 2>&1 in UNIX.
285
287 Shawn Sorichetti, "<ssoriche@cpan.org>"
288
290 This module is in Github:
291
292 "/github.com/ssoriche/test-output/tree/master"" in <a
293 href="http:http://github.com/ssoriche/test-output/tree/master</a>>
294
296 Please report any bugs or feature requests to
297 "bug-test-output@rt.cpan.org", or through the web interface at
298 <http://rt.cpan.org>. I will be notified, and then you'll
299 automatically be notified of progress on your bug as I make changes.
300
302 Thanks to chromatic whose TieOut.pm was the basis for capturing output.
303
304 Also thanks to rjbs for his help cleaning the documention, and pushing
305 me to Sub::Exporter.
306
307 Thanks to David Wheeler for providing code block support and tests.
308
309 Thanks to Michael G Schwern for the solution to combining STDOUT and
310 STDERR.
311
313 Copyright 2005 Shawn Sorichetti, All Rights Reserved.
314
315 This program is free software; you can redistribute it and/or modify it
316 under the same terms as Perl itself.
317
318
319
320perl v5.10.1 2008-10-25 Test::Output(3)