This repository has been archived by the owner on Aug 4, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 47
/
README
346 lines (208 loc) · 9.58 KB
/
README
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
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
NAME
Test2::Suite - Distribution with a rich set of tools built upon the
Test2 framework.
DESCRIPTION
Rich set of tools, plugins, bundles, etc built upon the Test2 testing
library. If you are interested in writing tests, this is the
distribution for you.
WHAT ARE TOOLS, PLUGINS, AND BUNDLES?
TOOLS
Tools are packages that export functions for use in test files. These
functions typically generate events. Tools SHOULD NEVER alter
behavior of other tools, or the system in general.
PLUGINS
Plugins are packages that produce effects, or alter behavior of
tools. An example would be a plugin that causes the test to bail out
after the first failure. Plugins SHOULD NOT export anything.
BUNDLES
Bundles are collections of tools and plugins. A bundle should load
and re-export functions from Tool packages. A bundle may also load
and configure any number of plugins.
If you want to write something that both exports new functions, and
effects behavior, you should write both a Tools distribution, and a
Plugin distribution, then a Bundle that loads them both. This is
important as it helps avoid the problem where a package exports
much-desired tools, but also produces undesirable side effects.
INCLUDED BUNDLES
Test2::V#
These do not live in the bundle namespace as they are the primary
ways to use Test2::Suite.
The current latest is Test2::V0.
use Test2::V0;
# strict and warnings are on for you now.
ok(...);
# Note: is does deep checking, unlike the 'is' from Test::More.
is(...);
...
done_testing;
This bundle includes every tool listed in the "INCLUDED TOOLS"
section below, except for Test2::Tools::ClassicCompare. This bundle
provides most of what anyone writing tests could need. This is also
the preferred bundle/toolset of the Test2 author.
See Test2::V0 for complete documentation.
Extended
** Deprecated ** See Test2::V0
use Test2::Bundle::Extended;
# strict and warnings are on for you now.
ok(...);
# Note: is does deep checking, unlike the 'is' from Test::More.
is(...);
...
done_testing;
This bundle includes every tool listed in the "INCLUDED TOOLS"
section below, except for Test2::Tools::ClassicCompare. This bundle
provides most of what anyone writing tests could need. This is also
the preferred bundle/toolset of the Test2 author.
See Test2::Bundle::Extended for complete documentation.
More
use Test2::Bundle::More;
use strict;
use warnings;
plan 3; # Or you can use done_testing at the end
ok(...);
is(...); # Note: String compare
is_deeply(...);
...
done_testing; # Use instead of plan
This bundle is meant to be a mostly drop-in replacement for
Test::More. There are some notable differences to be aware of
however. Some exports are missing: eq_array, eq_hash, eq_set, $TODO,
explain, use_ok, require_ok. As well it is no longer possible to set
the plan at import: use .. tests => 5. $TODO has been replaced by the
todo() function. Planning is done using plan, skip_all, or
done_testing.
See Test2::Bundle::More for complete documentation.
Simple
use Test2::Bundle::Simple;
use strict;
use warnings;
plan 1;
ok(...);
This bundle is meant to be a mostly drop-in replacement for
Test::Simple. See Test2::Bundle::Simple for complete documentation.
INCLUDED TOOLS
Basic
Basic provides most of the essential tools previously found in
Test::More. However it does not export any tools used for comparison.
The basic pass, fail, ok functions are present, as are functions for
planning.
See Test2::Tools::Basic for complete documentation.
Compare
This provides is, like, isnt, unlike, and several additional helpers.
Note: These are all deep comparison tools and work like a combination
of Test::More's is and is_deeply.
See Test2::Tools::Compare for complete documentation.
ClassicCompare
This provides Test::More flavored is, like, isnt, unlike, and
is_deeply. It also provides cmp_ok.
See Test2::Tools::ClassicCompare for complete documentation.
Class
This provides functions for testing objects and classes, things like
isa_ok.
See Test2::Tools::Class for complete documentation.
Defer
This provides functions for writing test functions in one place, but
running them later. This is useful for testing things that run in an
altered state.
See Test2::Tools::Defer for complete documentation.
Encoding
This exports a single function that can be used to change the
encoding of all your test output.
See Test2::Tools::Encoding for complete documentation.
Exports
This provides tools for verifying exports. You can verify that
functions have been imported, or that they have not been imported.
See Test2::Tools::Exports for complete documentation.
Mock
This provides tools for mocking objects and classes. This is based
largely on Mock::Quick, but several interface improvements have been
added that cannot be added to Mock::Quick itself without breaking
backwards compatibility.
See Test2::Tools::Mock for complete documentation.
Ref
This exports tools for validating and comparing references.
See Test2::Tools::Ref for complete documentation.
Spec
This is an RSPEC implementation with concurrency support.
See Test2::Tools::Spec for more details.
Subtest
This exports tools for running subtests.
See Test2::Tools::Subtest for complete documentation.
Target
This lets you load the package(s) you intend to test, and alias them
into constants/package variables.
See Test2::Tools::Target for complete documentation.
INCLUDED PLUGINS
BailOnFail
The much requested "bail-out on first failure" plugin. When this
plugin is loaded, any failure will cause the test to bail out
immediately.
See Test2::Plugin::BailOnFail for complete documentation.
DieOnFail
The much requested "die on first failure" plugin. When this plugin is
loaded, any failure will cause the test to die immediately.
See Test2::Plugin::DieOnFail for complete documentation.
ExitSummary
This plugin gives you statistics and diagnostics at the end of your
test in the event of a failure.
See Test2::Plugin::ExitSummary for complete documentation.
SRand
Use this to set the random seed to a specific seed, or to the current
date.
See Test2::Plugin::SRand for complete documentation.
UTF8
Turn on utf8 for your testing. This sets the current file to be utf8,
it also sets STDERR, STDOUT, and your formatter to all output utf8.
See Test2::Plugin::UTF8 for complete documentation.
INCLUDED REQUIREMENT CHECKERS
AuthorTesting
Using this package will cause the test file to be skipped unless the
AUTHOR_TESTING environment variable is set.
See Test2::Require::AuthorTesting for complete documentation.
EnvVar
Using this package will cause the test file to be skipped unless a
custom environment variable is set.
See Test2::Require::EnvVar for complete documentation.
Fork
Using this package will cause the test file to be skipped unless the
system is capable of forking (including emulated forking).
See Test2::Require::Fork for complete documentation.
RealFork
Using this package will cause the test file to be skipped unless the
system is capable of true forking.
See Test2::Require::RealFork for complete documentation.
Module
Using this package will cause the test file to be skipped unless the
specified module is installed (and optionally at a minimum version).
See Test2::Require::Module for complete documentation.
Perl
Using this package will cause the test file to be skipped unless the
specified minimum perl version is met.
See Test2::Require::Perl for complete documentation.
Threads
Using this package will cause the test file to be skipped unless the
system has threading enabled.
Note: This will not turn threading on for you.
See Test2::Require::Threads for complete documentation.
SEE ALSO
See the Test2 documentation for a namespace map. Everything in this
distribution uses Test2.
Test2::Manual is the Test2 Manual.
CONTACTING US
Many Test2 developers and users lurk on irc://irc.perl.org/#perl. We
also have a slack team that can be joined by anyone with an @cpan.org
email address https://perl-test2.slack.com/ If you do not have an
@cpan.org email you can ask for a slack invite by emailing Chad Granum
SOURCE
The source code repository for Test2-Suite can be found at
https://github.com/Test-More/Test2-Suite/.
MAINTAINERS
Chad Granum <[email protected]>
AUTHORS
Chad Granum <[email protected]>
COPYRIGHT
Copyright 2018 Chad Granum <[email protected]>.
This program is free software; you can redistribute it and/or modify it
under the same terms as Perl itself.
See http://dev.perl.org/licenses/