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
|
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
|
-
-
-
-
-
-
+
+
+
+
+
+
+
+
-
-
+
+
+
-
-
+
+
-
-
+
+
-
+
+
-
+
+
-
-
+
+
-
+
+
+
+
+
+
-
-
-
+
+
+
+
+
+
+
+
-
+
+
+
-
+
-
-
-
-
+
+
+
-
+
-
-
+
+
+
+
+
+
+
+
+
|
----------------------------
Why Megatest?
-------------
The Megatest project was started for two reasons, the first was an
immediate and pressing need for a generalized tool to manage a suite
of regression tests and the second was the fact that the author had
written or maintained several such tools at different companies over
the years and it seemed a good thing to have a single open source
tool, flexible enough to meet the needs of any team doing continuous
integrating and or running a complex suite of tests for release
qualification.
of regression tests and the second was the fact that I had written or
maintained several such tools at different companies over the years. I
thought a single open source tool, flexible enough to meet the needs
of any team doing continuous integrating and or running a complex
suite of tests for release qualification would solve some problems for
me and for others.
-- Matt Welland, original author of the Megatest tool suite.
Megatest Design Philosophy
--------------------------
Megatest is a distributed system intended to provide the minimum needed
resources to make writing a suite of tests and tasks for implementing
continuous build for software, design engineering or process control (via
owlfs for example) without being specialized for any specific problem
space. Megatest in of itself does not know what constitutes a PASS or FAIL
of a test or task. In most cases megatest is best used in conjunction with
logpro or a similar tool to parse, analyze and decide on the test outcome.
* Self-checking -Repeatable strive for directed or self-checking test
as opposed to delta based tests
* Self-checking - make it as easy as possible to write self-checking
tests (as opposed to using deltas, i.e. tests that compare with a
previous measurement to deterine PASS/FAIL).
* Traceable - environment variables, host OS and other possibly influential
variables are captured and kept recorded.
* Traceable - environment variables, host OS and other possibly
influential variables are captured and kept recorded.
* Immutable - once this test is run it cannot be easily overwritten or
accidentally modified.
* Immutable - once a test is run it cannot be easily overwritten or
modified accidentally.
* Repeatable - this test result can be recreated in the future
* Repeatable - test results can be recreated in the future using all
the original variables.
* Relocatable - the testsuite or automation area can be checked out and the tests run anywhere
* Relocatable - the testsuite or automation area can be checked out
and the tests run anywhere in the disk hierarchy.
* Encapsulated - the tests run in self-contained directories and all inputs
and outputs to the process can be found in the run areas.
* Encapsulated - the tests run in self-contained directories and all
inputs and outputs to the process can be found in the run areas.
* Deployable - anyone on the team, at any site, at any time can run the flow
* Deployable - a testsuite is self-contained and can be bundled with
a software project and easily used by others with little to no
setup burden.
Megatest Architecture
---------------------
Data separation
~~~~~~~~~~~~~~~
All data to specify the tests and configure the system is stored in
plain text files. All system state is stored in an sqlite3
database. Tests are launched using the launching system available for
the distributed compute platform in use. A template script is provided
plain text config files. All system state is stored in an sqlite3
database.
Distributed Compute
~~~~~~~~~~~~~~~~~~~
Tests are launched using the launching system available for the
distributed compute platform in use. A template script is provided
which can launch jobs on local and remote Linux hosts. Currently
megatest uses the network filesystem to call home to your master
sqlite3 database.
sqlite3 database. Megatest has been used with the Intel Netbatch and
lsf (also known as openlava) batch systems and it should be
straightforward to use it with other similar systems.
include::plan.in[]
include::overview.txt[]
// to allow the getting_started.txt to be a stand-alone document use level
shifting, note that the preceding blank line is needed.
// :leveloffset: 2
include::installation.txt[]
include::getting_started.in[]
include::getting_started.txt[]
include::study_plan.txt[]
:leveloffset: 0
// :leveloffset: 0
include::writing_tests.txt[]
include::howto.in[]
include::reference.in[]
include::howto.txt[]
include::reference.txt[]
Megatest Internals
------------------
["graphviz", "server.png"]
----------------------------------------------------------------------
include::server.dot[]
----------------------------------------------------------------------
include::plan.txt[]
// to allow the getting_started.txt to be a stand-alone document use level
shifting, note that the preceding blank line is needed.
// :leveloffset: 2
// [appendix]
// Example Appendix
// ================
// One or more optional appendixes go here at section level zero.
//
|
150
151
152
153
154
155
156
157
158
159
160
161
162
|
173
174
175
176
177
178
179
180
181
182
183
184
185
|
-
-
+
+
|
//
// [colophon]
// Example Colophon
// ================
// Text at the end of a book describing facts about its production.
[index]
Example Index
-------------
Index
-----
////////////////////////////////////////////////////////////////
The index is normally left completely empty, it's contents are
generated automatically by the DocBook toolchain.
////////////////////////////////////////////////////////////////
|