-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME
114 lines (84 loc) · 4 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
NAME
Test2 - Framework for writing test tools that all work together.
EXPERIMENTAL RELEASE
This is an experimental release. Using this right now is not
recommended.
DESCRIPTION
Test2 is a new testing framework produced by forking Test::Builder,
completely refactoring it, adding many new features and capabilities.
GETTING STARTED
If you are interested in writing tests using new tools then you should
look at Test2::Suite.
If you are interested in writing new tools you should take a look at
Test2::API first.
NAMESPACE LAYOUT
Test2::Tools::
This namespace is for sets of tools. Modules in this namespace should
export tools like "ok()" and "is()". Most things written for Test2
should go here. Modules in this namespace MUST NOT export subs from
other tools. See the "Test2::Bundle::" namespace if you want to do that.
Test2::Plugin::
This namespace is for plugins. Plugins are modules that change or
enhance the behavior of Test2. An example of a plugin is a module that
sets the encoding to utf8 globally. Another example is a module that
causes a bail-out event after the first test failure.
Test2::Bundle::
This namespace is for bundles of tools and plugins. Loading one of these
may load multiple tools and plugins. Modules in this namespace should
not implement tools directly. In general modules in this namespace
should load tools and plugins, then re-export things into the consumers
namespace.
Test2::Require::
This namespace is for modules that cause a test to be skipped when
conditions do not allow it to run. Examples would be modules that skip
the test on older perls, or when non-essential modules have not been
installed.
Test2::Formatter::
Formatters live under this namespace. Test2::Formatter::TAP is the only
formatter currently. It is acceptible for third party distributions to
create new formatters under this namespace.
Test2::Event::
Events live under this namespace. It is considered acceptible for third
party distributions to add new event types in this namespace.
Test2::Hub::
Hub subclasses (and some hub utility objects) live under this namespace.
It is perfectly reasonable for third party distributions to add new hub
subclasses in this namespace.
Test2::IPC::
The IPC subsystem lives in this namespace. There are not many good
reasons to add anything to this namespace, with exception of IPC
drivers.
Test2::IPC::Driver::
IPC drivers live in this namespace. It is fine to create new IPC drivers
and to put them in this namespace.
Test2::Util::
This namespace is for general utilities used by testing tools. Please be
considerate when adding new modules to this namespace.
Test2::API::
This is for Test2 API and related packages.
Test2::
The Test2:: namespace is intended for extentions and frameworks. Tools,
Plugins, etc should not go directly into this namespace. However
extentions that are used to build tools and plugins may go here.
In short: If the module exports anything that should be run directly by
a test script it should probably NOT go directly into "Test2::XXX".
SEE ALSO
Test2::API - Primary API functions.
Test2::API::Context - Detailed documentation of the context object.
Test2::IPC - The IPC system used for threading/fork support.
Test2::Formatter - Formatters such as TAP live here.
Test2::Event - Events live in this namespace.
Test2::Hub - All events eventually funnel through a hub. Custom hubs are
how "intercept()" and "run_subtest()" are implemented.
SOURCE
The source code repository for Test2 can be found at
http://github.com/Test-More/Test2/.
MAINTAINERS
Chad Granum <exodist@cpan.org>
AUTHORS
Chad Granum <exodist@cpan.org>
COPYRIGHT
Copyright 2015 Chad Granum <exodist7@gmail.com>.
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/