1App::Yath::Command::staUrste(r3)Contributed Perl DocumenAtpapt:i:oYnath::Command::start(3)
2
3
4

NAME

6       App::Yath::Command::start - Start the persistent test runner
7

DESCRIPTION

9       This command is used to start a persistant instance of yath. A
10       persistant instance is useful because it allows you to preload modules
11       in advance, reducing start time for any tests you decide to run as you
12       work.
13
14       A running instance will watch for changes to any preloaded files, and
15       restart itself if anything changes. Changed files are blacklisted for
16       subsequent reloads so that reloading is not a frequent occurence when
17       editing the same file over and over again.
18

USAGE

20           $ yath [YATH OPTIONS] start [COMMAND OPTIONS]
21
22   YATH OPTIONS
23       Developer
24
25       --dev-lib
26       --dev-lib=lib
27       -D
28       -D=lib
29       -Dlib
30       --no-dev-lib
31           Add paths to @INC before loading ANYTHING. This is what you use if
32           you are developing yath or yath plugins to make sure the yath
33           script finds the local code instead of the installed versions of
34           the same code. You can provide an argument (-Dfoo) to provide a
35           custom path, or you can just use -D without and arg to add lib,
36           blib/lib and blib/arch.
37
38           Can be specified multiple times
39
40       Environment
41
42       --persist-dir ARG
43       --persist-dir=ARG
44       --no-persist-dir
45           Where to find persistence files.
46
47       --persist-file ARG
48       --persist-file=ARG
49       --pfile ARG
50       --pfile=ARG
51       --no-persist-file
52           Where to find the persistence file. The default is
53           /{system-tempdir}/project-yath-persist.json. If no project is
54           specified then it will fall back to the current directory. If the
55           current directory is not writable it will default to
56           /tmp/yath-persist.json which limits you to one persistent runner on
57           your system.
58
59       --project ARG
60       --project=ARG
61       --project-name ARG
62       --project-name=ARG
63       --no-project
64           This lets you provide a label for your current project/codebase.
65           This is best used in a .yath.rc file. This is necessary for a
66           persistent runner.
67
68       Help and Debugging
69
70       --show-opts
71       --no-show-opts
72           Exit after showing what yath thinks your options mean
73
74       --version
75       -V
76       --no-version
77           Exit after showing a helpful usage message
78
79       Plugins
80
81       --no-scan-plugins
82       --no-no-scan-plugins
83           Normally yath scans for and loads all App::Yath::Plugin::* modules
84           in order to bring in command-line options they may provide. This
85           flag will disable that. This is useful if you have a naughty plugin
86           that is loading other modules when it should not.
87
88       --plugins PLUGIN
89       --plugins +App::Yath::Plugin::PLUGIN
90       --plugins PLUGIN=arg1,arg2,...
91       --plugin PLUGIN
92       --plugin +App::Yath::Plugin::PLUGIN
93       --plugin PLUGIN=arg1,arg2,...
94       -pPLUGIN
95       --no-plugins
96           Load a yath plugin.
97
98           Can be specified multiple times
99
100   COMMAND OPTIONS
101       Collector Options
102
103       --max-open-jobs 18
104       --no-max-open-jobs
105           Maximum number of jobs a collector can process at a time, if more
106           jobs are pending their output will be delayed until the earlier
107           jobs have been processed. (Default: double the -j value)
108
109       --max-poll-events 1000
110       --no-max-poll-events
111           Maximum number of events to poll from a job before jumping to the
112           next job. (Default: 1000)
113
114       Cover Options
115
116       --cover-aggregator ByTest
117       --cover-aggregator ByRun
118       --cover-aggregator +Custom::Aggregator
119       --cover-agg ByTest
120       --cover-agg ByRun
121       --cover-agg +Custom::Aggregator
122       --no-cover-aggregator
123           Choose a custom aggregator subclass
124
125       --cover-class ARG
126       --cover-class=ARG
127       --no-cover-class
128           Choose a Test2::Plugin::Cover subclass
129
130       --cover-dirs ARG
131       --cover-dirs=ARG
132       --cover-dir ARG
133       --cover-dir=ARG
134       --no-cover-dirs
135           NO DESCRIPTION - FIX ME
136
137           Can be specified multiple times
138
139       --cover-exclude-private
140       --no-cover-exclude-private
141       --cover-files
142       --no-cover-files
143           Use Test2::Plugin::Cover to collect coverage data for what files
144           are touched by what tests. Unlike Devel::Cover this has very little
145           performance impact (About 4% difference)
146
147       --cover-from path/to/log.jsonl
148       --cover-from http://example.com/coverage
149       --cover-from path/to/coverage.jsonl
150       --no-cover-from
151           This can be a test log, a coverage dump (old style json or new
152           jsonl format), or a url to any of the previous. Tests will not be
153           run if the file/url is invalid.
154
155       --cover-from-type json
156       --cover-from-type jsonl
157       --cover-from-type log
158       --no-cover-from-type
159           File type for coverage source. Usually it can be detected, but when
160           it cannot be you should specify. "json" is old style single-blob
161           coverage data, "jsonl" is the new by-test style, "log" is a logfile
162           from a previous run.
163
164       --cover-manager My::Coverage::Manager
165       --no-cover-manager
166           Coverage 'from' manager to use when coverage data does not provide
167           one
168
169       --cover-maybe-from path/to/log.jsonl
170       --cover-maybe-from http://example.com/coverage
171       --cover-maybe-from path/to/coverage.jsonl
172       --no-cover-maybe-from
173           This can be a test log, a coverage dump (old style json or new
174           jsonl format), or a url to any of the previous. Tests will coninue
175           if even if the coverage file/url is invalid.
176
177       --cover-maybe-from-type json
178       --cover-maybe-from-type jsonl
179       --cover-maybe-from-type log
180       --no-cover-maybe-from-type
181           Same as "from_type" but for "maybe_from". Defaults to "from_type"
182           if that is specified, otherwise auto-detect
183
184       --cover-metrics
185       --no-cover-metrics
186       --cover-types ARG
187       --cover-types=ARG
188       --cover-type ARG
189       --cover-type=ARG
190       --no-cover-types
191           NO DESCRIPTION - FIX ME
192
193           Can be specified multiple times
194
195       --cover-write
196       --cover-write=coverage.jsonl
197       --cover-write=coverage.json
198       --no-cover-write
199           Create a json or jsonl file of all coverage data seen during the
200           run (This implies --cover-files).
201
202       Git Options
203
204       --git-change-base master
205       --git-change-base HEAD^
206       --git-change-base df22abe4
207       --no-git-change-base
208           Find files changed by all commits in the current branch from most
209           recent stopping when a commit is found that is also present in the
210           history of the branch/commit specified as the change base.
211
212       Help and Debugging
213
214       --dummy
215       -d
216       --no-dummy
217           Dummy run, do not actually execute anything
218
219           Can also be set with the following environment variables:
220           "T2_HARNESS_DUMMY"
221
222       --help
223       -h
224       --no-help
225           exit after showing help information
226
227       --interactive
228       -i
229       --no-interactive
230           Use interactive mode, 1 test at a time, stdin forwarded to it
231
232       --keep-dirs
233       --keep_dir
234       -k
235       --no-keep-dirs
236           Do not delete directories when done. This is useful if you want to
237           inspect the directories used for various commands.
238
239       --procname-prefix ARG
240       --procname-prefix=ARG
241       --no-procname-prefix
242           Add a prefix to all proc names (as seen by ps).
243
244       Persistent Runner Options
245
246       --quiet
247       -q
248       --no-quiet
249           Be very quiet.
250
251           Can be specified multiple times
252
253       --reload
254       -r
255       --no-reload
256           Attempt to reload modified modules in-place, restarting entire
257           stages only when necessary.
258
259       --restrict-reload
260       --restrict-reload=path
261       --no-restrict-reload
262           Only reload modules under the specified path, if no path is
263           specified look at anything under the .yath.rc path, or the current
264           working directory.
265
266           Can be specified multiple times
267
268       Runner Options
269
270       --abort-on-bail
271       --no-abort-on-bail
272           Abort all testing if a bail-out is encountered (default: on)
273
274       --blib
275       -b
276       --no-blib
277           (Default: include if it exists) Include 'blib/lib' and 'blib/arch'
278           in your module path
279
280       --cover
281       --cover=-silent,1,+ignore,^t/,+ignore,^t2/,+ignore,^xt,+ignore,^test.pl
282       --no-cover
283           Use Devel::Cover to calculate test coverage. This disables forking.
284           If no args are specified the following are used:
285           -silent,1,+ignore,^t/,+ignore,^t2/,+ignore,^xt,+ignore,^test.pl
286
287       --daemon
288       --no-daemon
289           Start the runner as a daemon (Default: True)
290
291       --dump-depmap
292       --no-dump-depmap
293           When using staged preload, dump the depmap for each stage as json
294           files
295
296       --event-timeout SECONDS
297       --et SECONDS
298       --no-event-timeout
299           Kill test if no output is received within timeout period. (Default:
300           60 seconds). Add the "# HARNESS-NO-TIMEOUT" comment to the top of a
301           test file to disable timeouts on a per-test basis. This prevents a
302           hung test from running forever.
303
304       --include ARG
305       --include=ARG
306       -I ARG
307       -I=ARG
308       --no-include
309           Add a directory to your include paths
310
311           Can be specified multiple times
312
313       --job-count 4
314       --job-count 8:2
315       --jobs 4
316       --jobs 8:2
317       -j4
318       -j8:2
319       --no-job-count
320           Set the number of concurrent jobs to run. Add a :# if you also wish
321           to designate multiple slots per test. 8:2 means 8 slots, but each
322           test gets 2 slots, so 4 tests run concurrently. Tests can find
323           their concurrency assignemnt in the "T2_HARNESS_MY_JOB_CONCURRENCY"
324           environment variable.
325
326           Can also be set with the following environment variables:
327           "YATH_JOB_COUNT", "T2_HARNESS_JOB_COUNT", "HARNESS_JOB_COUNT"
328
329       --lib
330       -l
331       --no-lib
332           (Default: include if it exists) Include 'lib' in your module path
333
334       --nytprof
335       --no-nytprof
336           Use Devel::NYTProf on tests. This will set addpid=1 for you. This
337           works with or without fork.
338
339       --post-exit-timeout SECONDS
340       --pet SECONDS
341       --no-post-exit-timeout
342           Stop waiting post-exit after the timeout period. (Default: 15
343           seconds) Some tests fork and allow the parent to exit before
344           writing all their output. If Test2::Harness detects an incomplete
345           plan after the test exits it will monitor for more events until the
346           timeout period. Add the "# HARNESS-NO-TIMEOUT" comment to the top
347           of a test file to disable timeouts on a per-test basis.
348
349       --preload-threshold ARG
350       --preload-threshold=ARG
351       --Pt ARG
352       --Pt=ARG
353       -W ARG
354       -W=ARG
355       --no-preload-threshold
356           Only do preload if at least N tests are going to be run. In some
357           cases a full preload takes longer than simply running the tests,
358           this lets you specify a minimum number of test jobs that will be
359           run for preload to happen. This has no effect for a persistent
360           runner. The default is 0, and it means always preload.
361
362       --preloads ARG
363       --preloads=ARG
364       --preload ARG
365       --preload=ARG
366       -P ARG
367       -P=ARG
368       --no-preloads
369           Preload a module before running tests
370
371           Can be specified multiple times
372
373       --resource Port
374       --resource +Test2::Harness::Runner::Resource::Port
375       -R Port
376       --no-resource
377           Use a resource module to assign resource assignments to individual
378           tests
379
380           Can be specified multiple times
381
382       --runner-id ARG
383       --runner-id=ARG
384       --no-runner-id
385           Runner ID (usually a generated uuid)
386
387       --shared-jobs-config .sharedjobslots.yml
388       --shared-jobs-config relative/path/.sharedjobslots.yml
389       --shared-jobs-config /absolute/path/.sharedjobslots.yml
390       --no-shared-jobs-config
391           Where to look for a shared slot config file. If a filename with no
392           path is provided yath will search the current and all parent
393           directories for the name.
394
395       --slots-per-job 2
396       -x2
397       --no-slots-per-job
398           This sets the number of slots each job will use (default 1). This
399           is normally set by the ':#' in '-j#:#'.
400
401           Can also be set with the following environment variables:
402           "T2_HARNESS_JOB_CONCURRENCY"
403
404       --switch ARG
405       --switch=ARG
406       -S ARG
407       -S=ARG
408       --no-switch
409           Pass the specified switch to perl for each test. This is not
410           compatible with preload.
411
412           Can be specified multiple times
413
414       --tlib
415       --no-tlib
416           (Default: off) Include 't/lib' in your module path
417
418       --unsafe-inc
419       --no-unsafe-inc
420           perl is removing '.' from @INC as a security concern. This option
421           keeps things from breaking for now.
422
423           Can also be set with the following environment variables:
424           "PERL_USE_UNSAFE_INC"
425
426       --use-fork
427       --fork
428       --no-use-fork
429           (default: on, except on windows) Normally tests are run by forking,
430           which allows for features like preloading. This will turn off the
431           behavior globally (which is not compatible with preloading). This
432           is slower, it is better to tag misbehaving tests with the '#
433           HARNESS-NO-PRELOAD' comment in their header to disable forking only
434           for those tests.
435
436           Can also be set with the following environment variables:
437           "!T2_NO_FORK", "T2_HARNESS_FORK", "!T2_HARNESS_NO_FORK",
438           "YATH_FORK", "!YATH_NO_FORK"
439
440       --use-timeout
441       --timeout
442       --no-use-timeout
443           (default: on) Enable/disable timeouts
444
445       Workspace Options
446
447       --clear
448       -C
449       --no-clear
450           Clear the work directory if it is not already empty
451
452       --tmp-dir ARG
453       --tmp-dir=ARG
454       --tmpdir ARG
455       --tmpdir=ARG
456       -t ARG
457       -t=ARG
458       --no-tmp-dir
459           Use a specific temp directory (Default: use system temp dir)
460
461           Can also be set with the following environment variables:
462           "T2_HARNESS_TEMP_DIR", "YATH_TEMP_DIR", "TMPDIR", "TEMPDIR",
463           "TMP_DIR", "TEMP_DIR"
464
465       --workdir ARG
466       --workdir=ARG
467       -w ARG
468       -w=ARG
469       --no-workdir
470           Set the work directory (Default: new temp directory)
471
472           Can also be set with the following environment variables:
473           "T2_WORKDIR", "YATH_WORKDIR"
474
475       YathUI Options
476
477       --yathui-api-key ARG
478       --yathui-api-key=ARG
479       --no-yathui-api-key
480           Yath-UI API key. This is not necessary if your Yath-UI instance is
481           set to single-user
482
483       --yathui-db
484       --no-yathui-db
485           Add the YathUI DB renderer in addition to other renderers
486
487       --yathui-grace
488       --no-yathui-grace
489           If yath cannot connect to yath-ui it normally throws an error, use
490           this to make it fail gracefully. You get a warning, but things keep
491           going.
492
493       --yathui-long-duration 10
494       --no-yathui-long-duration
495           Minimum duration length (seconds) before a test goes from MEDIUM to
496           LONG
497
498       --yathui-medium-duration 5
499       --no-yathui-medium-duration
500           Minimum duration length (seconds) before a test goes from SHORT to
501           MEDIUM
502
503       --yathui-mode summary
504       --yathui-mode qvf
505       --yathui-mode qvfd
506       --yathui-mode complete
507       --no-yathui-mode
508           Set the upload mode (default 'qvfd')
509
510       --yathui-only
511       --no-yathui-only
512           Only use the YathUI renderer
513
514       --yathui-only-db
515       --no-yathui-only-db
516           Only use the YathUI DB renderer
517
518       --yathui-port 8080
519       --no-yathui-port
520           Port to use when running a local server
521
522       --yathui-port-command get_port.sh
523       --yathui-port-command get_port.sh --pid $$
524       --no-yathui-port-command
525           Use a command to get a port number. "$$" will be replaced with the
526           PID of the yath process
527
528       --yathui-project ARG
529       --yathui-project=ARG
530       --no-yathui-project
531           The Yath-UI project for your test results
532
533       --yathui-render
534       --no-yathui-render
535           Add the YathUI renderer in addition to other renderers
536
537       --yathui-resources
538       --yathui-resources=5
539       --no-yathui-resources
540           Send resource info (for supported resources) to yathui at the
541           specified interval in seconds (5 if not specified)
542
543       --yathui-retry
544       --no-yathui-retry
545           How many times to try an operation before giving up
546
547           Can be specified multiple times
548
549       --yathui-schema PostgreSQL
550       --yathui-schema MySQL
551       --yathui-schema MySQL56
552       --no-yathui-schema
553           What type of DB/schema to use when using a temporary database
554
555       --yathui-url http://my-yath-ui.com/...
556       --uri http://my-yath-ui.com/...
557       --no-yathui-url
558           Yath-UI url
559
560       --yathui-user ARG
561       --yathui-user=ARG
562       --no-yathui-user
563           Username to attach to the data sent to the db
564
565       --yathui-db-buffering none
566       --yathui-db-buffering job
567       --yathui-db-buffering diag
568       --yathui-db-buffering run
569       --no-yathui-db-buffering
570           Type of buffering to use, if "none" then events are written to the
571           db one at a time, which is SLOW
572
573       --yathui-db-config ARG
574       --yathui-db-config=ARG
575       --no-yathui-db-config
576           Module that implements 'MODULE->yath_ui_config(%params)' which
577           should return a Test2::Harness::UI::Config instance.
578
579       --yathui-db-coverage
580       --no-yathui-db-coverage
581           Pull coverage data directly from the database (default: off)
582
583       --yathui-db-driver Pg
584       --yathui-db-drivermysql
585       --yathui-db-driverMariaDB
586       --no-yathui-db-driver
587           DBI Driver to use
588
589       --yathui-db-dsn ARG
590       --yathui-db-dsn=ARG
591       --no-yathui-db-dsn
592           DSN to use when connecting to the db
593
594       --yathui-db-duration-limit ARG
595       --yathui-db-duration-limit=ARG
596       --no-yathui-db-duration-limit
597           Limit the number of runs to look at for durations data (default:
598           10)
599
600       --yathui-db-durations
601       --no-yathui-db-durations
602           Pull duration data directly from the database (default: off)
603
604       --yathui-db-flush-interval 2
605       --yathui-db-flush-interval 1.5
606       --no-yathui-db-flush-interval
607           When buffering DB writes, force a flush when an event is recieved
608           at least N seconds after the last flush.
609
610       --yathui-db-host ARG
611       --yathui-db-host=ARG
612       --no-yathui-db-host
613           hostname to use when connecting to the db
614
615       --yathui-db-name ARG
616       --yathui-db-name=ARG
617       --no-yathui-db-name
618           Name of the database to use for yathui
619
620       --yathui-db-pass ARG
621       --yathui-db-pass=ARG
622       --no-yathui-db-pass
623           Password to use when connecting to the db
624
625       --yathui-db-port ARG
626       --yathui-db-port=ARG
627       --no-yathui-db-port
628           port to use when connecting to the db
629
630       --yathui-db-publisher ARG
631       --yathui-db-publisher=ARG
632       --no-yathui-db-publisher
633           When using coverage or duration data, only use data uploaded by
634           this user
635
636       --yathui-db-socket ARG
637       --yathui-db-socket=ARG
638       --no-yathui-db-socket
639           socket to use when connecting to the db
640
641       --yathui-db-user ARG
642       --yathui-db-user=ARG
643       --no-yathui-db-user
644           Username to use when connecting to the db
645

SOURCE

647       The source code repository for Test2-Harness can be found at
648       http://github.com/Test-More/Test2-Harness/.
649

MAINTAINERS

651       Chad Granum <exodist@cpan.org>
652

AUTHORS

654       Chad Granum <exodist@cpan.org>
655
657       Copyright 2023 Chad Granum <exodist7@gmail.com>.
658
659       This program is free software; you can redistribute it and/or modify it
660       under the same terms as Perl itself.
661
662       See http://dev.perl.org/licenses/
663
664
665
666perl v5.38.0                      2023-10-04      App::Yath::Command::start(3)
Impressum