1App::Yath(3) User Contributed Perl Documentation App::Yath(3)
2
3
4
6 App::Yath - Yet Another Test Harness (Test2-Harness) Command Line
7 Interface (CLI)
8
10 PLEASE NOTE: Test2::Harness is still experimental, it can all change at
11 any time. Documentation and tests have not been written yet!
12
13 This is the primary documentation for "yath", App::Yath,
14 Test2::Harness.
15
16 The canonical source of up-to-date command options are the help output
17 when using "$ yath help" and "$ yath help COMMAND".
18
19 This document is mainly an overview of "yath" usage and common recipes.
20
22 To use Test2::Harness, you use the "yath" command. Yath will find the
23 tests (or use the ones you specify) and run them. As it runs, it will
24 output diagnostic information such as failures. At the end, yath will
25 print a summary of the test run.
26
27 "yath" can be thought of as a more powerful alternative to "prove"
28 (Test::Harness)
29
31 These are common recipes for using "yath".
32
33 RUN PROJECT TESTS
34 $ yath
35
36 Simply running yath with no arguments means "Run all tests for the
37 current project". Yath will look for tests in "./t", "./t2", and
38 "./test.pl" and run any which are found.
39
40 Normally this implies the "test" command but will instead imply the
41 "run" command if a persistent test runner is detected.
42
43 PRELOAD MODULES
44 Yath has the ability to preload modules. Yath normally forks to start
45 new tests, so preloading can reduce the time spent loading modules over
46 and over in each test.
47
48 Note that some tests may depend on certain modules not being loaded. In
49 these cases you can add the "# HARNESS-NO-PRELOAD" directive to the top
50 of the test files that cannot use preload.
51
52 SIMPLE PRELOAD
53
54 Any module can be preloaded:
55
56 $ yath -PMoose
57
58 You can preload as many modules as you want:
59
60 $ yath -PList::Util -PScalar::Util
61
62 COMPLEX PRELOAD
63
64 If your preload is a subclass of Test2::Harness::Preload then more
65 complex preload behavior is possible. See those docs for more info.
66
67 LOGGING
68 RECORDING A LOG
69
70 You can turn on logging with a flag. The filename of the log will be
71 printed at the end.
72
73 $ yath -L
74 ...
75 Wrote log file: test-logs/2017-09-12~22:44:34~1505281474~25709.jsonl
76
77 The event log can be quite large. It can be compressed with bzip2.
78
79 $ yath -B
80 ...
81 Wrote log file: test-logs/2017-09-12~22:44:34~1505281474~25709.jsonl.bz2
82
83 gzip compression is also supported.
84
85 $ yath -G
86 ...
87 Wrote log file: test-logs/2017-09-12~22:44:34~1505281474~25709.jsonl.gz
88
89 "-B" and "-G" both imply "-L".
90
91 REPLAYING FROM A LOG
92
93 You can replay a test run from a log file:
94
95 $ yath test-logs/2017-09-12~22:44:34~1505281474~25709.jsonl.bz2
96
97 This will be significantly faster than the initial run as no tests are
98 actually being executed. All events are simply read from the log, and
99 processed by the harness.
100
101 You can change display options and limit rendering/processing to
102 specific test jobs from the run:
103
104 $ yath test-logs/2017-09-12~22:44:34~1505281474~25709.jsonl.bz2 -v 5 10
105
106 Note: This is done using the "$ yath replay ..." command. The "replay"
107 command is implied if the first argument is a log file.
108
109 PER-TEST TIMING DATA
110 The "-T" option will cause each test file to report how long it took to
111 run.
112
113 $ yath -T
114
115 ( PASSED ) job 1 t/App/Yath.t
116 ( TIME ) job 1 0.06942s on wallclock (0.07 usr 0.01 sys + 0.00 cusr 0.00 csys = 0.08 CPU)
117
118 PERSISTENT RUNNER
119 yath supports starting a yath session that waits for tests to run. This
120 is very useful when combined with preload.
121
122 STARTING
123
124 This starts the server. Many options available to the 'test' command
125 will work here but not all. See "$ yath help start" for more info.
126
127 $ yath start
128
129 RUNNING
130
131 This will run tests using the persistent runner. By default, it will
132 search for tests just like the 'test' command. Many options available
133 to the "test" command will work for this as well. See "$ yath help run"
134 for more details.
135
136 $ yath run
137
138 STOPPING
139
140 Stopping a persistent runner is easy.
141
142 $ yath stop
143
144 INFORMATIONAL
145
146 The "which" command will tell you which persistent runner will be used.
147 Yath searches for the persistent runner in the current directory, then
148 searches in parent directories until it either hits the root directory,
149 or finds the persistent runner tracking file.
150
151 $ yath which
152
153 The "watch" command will tail the runner's log files.
154
155 $ yath watch
156
157 PRELOAD + PERSISTENT RUNNER
158
159 You can use preloads with the "yath start" command. In this case, yath
160 will track all the modules pulled in during preload. If any of them
161 change, the server will reload itself to bring in the changes. Further,
162 modified modules will be blacklisted so that they are not preloaded on
163 subsequent reloads. This behavior is useful if you are actively working
164 on a module that is normally preloaded.
165
166 MAKING YOUR PROJECT ALWAYS USE YATH
167 $ yath init
168
169 The above command will create "test.pl". "test.pl" is automatically run
170 by most build utils, in which case only the exit value matters. The
171 generated "test.pl" will run "yath" and execute all tests in the "./t"
172 and/or "./t2" directories. Tests in "./t" will ALSO be run by prove but
173 tests in "./t2" will only be run by yath.
174
175 PROJECT-SPECIFIC YATH CONFIG
176 You can write a ".yath.rc" file. The file format is very simple. Create
177 a "[COMMAND]" section to start the configuration for a command and then
178 provide any options normally allowed by it. When "yath" is run inside
179 your project, it will use the config specified in the rc file, unless
180 overridden by command line options.
181
182 Comments start with a semi-colon.
183
184 Example .yath.rc:
185
186 [test]
187 -B ;Always write a bzip2-compressed log
188
189 [start]
190 -PMoose ;Always preload Moose with a persistent runner
191
192 This file is normally committed into the project's repo.
193
194 PROJECT-SPECIFIC YATH CONFIG USER OVERRIDES
195 You can add a ".yath.user.rc" file. Format is the same as the regular
196 ".yath.rc" file. This file will be read in addition to the regular
197 config file. Directives in this file will come AFTER the directives in
198 the primary config so it may be used to override config.
199
200 This file should not normally be committed to the project repo.
201
202 HARNESS DIRECTIVES INSIDE TESTS
203 "yath" will recognise a number of directive comments placed near the
204 top of test files. These directives should be placed after the "#!"
205 line but before any real code.
206
207 Real code is defined as any line that does not start with use, require,
208 BEGIN, package, or #
209
210 good example 1
211 #!/usr/bin/perl
212 # HARNESS-NO-FORK
213
214 ...
215
216 good example 2
217 #!/usr/bin/perl
218 use strict;
219 use warnings;
220
221 # HARNESS-NO-FORK
222
223 ...
224
225 bad example 1
226 #!/usr/bin/perl
227
228 # blah
229
230 # HARNESS-NO-FORK
231
232 ...
233
234 bad example 2
235 #!/usr/bin/perl
236
237 print "hi\n";
238
239 # HARNESS-NO-FORK
240
241 ...
242
243 HARNESS-NO-PRELOAD
244
245 #!/usr/bin/perl
246 # HARNESS-NO-PRELOAD
247
248 Use this if your test will fail when modules are preloaded. This will
249 tell yath to start a new perl process to run the script instead of
250 forking with preloaded modules.
251
252 Currently this implies HARNESS-NO-FORK, but that may not always be the
253 case.
254
255 HARNESS-NO-FORK
256
257 #!/usr/bin/perl
258 # HARNESS-NO-FORK
259
260 Use this if your test file cannot run in a forked process, but instead
261 must be run directly with a new perl process.
262
263 This implies HARNESS-NO-PRELOAD.
264
265 HARNESS-NO-STREAM
266
267 "yath" usually uses the Test2::Formatter::Stream formatter instead of
268 TAP. Some tests depend on using a TAP formatter. This option will make
269 "yath" use Test2::Formatter::TAP or Test::Builder::Formatter.
270
271 HARNESS-NO-TIMEOUT
272
273 "yath" will usually kill a test if no events occur within a timeout
274 (default 60 seconds). You can add this directive to tests that are
275 expected to trip the timeout, but should be allowed to continue.
276
277 NOTE: you usually are doing the wrong thing if you need to set this.
278 See: "HARNESS-TIMEOUT-EVENT".
279
280 HARNESS-TIMEOUT-EVENT 60
281
282 "yath" can be told to alter the default event timeout from 60 seconds
283 to another value. This is the recommended alternative to HARNESS-NO-
284 TIMEOUT
285
286 HARNESS-TIMEOUT-POSTEXIT 15
287
288 "yath" can be told to alter the default POSTEXIT timeout from 15
289 seconds to another value.
290
291 Sometimes a test will fork producing output in the child while the
292 parent is allowed to exit. In these cases we cannot rely on the
293 original process exit to tell us when a test is complete. In cases
294 where we have an exit, and partial output (assertions with no final
295 plan, or a plan that has not been completed) we wait for a timeout
296 period to see if any additional events come into
297
298 HARNESS-CATEGORY-LONG
299
300 This lets you tell "yath" that the test file is long-running. This is
301 primarily used when concurrency is turned on in order to run longer
302 tests earlier, and concurrently with shorter ones. There is also a
303 "yath" option to skip all long category tests.
304
305 This category is set automatically if HARNESS-NO-TIMEOUT is set.
306
307 HARNESS-CATEGORY-MEDIUM
308
309 This lets you tell "yath" that the test is medium-length.
310
311 This category is set automatically if HARNESS-NO-FORK or HARNESS-NO-
312 PRELOAD are set.
313
314 HARNESS-CATEGORY-ISOLATION
315
316 This lets you tell "yath" that the test cannot be run concurrently with
317 other tests. Yath will hold off and run these tests one at a time after
318 all other tests.
319
320 HARNESS-CATEGORY-IMMISCIBLE
321
322 This lets you tell "yath" that the test cannot be run concurrently with
323 other tests of this class. This is helpful when you have multiple tests
324 which would otherwise have to be run sequentially at the end of the
325 run.
326
327 Yath prioritizes running these tests above HARNESS-CATEGORY-LONG.
328
329 HARNESS-CATEGORY-GENERAL
330
331 This is the default category.
332
333 HARNESS-CONFLICTS-XXX
334
335 This lets you tell "yath" that no other test of type XXX can be run at
336 the same time as this one. You are able to set multiple conflict types
337 and "yath" will honor them.
338
339 XXX can be replaced with any type of your choosing.
340
341 NOTE: This directive does not alter the category of your test. You are
342 free to mark the test with LONG or MEDIUM in addition to this marker.
343
344 Example with multiple lines.
345 #!/usr/bin/perl
346 # DASH and space are split the same way.
347 # HARNESS-CONFLICTS-DAEMON
348 # HARNESS-CONFLICTS MYSQL
349
350 ...
351
352 Or on a single line.
353 #!/usr/bin/perl
354 # HARNESS-CONFLICTS DAEMON MYSQL
355
356 ...
357
359 This section documents the App::Yath module itself.
360
361 SYNOPSIS
362 This is the entire "yath" script, comments removed.
363
364 #!/usr/bin/env perl
365 use App::Yath(\@ARGV, \$App::Yath::RUN);
366 exit($App::Yath::RUN->());
367
368 METHODS
369 $class->import(\@argv, \$runref)
370 This will find, load, and process the command as found via @argv
371 processing. It will set $runref to a coderef that should be
372 executed at runtime (IE not in the "BEGIN" block implied by "use".
373
374 Please note that statements after the import may never be reached.
375 A source filter may be used to rewrite the rest of the file to be
376 the source of a running test.
377
378 $class->info("Message")
379 Print a message to STDOUT.
380
381 $class->run_command($cmd_class, $cmd_name, \@argv)
382 Run a command identified by $cmd_class and $cmd_name, using
383 "\@argv" as input.
384
385 $cmd_name = $class->parse_argv(\@argv)
386 Determine what command should be used based on "\@argv". "\@argv"
387 may be modified depending on what it contains.
388
389 $cmd_class = $class->load_command($cmd_name)
390 Load a command by name, returns the class of the command.
391
393 The source code repository for Test2-Harness can be found at
394 http://github.com/Test-More/Test2-Harness/.
395
397 Chad Granum <exodist@cpan.org>
398
400 Chad Granum <exodist@cpan.org>
401
403 Copyright 2019 Chad Granum <exodist7@gmail.com>.
404
405 This program is free software; you can redistribute it and/or modify it
406 under the same terms as Perl itself.
407
408 See http://dev.perl.org/licenses/
409
410
411
412perl v5.30.0 2019-08-14 App::Yath(3)