1 | -- $Id: TestManagerDatabaseInit.pgsql 61407 2016-06-02 11:58:57Z vboxsync $
|
---|
2 | --- @file
|
---|
3 | -- VBox Test Manager Database Creation script.
|
---|
4 | --
|
---|
5 |
|
---|
6 | --
|
---|
7 | -- Copyright (C) 2012-2015 Oracle Corporation
|
---|
8 | --
|
---|
9 | -- This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
10 | -- available from http://www.virtualbox.org. This file is free software;
|
---|
11 | -- you can redistribute it and/or modify it under the terms of the GNU
|
---|
12 | -- General Public License (GPL) as published by the Free Software
|
---|
13 | -- Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
14 | -- VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
15 | -- hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
16 | --
|
---|
17 | -- The contents of this file may alternatively be used under the terms
|
---|
18 | -- of the Common Development and Distribution License Version 1.0
|
---|
19 | -- (CDDL) only, as it comes in the "COPYING.CDDL" file of the
|
---|
20 | -- VirtualBox OSE distribution, in which case the provisions of the
|
---|
21 | -- CDDL are applicable instead of those of the GPL.
|
---|
22 | --
|
---|
23 | -- You may elect to license modified versions of this file under the
|
---|
24 | -- terms and conditions of either the GPL or the CDDL or both.
|
---|
25 | --
|
---|
26 |
|
---|
27 | --
|
---|
28 | -- Declaimer:
|
---|
29 | --
|
---|
30 | -- The guys working on this design are not database experts, web
|
---|
31 | -- programming experts or similar, rather we are low level guys
|
---|
32 | -- who's main job is x86 & AMD64 virtualization. So, please don't
|
---|
33 | -- be too hard on us. :-)
|
---|
34 | --
|
---|
35 | --
|
---|
36 |
|
---|
37 |
|
---|
38 | -- D R O P D A T A B A S E t e s t m a n a g e r - - you do this now.
|
---|
39 | \set ON_ERROR_STOP 1
|
---|
40 | CREATE DATABASE testmanager;
|
---|
41 | \connect testmanager;
|
---|
42 |
|
---|
43 |
|
---|
44 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
45 | --
|
---|
46 | -- S y s t e m
|
---|
47 | --
|
---|
48 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
49 |
|
---|
50 | ---
|
---|
51 | -- Log table for a few important events.
|
---|
52 | --
|
---|
53 | -- Currently, two events are planned to be logged:
|
---|
54 | -- - Sign on of an unknown testbox, including the IP and System UUID.
|
---|
55 | -- This will be restricted to one entry per 24h or something like that:
|
---|
56 | -- SELECT COUNT(*)
|
---|
57 | -- FROM SystemLog
|
---|
58 | -- WHERE tsCreated >= (current_timestamp - interval '24 hours')
|
---|
59 | -- AND sEvent = 'TBoxUnkn'
|
---|
60 | -- AND sLogText = :sNewLogText;
|
---|
61 | -- - When cleaning up an abandond testcase (scenario #9), log which
|
---|
62 | -- testbox abandond which testset.
|
---|
63 | --
|
---|
64 | -- The Web UI will have some way of displaying the log.
|
---|
65 | --
|
---|
66 | -- A batch job should regularly clean out old log messages, like for instance
|
---|
67 | -- > 64 days.
|
---|
68 | --
|
---|
69 | CREATE TABLE SystemLog (
|
---|
70 | --- When this was logged.
|
---|
71 | tsCreated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
72 | --- The event type.
|
---|
73 | -- This is a 8 character string identifier so that we don't need to change
|
---|
74 | -- some enum type everytime we introduce a new event type.
|
---|
75 | sEvent CHAR(8) NOT NULL,
|
---|
76 | --- The log text.
|
---|
77 | sLogText text NOT NULL,
|
---|
78 |
|
---|
79 | PRIMARY KEY (tsCreated, sEvent)
|
---|
80 | );
|
---|
81 |
|
---|
82 |
|
---|
83 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
84 | --
|
---|
85 | -- C o n f i g u r a t i o n
|
---|
86 | --
|
---|
87 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
88 |
|
---|
89 | --- @table Users
|
---|
90 | -- Test manager users.
|
---|
91 | --
|
---|
92 | -- This is mainly for doing simple access checks before permitting access to
|
---|
93 | -- the test manager. This needs to be coordinated with
|
---|
94 | -- apache/ldap/Oracle-Single-Sign-On.
|
---|
95 | --
|
---|
96 | -- The main purpose, though, is for tracing who changed the test config and
|
---|
97 | -- analysis data.
|
---|
98 | --
|
---|
99 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
100 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
101 | -- current_timestamp.
|
---|
102 | --
|
---|
103 | CREATE SEQUENCE UserIdSeq
|
---|
104 | START 1
|
---|
105 | INCREMENT BY 1
|
---|
106 | NO MAXVALUE
|
---|
107 | NO MINVALUE
|
---|
108 | CACHE 1;
|
---|
109 | CREATE TABLE Users (
|
---|
110 | --- The user id.
|
---|
111 | uid INTEGER DEFAULT NEXTVAL('UserIdSeq') NOT NULL,
|
---|
112 | --- When this row starts taking effect (inclusive).
|
---|
113 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
114 | --- When this row stops being tsEffective (exclusive).
|
---|
115 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
116 | --- The user id of the one who created/modified this entry.
|
---|
117 | -- Non-unique foreign key: Users(uid)
|
---|
118 | uidAuthor INTEGER DEFAULT NULL,
|
---|
119 | --- User name.
|
---|
120 | sUsername text NOT NULL,
|
---|
121 | --- The email address of the user.
|
---|
122 | sEmail text NOT NULL,
|
---|
123 | --- The full name.
|
---|
124 | sFullName text NOT NULL,
|
---|
125 | --- The login name used by apache.
|
---|
126 | sLoginName text NOT NULL,
|
---|
127 |
|
---|
128 | PRIMARY KEY (uid, tsExpire)
|
---|
129 | );
|
---|
130 | CREATE INDEX UsersLoginNameIdx ON Users (sLoginName, tsExpire DESC);
|
---|
131 |
|
---|
132 |
|
---|
133 | --- @table GlobalResources
|
---|
134 | -- Global resource configuration.
|
---|
135 | --
|
---|
136 | -- For example an iSCSI target.
|
---|
137 | --
|
---|
138 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
139 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
140 | -- current_timestamp.
|
---|
141 | --
|
---|
142 | CREATE SEQUENCE GlobalResourceIdSeq
|
---|
143 | START 1
|
---|
144 | INCREMENT BY 1
|
---|
145 | NO MAXVALUE
|
---|
146 | NO MINVALUE
|
---|
147 | CACHE 1;
|
---|
148 | CREATE TABLE GlobalResources (
|
---|
149 | --- The global resource ID.
|
---|
150 | -- This stays the same thru updates.
|
---|
151 | idGlobalRsrc INTEGER DEFAULT NEXTVAL('GlobalResourceIdSeq') NOT NULL,
|
---|
152 | --- When this row starts taking effect (inclusive).
|
---|
153 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
154 | --- When this row stops being tsEffective (exclusive).
|
---|
155 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
156 | --- The user id of the one who created/modified this entry.
|
---|
157 | -- Non-unique foreign key: Users(uid)
|
---|
158 | uidAuthor INTEGER NOT NULL,
|
---|
159 | --- The name of the resource.
|
---|
160 | sName text NOT NULL,
|
---|
161 | --- Optional resource description.
|
---|
162 | sDescription text,
|
---|
163 | --- Indicates whether this resource is currently enabled (online).
|
---|
164 | fEnabled boolean DEFAULT FALSE NOT NULL,
|
---|
165 |
|
---|
166 | PRIMARY KEY (idGlobalRsrc, tsExpire)
|
---|
167 | );
|
---|
168 |
|
---|
169 |
|
---|
170 | --- @table BuildSources
|
---|
171 | -- Build sources.
|
---|
172 | --
|
---|
173 | -- This is used by a scheduling group to select builds and the default
|
---|
174 | -- Validation Kit from the Builds table.
|
---|
175 | --
|
---|
176 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
177 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
178 | -- current_timestamp.
|
---|
179 | --
|
---|
180 | -- @todo Any better way of representing this so we could more easily
|
---|
181 | -- join/whatever when searching for builds?
|
---|
182 | --
|
---|
183 | CREATE SEQUENCE BuildSourceIdSeq
|
---|
184 | START 1
|
---|
185 | INCREMENT BY 1
|
---|
186 | NO MAXVALUE
|
---|
187 | NO MINVALUE
|
---|
188 | CACHE 1;
|
---|
189 | CREATE TABLE BuildSources (
|
---|
190 | --- The build source identifier.
|
---|
191 | -- This stays constant over time.
|
---|
192 | idBuildSrc INTEGER DEFAULT NEXTVAL('BuildSourceIdSeq') NOT NULL,
|
---|
193 | --- When this row starts taking effect (inclusive).
|
---|
194 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
195 | --- When this row stops being tsEffective (exclusive).
|
---|
196 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
197 | --- The user id of the one who created/modified this entry.
|
---|
198 | -- Non-unique foreign key: Users(uid)
|
---|
199 | uidAuthor INTEGER NOT NULL,
|
---|
200 |
|
---|
201 | --- The name of the build source.
|
---|
202 | sName TEXT NOT NULL,
|
---|
203 | --- Description.
|
---|
204 | sDescription TEXT DEFAULT NULL,
|
---|
205 |
|
---|
206 | --- Which product.
|
---|
207 | -- ASSUME that it is okay to limit a build source to a single product.
|
---|
208 | sProduct text NOT NULL,
|
---|
209 | --- Which branch.
|
---|
210 | -- ASSUME that it is okay to limit a build source to a branch.
|
---|
211 | sBranch text NOT NULL,
|
---|
212 |
|
---|
213 | --- Build types to include, all matches if NULL.
|
---|
214 | -- @todo Weighting the types would be nice in a later version.
|
---|
215 | asTypes text ARRAY DEFAULT NULL,
|
---|
216 | --- Array of the 'sOs.sCpuArch' to match, all matches if NULL.
|
---|
217 | -- See KBUILD_OSES in kBuild for a list of standard target OSes, and
|
---|
218 | -- KBUILD_ARCHES for a list of standard architectures.
|
---|
219 | --
|
---|
220 | -- @remarks See marks on 'os-agnostic' and 'noarch' in BuildCategories.
|
---|
221 | asOsArches text ARRAY DEFAULT NULL,
|
---|
222 |
|
---|
223 | --- The first subversion tree revision to match, no lower limit if NULL.
|
---|
224 | iFirstRevision INTEGER DEFAULT NULL,
|
---|
225 | --- The last subversion tree revision to match, no upper limit if NULL.
|
---|
226 | iLastRevision INTEGER DEFAULT NULL,
|
---|
227 |
|
---|
228 | --- The maximum age of the builds in seconds, unlimited if NULL.
|
---|
229 | cSecMaxAge INTEGER DEFAULT NULL,
|
---|
230 |
|
---|
231 | PRIMARY KEY (idBuildSrc, tsExpire)
|
---|
232 | );
|
---|
233 |
|
---|
234 |
|
---|
235 | --- @table TestCases
|
---|
236 | -- Test case configuration.
|
---|
237 | --
|
---|
238 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
239 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
240 | -- current_timestamp.
|
---|
241 | --
|
---|
242 | CREATE SEQUENCE TestCaseIdSeq
|
---|
243 | START 1
|
---|
244 | INCREMENT BY 1
|
---|
245 | NO MAXVALUE
|
---|
246 | NO MINVALUE
|
---|
247 | CACHE 1;
|
---|
248 | CREATE SEQUENCE TestCaseGenIdSeq
|
---|
249 | START 1
|
---|
250 | INCREMENT BY 1
|
---|
251 | NO MAXVALUE
|
---|
252 | NO MINVALUE
|
---|
253 | CACHE 1;
|
---|
254 | CREATE TABLE TestCases (
|
---|
255 | --- The fixed test case ID.
|
---|
256 | -- This is assigned when the test case is created and will never change.
|
---|
257 | idTestCase INTEGER DEFAULT NEXTVAL('TestCaseIdSeq') NOT NULL,
|
---|
258 | --- When this row starts taking effect (inclusive).
|
---|
259 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
260 | --- When this row stops being tsEffective (exclusive).
|
---|
261 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
262 | --- The user id of the one who created/modified this entry.
|
---|
263 | -- Non-unique foreign key: Users(uid)
|
---|
264 | uidAuthor INTEGER NOT NULL,
|
---|
265 | --- Generation ID for this row, a truly unique identifier.
|
---|
266 | -- This is primarily for referencing by TestSets.
|
---|
267 | idGenTestCase INTEGER UNIQUE DEFAULT NEXTVAL('TestCaseGenIdSeq') NOT NULL,
|
---|
268 |
|
---|
269 | --- The name of the test case.
|
---|
270 | sName TEXT NOT NULL,
|
---|
271 | --- Optional test case description.
|
---|
272 | sDescription TEXT DEFAULT NULL,
|
---|
273 | --- Indicates whether this test case is currently enabled.
|
---|
274 | fEnabled BOOLEAN DEFAULT FALSE NOT NULL,
|
---|
275 | --- Default test case timeout given in seconds.
|
---|
276 | cSecTimeout INTEGER NOT NULL CHECK (cSecTimeout > 0),
|
---|
277 | --- Default TestBox requirement expression (python boolean expression).
|
---|
278 | -- All the scheduler properties are available for use with the same names
|
---|
279 | -- as in that table.
|
---|
280 | -- If NULL everything matches.
|
---|
281 | sTestBoxReqExpr TEXT DEFAULT NULL,
|
---|
282 | --- Default build requirement expression (python boolean expression).
|
---|
283 | -- The following build properties are available: sProduct, sBranch,
|
---|
284 | -- sType, asOsArches, sVersion, iRevision, uidAuthor and idBuild.
|
---|
285 | -- If NULL everything matches.
|
---|
286 | sBuildReqExpr TEXT DEFAULT NULL,
|
---|
287 |
|
---|
288 | --- The base command.
|
---|
289 | -- String suitable for executing in bourne shell with space as separator
|
---|
290 | -- (IFS). References to @BUILD_BINARIES@ will be replaced WITH the content
|
---|
291 | -- of the Builds(sBinaries) field.
|
---|
292 | sBaseCmd TEXT NOT NULL,
|
---|
293 |
|
---|
294 | --- Comma separated list of test suite zips (or tars) that the testbox will
|
---|
295 | -- need to download and expand prior to testing.
|
---|
296 | -- If NULL the current test suite of the scheduling group will be used (the
|
---|
297 | -- scheduling group will have an optional test suite build queue associated
|
---|
298 | -- with it). The current test suite can also be referenced by
|
---|
299 | -- @VALIDATIONKIT_ZIP@ in case more downloads are required. Files may also be
|
---|
300 | -- uploaded to the test manager download area, in which case the
|
---|
301 | -- @DOWNLOAD_BASE_URL@ prefix can be used to refer to this area.
|
---|
302 | sTestSuiteZips TEXT DEFAULT NULL,
|
---|
303 |
|
---|
304 | PRIMARY KEY (idTestCase, tsExpire)
|
---|
305 | );
|
---|
306 |
|
---|
307 |
|
---|
308 | --- @table TestCaseArgs
|
---|
309 | -- Test case argument list variations.
|
---|
310 | --
|
---|
311 | -- For example, we have a test case that does a set of tests on a virtual
|
---|
312 | -- machine. To get better code/feature coverage of this testcase we wish to
|
---|
313 | -- run it with different guest hardware configuration. The test case may do
|
---|
314 | -- the same stuff, but the guest OS as well as the VMM may react differently to
|
---|
315 | -- the hardware configurations and uncover issues in the VMM, device emulation
|
---|
316 | -- or other places.
|
---|
317 | --
|
---|
318 | -- Typical hardware variations are:
|
---|
319 | -- - guest memory size (RAM),
|
---|
320 | -- - guest video memory size (VRAM),
|
---|
321 | -- - virtual CPUs / cores / threads,
|
---|
322 | -- - virtual chipset
|
---|
323 | -- - virtual network interface card (NIC)
|
---|
324 | -- - USB 1.1, USB 2.0, no USB
|
---|
325 | --
|
---|
326 | -- The TM web UI will help the user create a reasonable set of permutations
|
---|
327 | -- of these parameters, the user specifies a maximum and the TM uses certain
|
---|
328 | -- rules together with random selection to generate the desired number. The
|
---|
329 | -- UI will also help suggest fitting testbox requirements according to the
|
---|
330 | -- RAM/VRAM sizes and the virtual CPU counts. The user may then make
|
---|
331 | -- adjustments to the suggestions before commit them.
|
---|
332 | --
|
---|
333 | -- Alternatively, the user may also enter all the permutations without any
|
---|
334 | -- help from the UI.
|
---|
335 | --
|
---|
336 | -- Note! All test cases has at least one entry in this table, even if it is
|
---|
337 | -- empty, because testbox requirements are specified thru this.
|
---|
338 | --
|
---|
339 | -- Querying the valid parameter lists for a testase this way:
|
---|
340 | -- SELECT * ... WHERE idTestCase = TestCases.idTestCase
|
---|
341 | -- AND tsExpire > <when>
|
---|
342 | -- AND tsEffective <= <when>;
|
---|
343 | --
|
---|
344 | -- Querying the valid parameter list for the latest generation can be
|
---|
345 | -- simplified by just checking tsExpire date:
|
---|
346 | -- SELECT * ... WHERE idTestCase = TestCases.idTestCase
|
---|
347 | -- AND tsExpire == TIMESTAMP WITH TIME ZONE 'infinity';
|
---|
348 | --
|
---|
349 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
350 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
351 | -- current_timestamp.
|
---|
352 | --
|
---|
353 | CREATE SEQUENCE TestCaseArgsIdSeq
|
---|
354 | START 1
|
---|
355 | INCREMENT BY 1
|
---|
356 | NO MAXVALUE
|
---|
357 | NO MINVALUE
|
---|
358 | CACHE 1;
|
---|
359 | CREATE SEQUENCE TestCaseArgsGenIdSeq
|
---|
360 | START 1
|
---|
361 | INCREMENT BY 1
|
---|
362 | NO MAXVALUE
|
---|
363 | NO MINVALUE
|
---|
364 | CACHE 1;
|
---|
365 | CREATE TABLE TestCaseArgs (
|
---|
366 | --- The test case ID.
|
---|
367 | -- Non-unique foreign key: TestCases(idTestCase).
|
---|
368 | idTestCase INTEGER NOT NULL,
|
---|
369 | --- The testcase argument variation ID (fixed).
|
---|
370 | -- This is primarily for TestGroupMembers.aidTestCaseArgs.
|
---|
371 | idTestCaseArgs INTEGER DEFAULT NEXTVAL('TestCaseArgsIdSeq') NOT NULL,
|
---|
372 | --- When this row starts taking effect (inclusive).
|
---|
373 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
374 | --- When this row stops being tsEffective (exclusive).
|
---|
375 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
376 | --- The user id of the one who created/modified this entry.
|
---|
377 | -- Non-unique foreign key: Users(uid)
|
---|
378 | uidAuthor INTEGER NOT NULL,
|
---|
379 | --- Generation ID for this row.
|
---|
380 | -- This is primarily for efficient referencing by TestSets and SchedQueues.
|
---|
381 | idGenTestCaseArgs INTEGER UNIQUE DEFAULT NEXTVAL('TestCaseArgsGenIdSeq') NOT NULL,
|
---|
382 |
|
---|
383 | --- The additional arguments.
|
---|
384 | -- String suitable for bourne shell style argument parsing with space as
|
---|
385 | -- separator (IFS). References to @BUILD_BINARIES@ will be replaced with
|
---|
386 | -- the content of the Builds(sBinaries) field.
|
---|
387 | sArgs TEXT NOT NULL,
|
---|
388 | --- Optional test case timeout given in seconds.
|
---|
389 | -- If NULL, the TestCases.cSecTimeout field is used instead.
|
---|
390 | cSecTimeout INTEGER DEFAULT NULL CHECK (cSecTimeout IS NULL OR cSecTimeout > 0),
|
---|
391 | --- Additional TestBox requirement expression (python boolean expression).
|
---|
392 | -- All the scheduler properties are available for use with the same names
|
---|
393 | -- as in that table. This is checked after first checking the requirements
|
---|
394 | -- in the TestCases.sTestBoxReqExpr field.
|
---|
395 | sTestBoxReqExpr TEXT DEFAULT NULL,
|
---|
396 | --- Additional build requirement expression (python boolean expression).
|
---|
397 | -- The following build properties are available: sProduct, sBranch,
|
---|
398 | -- sType, asOsArches, sVersion, iRevision, uidAuthor and idBuild. This is
|
---|
399 | -- checked after first checking the requirements in the
|
---|
400 | -- TestCases.sBuildReqExpr field.
|
---|
401 | sBuildReqExpr TEXT DEFAULT NULL,
|
---|
402 | --- Number of testboxes required (gang scheduling).
|
---|
403 | cGangMembers SMALLINT DEFAULT 1 NOT NULL CHECK (cGangMembers > 0 AND cGangMembers < 1024),
|
---|
404 | --- Optional variation sub-name.
|
---|
405 | sSubName TEXT DEFAULT NULL,
|
---|
406 |
|
---|
407 | --- The arguments are part of the primary key for several reasons.
|
---|
408 | -- No duplicate argument lists (makes no sense - if you want to prioritize
|
---|
409 | -- argument lists, we add that explicitly). This may hopefully enable us
|
---|
410 | -- to more easily check coverage later on, even when the test case is
|
---|
411 | -- reconfigured with more/less permutations.
|
---|
412 | PRIMARY KEY (idTestCase, tsExpire, sArgs)
|
---|
413 | );
|
---|
414 | CREATE INDEX TestCaseArgsLookupIdx ON TestCaseArgs (idTestCase, tsExpire DESC, tsEffective ASC);
|
---|
415 |
|
---|
416 |
|
---|
417 | --- @table TestCaseDeps
|
---|
418 | -- Test case dependencies (N:M)
|
---|
419 | --
|
---|
420 | -- This effect build selection. The build must have passed all runs of the
|
---|
421 | -- given prerequisite testcase (idTestCasePreReq) and executed at a minimum one
|
---|
422 | -- argument list variation.
|
---|
423 | --
|
---|
424 | -- This should also affect scheduling order, if possible at least one
|
---|
425 | -- prerequisite testcase variation should be place before the specific testcase
|
---|
426 | -- in the scheduling queue.
|
---|
427 | --
|
---|
428 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
429 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
430 | -- current_timestamp. To select the currently valid entries use
|
---|
431 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
432 | --
|
---|
433 | CREATE TABLE TestCaseDeps (
|
---|
434 | --- The test case that depends on someone.
|
---|
435 | -- Non-unique foreign key: TestCases(idTestCase).
|
---|
436 | idTestCase INTEGER NOT NULL,
|
---|
437 | --- The prerequisite test case ID.
|
---|
438 | -- Non-unique foreign key: TestCases(idTestCase).
|
---|
439 | idTestCasePreReq INTEGER NOT NULL,
|
---|
440 | --- When this row starts taking effect (inclusive).
|
---|
441 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
442 | --- When this row stops being tsEffective (exclusive).
|
---|
443 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
444 | --- The user id of the one who created/modified this entry.
|
---|
445 | -- Non-unique foreign key: Users(uid)
|
---|
446 | uidAuthor INTEGER NOT NULL,
|
---|
447 |
|
---|
448 | PRIMARY KEY (idTestCase, idTestCasePreReq, tsExpire)
|
---|
449 | );
|
---|
450 |
|
---|
451 |
|
---|
452 | --- @table TestCaseGlobalRsrcDeps
|
---|
453 | -- Test case dependencies on global resources (N:M)
|
---|
454 | --
|
---|
455 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
456 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
457 | -- current_timestamp. To select the currently valid entries use
|
---|
458 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
459 | --
|
---|
460 | CREATE TABLE TestCaseGlobalRsrcDeps (
|
---|
461 | --- The test case that depends on someone.
|
---|
462 | -- Non-unique foreign key: TestCases(idTestCase).
|
---|
463 | idTestCase INTEGER NOT NULL,
|
---|
464 | --- The prerequisite resource ID.
|
---|
465 | -- Non-unique foreign key: GlobalResources(idGlobalRsrc).
|
---|
466 | idGlobalRsrc INTEGER NOT NULL,
|
---|
467 | --- When this row starts taking effect (inclusive).
|
---|
468 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
469 | --- When this row stops being tsEffective (exclusive).
|
---|
470 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
471 | --- The user id of the one who created/modified this entry.
|
---|
472 | -- Non-unique foreign key: Users(uid)
|
---|
473 | uidAuthor INTEGER NOT NULL,
|
---|
474 |
|
---|
475 | PRIMARY KEY (idTestCase, idGlobalRsrc, tsExpire)
|
---|
476 | );
|
---|
477 |
|
---|
478 |
|
---|
479 | --- @table TestGroups
|
---|
480 | -- Test Group - A collection of test cases.
|
---|
481 | --
|
---|
482 | -- This is for simplifying test configuration by working with a few groups
|
---|
483 | -- instead of a herd of individual testcases. It may also be used for creating
|
---|
484 | -- test suites for certain areas (like guest additions) or tasks (like
|
---|
485 | -- performance measurements).
|
---|
486 | --
|
---|
487 | -- A test case can be member of any number of test groups.
|
---|
488 | --
|
---|
489 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
490 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
491 | -- current_timestamp. To select the currently valid entries use
|
---|
492 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
493 | --
|
---|
494 | CREATE SEQUENCE TestGroupIdSeq
|
---|
495 | START 1
|
---|
496 | INCREMENT BY 1
|
---|
497 | NO MAXVALUE
|
---|
498 | NO MINVALUE
|
---|
499 | CACHE 1;
|
---|
500 | CREATE TABLE TestGroups (
|
---|
501 | --- The fixed scheduling group ID.
|
---|
502 | -- This is assigned when the group is created and will never change.
|
---|
503 | idTestGroup INTEGER DEFAULT NEXTVAL('TestGroupIdSeq') NOT NULL,
|
---|
504 | --- When this row starts taking effect (inclusive).
|
---|
505 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
506 | --- When this row stops being tsEffective (exclusive).
|
---|
507 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
508 | --- The user id of the one who created/modified this entry.
|
---|
509 | -- Non-unique foreign key: Users(uid)
|
---|
510 | uidAuthor INTEGER NOT NULL,
|
---|
511 |
|
---|
512 | --- The name of the scheduling group.
|
---|
513 | sName text NOT NULL,
|
---|
514 | --- Optional group description.
|
---|
515 | sDescription text,
|
---|
516 |
|
---|
517 | PRIMARY KEY (idTestGroup, tsExpire)
|
---|
518 | );
|
---|
519 | CREATE INDEX TestGroups_id_index ON TestGroups (idTestGroup, tsExpire DESC, tsEffective ASC);
|
---|
520 |
|
---|
521 |
|
---|
522 | --- @table TestGroupMembers
|
---|
523 | -- The N:M relation ship between test case configurations and test groups.
|
---|
524 | --
|
---|
525 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
526 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
527 | -- current_timestamp. To select the currently valid entries use
|
---|
528 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
529 | --
|
---|
530 | CREATE TABLE TestGroupMembers (
|
---|
531 | --- The group ID.
|
---|
532 | -- Non-unique foreign key: TestGroups(idTestGroup).
|
---|
533 | idTestGroup INTEGER NOT NULL,
|
---|
534 | --- The test case ID.
|
---|
535 | -- Non-unique foreign key: TestCases(idTestCase).
|
---|
536 | idTestCase INTEGER NOT NULL,
|
---|
537 | --- When this row starts taking effect (inclusive).
|
---|
538 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
539 | --- When this row stops being tsEffective (exclusive).
|
---|
540 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
541 | --- The user id of the one who created/modified this entry.
|
---|
542 | -- Non-unique foreign key: Users(uid)
|
---|
543 | uidAuthor INTEGER NOT NULL,
|
---|
544 |
|
---|
545 | --- Test case scheduling priority.
|
---|
546 | -- Higher number causes the test case to be run more frequently.
|
---|
547 | -- @sa SchedGroupMembers.iSchedPriority
|
---|
548 | -- @todo Not sure we want to keep this...
|
---|
549 | iSchedPriority INTEGER DEFAULT 16 CHECK (iSchedPriority >= 0 AND iSchedPriority < 32) NOT NULL,
|
---|
550 |
|
---|
551 | --- Limit the memberships to the given argument variations.
|
---|
552 | -- Non-unique foreign key: TestCaseArgs(idTestCase, idTestCaseArgs).
|
---|
553 | aidTestCaseArgs INTEGER ARRAY DEFAULT NULL,
|
---|
554 |
|
---|
555 | PRIMARY KEY (idTestGroup, idTestCase, tsExpire)
|
---|
556 | );
|
---|
557 |
|
---|
558 |
|
---|
559 | --- @table SchedGroups
|
---|
560 | -- Scheduling group (aka. testbox partitioning) configuration.
|
---|
561 | --
|
---|
562 | -- A testbox is associated with exactly one scheduling group. This association
|
---|
563 | -- can be changed, of course. If we (want to) retire a group which still has
|
---|
564 | -- testboxes associated with it, these will be moved to the 'default' group.
|
---|
565 | --
|
---|
566 | -- The TM web UI will make sure that a testbox is always in a group and that
|
---|
567 | -- the default group cannot be deleted.
|
---|
568 | --
|
---|
569 | -- A scheduling group combines several things:
|
---|
570 | -- - A selection of builds to test (via idBuildSrc).
|
---|
571 | -- - A collection of test groups to test with (via SchedGroupMembers).
|
---|
572 | -- - A set of testboxes to test on (via TestBoxes.idSchedGroup).
|
---|
573 | --
|
---|
574 | -- In additions there is an optional source of fresh test suite builds (think
|
---|
575 | -- VBoxTestSuite) as well as scheduling options.
|
---|
576 | --
|
---|
577 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
578 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
579 | -- current_timestamp. To select the currently valid entries use
|
---|
580 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
581 | --
|
---|
582 | CREATE TYPE Scheduler_T AS ENUM (
|
---|
583 | 'bestEffortContinousItegration',
|
---|
584 | 'reserved'
|
---|
585 | );
|
---|
586 | CREATE SEQUENCE SchedGroupIdSeq
|
---|
587 | START 2
|
---|
588 | INCREMENT BY 1
|
---|
589 | NO MAXVALUE
|
---|
590 | NO MINVALUE
|
---|
591 | CACHE 1;
|
---|
592 | CREATE TABLE SchedGroups (
|
---|
593 | --- The fixed scheduling group ID.
|
---|
594 | -- This is assigned when the group is created and will never change.
|
---|
595 | idSchedGroup INTEGER DEFAULT NEXTVAL('SchedGroupIdSeq') NOT NULL,
|
---|
596 | --- When this row starts taking effect (inclusive).
|
---|
597 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
598 | --- When this row stops being tsEffective (exclusive).
|
---|
599 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
600 | --- The user id of the one who created/modified this entry.
|
---|
601 | -- Non-unique foreign key: Users(uid)
|
---|
602 | -- @note This is NULL for the default group.
|
---|
603 | uidAuthor INTEGER DEFAULT NULL,
|
---|
604 |
|
---|
605 | --- The name of the scheduling group.
|
---|
606 | sName text NOT NULL,
|
---|
607 | --- Optional group description.
|
---|
608 | sDescription text,
|
---|
609 | --- Indicates whether this group is currently enabled.
|
---|
610 | fEnabled boolean NOT NULL,
|
---|
611 | --- The scheduler to use.
|
---|
612 | -- This is for when we later desire different scheduling that the best
|
---|
613 | -- effort stuff provided by the initial implementation.
|
---|
614 | enmScheduler Scheduler_T DEFAULT 'bestEffortContinousItegration'::Scheduler_T NOT NULL,
|
---|
615 | --- The build source.
|
---|
616 | -- Non-unique foreign key: BuildSources(idBuildSrc)
|
---|
617 | idBuildSrc INTEGER DEFAULT NULL,
|
---|
618 | --- The Validation Kit build source (@VALIDATIONKIT_ZIP@).
|
---|
619 | -- Non-unique foreign key: BuildSources(idBuildSrc)
|
---|
620 | idBuildSrcTestSuite INTEGER DEFAULT NULL,
|
---|
621 |
|
---|
622 | PRIMARY KEY (idSchedGroup, tsExpire)
|
---|
623 | );
|
---|
624 |
|
---|
625 | -- Special default group.
|
---|
626 | INSERT INTO SchedGroups (idSchedGroup, tsEffective, tsExpire, sName, sDescription, fEnabled)
|
---|
627 | VALUES (1, TIMESTAMP WITH TIME ZONE 'epoch', TIMESTAMP WITH TIME ZONE 'infinity', 'default', 'default group', FALSE);
|
---|
628 |
|
---|
629 |
|
---|
630 | --- @table SchedGroupMembers
|
---|
631 | -- N:M relationship between scheduling groups and test groups.
|
---|
632 | --
|
---|
633 | -- Several scheduling parameters are associated with this relationship.
|
---|
634 | --
|
---|
635 | -- The test group dependency (idTestGroupPreReq) can be used in the same way as
|
---|
636 | -- TestCaseDeps.idTestCasePreReq, only here on test group level. This means it
|
---|
637 | -- affects the build selection. The builds needs to have passed all test runs
|
---|
638 | -- the prerequisite test group and done at least one argument variation of each
|
---|
639 | -- test case in it.
|
---|
640 | --
|
---|
641 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
642 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
643 | -- current_timestamp. To select the currently valid entries use
|
---|
644 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
645 | --
|
---|
646 | CREATE TABLE SchedGroupMembers (
|
---|
647 | --- Scheduling ID.
|
---|
648 | -- Non-unique foreign key: SchedGroups(idSchedGroup).
|
---|
649 | idSchedGroup INTEGER NOT NULL,
|
---|
650 | --- Testgroup ID.
|
---|
651 | -- Non-unique foreign key: TestGroups(idTestGroup).
|
---|
652 | idTestGroup INTEGER NOT NULL,
|
---|
653 | --- When this row starts taking effect (inclusive).
|
---|
654 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
655 | --- When this row stops being tsEffective (exclusive).
|
---|
656 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
657 | --- The user id of the one who created/modified this entry.
|
---|
658 | -- Non-unique foreign key: Users(uid)
|
---|
659 | uidAuthor INTEGER NOT NULL,
|
---|
660 |
|
---|
661 | --- The scheduling priority if the test group.
|
---|
662 | -- Higher number causes the test case to be run more frequently.
|
---|
663 | -- @sa TestGroupMembers.iSchedPriority
|
---|
664 | iSchedPriority INTEGER DEFAULT 16 CHECK (iSchedPriority >= 0 AND iSchedPriority < 32) NOT NULL,
|
---|
665 | --- When during the week this group is allowed to start running, NULL means
|
---|
666 | -- there are no constraints.
|
---|
667 | -- Each bit in the bitstring represents one hour, with bit 0 indicating the
|
---|
668 | -- midnight hour on a monday.
|
---|
669 | bmHourlySchedule bit(168) DEFAULT NULL,
|
---|
670 | --- Optional test group dependency.
|
---|
671 | -- Non-unique foreign key: TestGroups(idTestGroup).
|
---|
672 | -- This is for requiring that a build has been subject to smoke tests
|
---|
673 | -- before bothering to subject it to longer tests.
|
---|
674 | -- @todo Not entirely sure this should be here, but I'm not so keen on yet
|
---|
675 | -- another table as the only use case is smoketests.
|
---|
676 | idTestGroupPreReq INTEGER DEFAULT NULL,
|
---|
677 |
|
---|
678 | PRIMARY KEY (idSchedGroup, idTestGroup, tsExpire)
|
---|
679 | );
|
---|
680 |
|
---|
681 |
|
---|
682 | --- @type TestBoxCmd_T
|
---|
683 | -- Testbox commands.
|
---|
684 | CREATE TYPE TestBoxCmd_T AS ENUM (
|
---|
685 | 'none',
|
---|
686 | 'abort',
|
---|
687 | 'reboot', --< This implies abort. Status changes when reaching 'idle'.
|
---|
688 | 'upgrade', --< This is only handled when asking for work.
|
---|
689 | 'upgrade-and-reboot', --< Ditto.
|
---|
690 | 'special' --< Similar to upgrade, reserved for the future.
|
---|
691 | );
|
---|
692 |
|
---|
693 |
|
---|
694 | --- @type LomKind_T
|
---|
695 | -- The kind of lights out management on a testbox.
|
---|
696 | CREATE TYPE LomKind_T AS ENUM (
|
---|
697 | 'none',
|
---|
698 | 'ilom',
|
---|
699 | 'elom',
|
---|
700 | 'apple-xserve-lom'
|
---|
701 | );
|
---|
702 |
|
---|
703 |
|
---|
704 | --- @table TestBoxes
|
---|
705 | -- Testbox configurations.
|
---|
706 | --
|
---|
707 | -- The testboxes are identified by IP and the system UUID if available. Should
|
---|
708 | -- the IP change, the testbox will be refused at sign on and the testbox
|
---|
709 | -- sheriff will have to update it's IP.
|
---|
710 | --
|
---|
711 | -- @todo Implement the UUID stuff. Get it from DMI, UEFI or whereever.
|
---|
712 | -- Mismatching needs to be logged somewhere...
|
---|
713 | --
|
---|
714 | -- To query the currently valid configuration:
|
---|
715 | -- SELECT ... WHERE id = idTestBox AND tsExpire = TIMESTAMP WITH TIME ZONE 'infinity';
|
---|
716 | --
|
---|
717 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
718 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
719 | -- current_timestamp. To select the currently valid entries use
|
---|
720 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
721 | --
|
---|
722 | CREATE SEQUENCE TestBoxIdSeq
|
---|
723 | START 1
|
---|
724 | INCREMENT BY 1
|
---|
725 | NO MAXVALUE
|
---|
726 | NO MINVALUE
|
---|
727 | CACHE 1;
|
---|
728 | CREATE SEQUENCE TestBoxGenIdSeq
|
---|
729 | START 1
|
---|
730 | INCREMENT BY 1
|
---|
731 | NO MAXVALUE
|
---|
732 | NO MINVALUE
|
---|
733 | CACHE 1;
|
---|
734 | CREATE TABLE TestBoxes (
|
---|
735 | --- The fixed testbox ID.
|
---|
736 | -- This is assigned when the testbox is created and will never change.
|
---|
737 | idTestBox INTEGER DEFAULT NEXTVAL('TestBoxIdSeq') NOT NULL,
|
---|
738 | --- When this row starts taking effect (inclusive).
|
---|
739 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
740 | --- When this row stops being tsEffective (exclusive).
|
---|
741 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
742 | --- The user id of the one who created/modified this entry.
|
---|
743 | -- When modified automatically by the testbox, NULL is used.
|
---|
744 | -- Non-unique foreign key: Users(uid)
|
---|
745 | uidAuthor INTEGER DEFAULT NULL,
|
---|
746 | --- Generation ID for this row.
|
---|
747 | -- This is primarily for referencing by TestSets.
|
---|
748 | idGenTestBox INTEGER UNIQUE DEFAULT NEXTVAL('TestBoxGenIdSeq') NOT NULL,
|
---|
749 |
|
---|
750 | --- The testbox IP.
|
---|
751 | -- This is from the webserver point of view and automatically updated on
|
---|
752 | -- SIGNON. The test setup doesn't permit for IP addresses to change while
|
---|
753 | -- the testbox is operational, because this will break gang tests.
|
---|
754 | ip inet NOT NULL,
|
---|
755 | --- The system or firmware UUID.
|
---|
756 | -- This uniquely identifies the testbox when talking to the server. After
|
---|
757 | -- SIGNON though, the testbox will also provide idTestBox and ip to
|
---|
758 | -- establish its identity beyond doubt.
|
---|
759 | uuidSystem uuid NOT NULL,
|
---|
760 | --- The testbox name.
|
---|
761 | -- Usually similar to the DNS name.
|
---|
762 | sName text NOT NULL,
|
---|
763 | --- Optional testbox description.
|
---|
764 | -- Intended for describing the box as well as making other relevant notes.
|
---|
765 | sDescription text DEFAULT NULL,
|
---|
766 |
|
---|
767 | --- Reference to the scheduling group that this testbox is a member of.
|
---|
768 | -- Non-unique foreign key: SchedGroups(idSchedGroup)
|
---|
769 | -- A testbox is always part of a group, the default one nothing else.
|
---|
770 | idSchedGroup INTEGER DEFAULT 1 NOT NULL,
|
---|
771 |
|
---|
772 | --- Indicates whether this testbox is enabled.
|
---|
773 | -- A testbox gets disabled when we're doing maintenance, debugging a issue
|
---|
774 | -- that happens only on that testbox, or some similar stuff. This is an
|
---|
775 | -- alternative to deleting the testbox.
|
---|
776 | fEnabled BOOLEAN DEFAULT NULL,
|
---|
777 |
|
---|
778 | --- The kind of lights-out-management.
|
---|
779 | enmLomKind LomKind_T DEFAULT 'none'::LomKind_T NOT NULL,
|
---|
780 | --- The IP adress of the lights-out-management.
|
---|
781 | -- This can be NULL if enmLomKind is 'none', otherwise it must contain a valid address.
|
---|
782 | ipLom inet DEFAULT NULL,
|
---|
783 |
|
---|
784 | --- Timeout scale factor, given as a percent.
|
---|
785 | -- This is a crude adjustment of the test case timeout for slower hardware.
|
---|
786 | pctScaleTimeout smallint DEFAULT 100 NOT NULL CHECK (pctScaleTimeout > 10 AND pctScaleTimeout < 20000),
|
---|
787 |
|
---|
788 | --- @name Scheduling properties (reported by testbox script).
|
---|
789 | -- @{
|
---|
790 | --- Same abbrieviations as kBuild, see KBUILD_OSES.
|
---|
791 | sOs text DEFAULT NULL,
|
---|
792 | --- Informational, no fixed format.
|
---|
793 | sOsVersion text DEFAULT NULL,
|
---|
794 | --- Same as CPUID reports (GenuineIntel, AuthenticAMD, CentaurHauls, ...).
|
---|
795 | sCpuVendor text DEFAULT NULL,
|
---|
796 | --- Same as kBuild - x86, amd64, ... See KBUILD_ARCHES.
|
---|
797 | sCpuArch text DEFAULT NULL,
|
---|
798 | --- The CPU name if available.
|
---|
799 | sCpuName text DEFAULT NULL,
|
---|
800 | --- Number identifying the CPU family/model/stepping/whatever.
|
---|
801 | -- For x86 and AMD64 type CPUs, this will on the following format:
|
---|
802 | -- (EffFamily << 24) | (EffModel << 8) | Stepping.
|
---|
803 | lCpuRevision bigint DEFAULT NULL,
|
---|
804 | --- Number of CPUs, CPU cores and CPU threads.
|
---|
805 | cCpus smallint DEFAULT NULL CHECK (cCpus IS NULL OR cCpus > 0),
|
---|
806 | --- Set if capable of hardware virtualization.
|
---|
807 | fCpuHwVirt boolean DEFAULT NULL,
|
---|
808 | --- Set if capable of nested paging.
|
---|
809 | fCpuNestedPaging boolean DEFAULT NULL,
|
---|
810 | --- Set if CPU capable of 64-bit (VBox) guests.
|
---|
811 | fCpu64BitGuest boolean DEFAULT NULL,
|
---|
812 | --- Set if chipset with usable IOMMU (VT-d / AMD-Vi).
|
---|
813 | fChipsetIoMmu boolean DEFAULT NULL,
|
---|
814 | --- The (approximate) memory size in megabytes (rounded down to nearest 4 MB).
|
---|
815 | cMbMemory bigint DEFAULT NULL CHECK (cMbMemory IS NULL OR cMbMemory > 0),
|
---|
816 | --- The amount of scratch space in megabytes (rounded down to nearest 64 MB).
|
---|
817 | cMbScratch bigint DEFAULT NULL CHECK (cMbScratch IS NULL OR cMbScratch >= 0),
|
---|
818 | --- Free form hardware and software report field.
|
---|
819 | sReport text DEFAULT NULL,
|
---|
820 | --- @}
|
---|
821 |
|
---|
822 | --- The testbox script revision number, serves the purpose of a version number.
|
---|
823 | -- Probably good to have when scheduling upgrades as well for status purposes.
|
---|
824 | iTestBoxScriptRev INTEGER DEFAULT 0 NOT NULL,
|
---|
825 | --- The python sys.hexversion (layed out as of 2.7).
|
---|
826 | -- Good to know which python versions we need to support.
|
---|
827 | iPythonHexVersion INTEGER DEFAULT NULL,
|
---|
828 |
|
---|
829 | --- Pending command.
|
---|
830 | -- @note We put it here instead of in TestBoxStatuses to get history.
|
---|
831 | enmPendingCmd TestBoxCmd_T DEFAULT 'none'::TestBoxCmd_T NOT NULL,
|
---|
832 |
|
---|
833 | PRIMARY KEY (idTestBox, tsExpire),
|
---|
834 |
|
---|
835 | --- Nested paging requires hardware virtualization.
|
---|
836 | CHECK (fCpuNestedPaging IS NULL OR (fCpuNestedPaging <> TRUE OR fCpuHwVirt = TRUE))
|
---|
837 | );
|
---|
838 | CREATE UNIQUE INDEX TestBoxesUuidIdx ON TestBoxes (uuidSystem, tsExpire DESC);
|
---|
839 | CREATE INDEX TestBoxesExpireEffectiveIdx ON TestBoxes (tsExpire DESC, tsEffective ASC);
|
---|
840 |
|
---|
841 |
|
---|
842 |
|
---|
843 |
|
---|
844 |
|
---|
845 |
|
---|
846 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
847 | --
|
---|
848 | -- F a i l u r e T r a c k i n g
|
---|
849 | --
|
---|
850 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
851 |
|
---|
852 |
|
---|
853 | --- @table FailureCategories
|
---|
854 | -- Failure categories.
|
---|
855 | --
|
---|
856 | -- This is for organizing the failure reasons.
|
---|
857 | --
|
---|
858 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
859 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
860 | -- current_timestamp. To select the currently valid entries use
|
---|
861 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
862 | --
|
---|
863 | CREATE SEQUENCE FailureCategoryIdSeq
|
---|
864 | START 1
|
---|
865 | INCREMENT BY 1
|
---|
866 | NO MAXVALUE
|
---|
867 | NO MINVALUE
|
---|
868 | CACHE 1;
|
---|
869 | CREATE TABLE FailureCategories (
|
---|
870 | --- The identifier of this failure category (once assigned, it will never change).
|
---|
871 | idFailureCategory INTEGER DEFAULT NEXTVAL('FailureCategoryIdSeq') NOT NULL,
|
---|
872 | --- When this row starts taking effect (inclusive).
|
---|
873 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
874 | --- When this row stops being tsEffective (exclusive).
|
---|
875 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
876 | --- The user id of the one who created/modified this entry.
|
---|
877 | -- Non-unique foreign key: Users(uid)
|
---|
878 | uidAuthor INTEGER NOT NULL,
|
---|
879 | --- The short category description.
|
---|
880 | -- For combo boxes and other selection lists.
|
---|
881 | sShort text NOT NULL,
|
---|
882 | --- Full description
|
---|
883 | -- For cursor-over-poppups for instance.
|
---|
884 | sFull text NOT NULL,
|
---|
885 |
|
---|
886 | PRIMARY KEY (idFailureCategory, tsExpire)
|
---|
887 | );
|
---|
888 |
|
---|
889 |
|
---|
890 | --- @table FailureReasons
|
---|
891 | -- Failure reasons.
|
---|
892 | --
|
---|
893 | -- When analysing a test failure, the testbox sheriff will try assign a fitting
|
---|
894 | -- reason for the failure. This table is here to help the sheriff in his/hers
|
---|
895 | -- job as well as developers looking checking if their changes affected the
|
---|
896 | -- test results in any way.
|
---|
897 | --
|
---|
898 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
899 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
900 | -- current_timestamp. To select the currently valid entries use
|
---|
901 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
902 | --
|
---|
903 | CREATE SEQUENCE FailureReasonIdSeq
|
---|
904 | START 1
|
---|
905 | INCREMENT BY 1
|
---|
906 | NO MAXVALUE
|
---|
907 | NO MINVALUE
|
---|
908 | CACHE 1;
|
---|
909 | CREATE TABLE FailureReasons (
|
---|
910 | --- The identifier of this failure reason (once assigned, it will never change).
|
---|
911 | idFailureReason INTEGER DEFAULT NEXTVAL('FailureReasonIdSeq') NOT NULL,
|
---|
912 | --- When this row starts taking effect (inclusive).
|
---|
913 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
914 | --- When this row stops being tsEffective (exclusive).
|
---|
915 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
916 | --- The user id of the one who created/modified this entry.
|
---|
917 | -- Non-unique foreign key: Users(uid)
|
---|
918 | uidAuthor INTEGER NOT NULL,
|
---|
919 |
|
---|
920 | --- The failure category this reason belongs to.
|
---|
921 | -- Non-unique foreign key: FailureCategories(idFailureCategory)
|
---|
922 | idFailureCategory INTEGER NOT NULL,
|
---|
923 | --- The short failure description.
|
---|
924 | -- For combo boxes and other selection lists.
|
---|
925 | sShort text NOT NULL,
|
---|
926 | --- Full failure description.
|
---|
927 | sFull text NOT NULL,
|
---|
928 | --- Ticket number in the primary bugtracker.
|
---|
929 | iTicket INTEGER DEFAULT NULL,
|
---|
930 | --- Other URLs to reports or discussions of the observed symptoms.
|
---|
931 | asUrls text ARRAY DEFAULT NULL,
|
---|
932 |
|
---|
933 | PRIMARY KEY (idFailureReason, tsExpire)
|
---|
934 | );
|
---|
935 | CREATE INDEX FailureReasonsCategoryIdx ON FailureReasons (idFailureCategory, idFailureReason);
|
---|
936 |
|
---|
937 |
|
---|
938 |
|
---|
939 | --- @table TestResultFailures
|
---|
940 | -- This is for tracking/discussing test result failures.
|
---|
941 | --
|
---|
942 | -- The rational for putting this is a separate table is that we need history on
|
---|
943 | -- this while TestResults does not.
|
---|
944 | --
|
---|
945 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
946 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
947 | -- current_timestamp. To select the currently valid entries use
|
---|
948 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
949 | --
|
---|
950 | CREATE TABLE TestResultFailures (
|
---|
951 | --- The test result we're disucssing.
|
---|
952 | -- @note The foreign key is declared after TestResults (further down).
|
---|
953 | idTestResult INTEGER NOT NULL,
|
---|
954 | --- When this row starts taking effect (inclusive).
|
---|
955 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
956 | --- When this row stops being tsEffective (exclusive).
|
---|
957 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
958 | --- The user id of the one who created/modified this entry.
|
---|
959 | -- Non-unique foreign key: Users(uid)
|
---|
960 | uidAuthor INTEGER NOT NULL,
|
---|
961 | --- The testsest this result is a part of.
|
---|
962 | -- This is mainly an aid for bypassing the enormous TestResults table.
|
---|
963 | -- Note! This is a foreign key, but we have to add it after TestSets has
|
---|
964 | -- been created, see further down.
|
---|
965 | idTestSet INTEGER NOT NULL,
|
---|
966 |
|
---|
967 | --- The suggested failure reason.
|
---|
968 | -- Non-unique foreign key: FailureReasons(idFailureReason)
|
---|
969 | idFailureReason INTEGER NOT NULL,
|
---|
970 | --- Optional comment.
|
---|
971 | sComment text DEFAULT NULL,
|
---|
972 |
|
---|
973 | PRIMARY KEY (idTestResult, tsExpire)
|
---|
974 | );
|
---|
975 | CREATE INDEX TestResultFailureIdx ON TestResultFailures (idTestSet, tsExpire DESC, tsEffective ASC);
|
---|
976 | CREATE INDEX TestResultFailureIdx2 ON TestResultFailures (idTestResult, tsExpire DESC, tsEffective ASC);
|
---|
977 | CREATE INDEX TestResultFailureIdx3 ON TestResultFailures (idFailureReason, idTestResult, tsExpire DESC, tsEffective ASC);
|
---|
978 |
|
---|
979 |
|
---|
980 |
|
---|
981 |
|
---|
982 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
983 | --
|
---|
984 | -- T e s t I n p u t
|
---|
985 | --
|
---|
986 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
987 |
|
---|
988 |
|
---|
989 | --- @table BuildBlacklist
|
---|
990 | -- Table used to blacklist sets of builds.
|
---|
991 | --
|
---|
992 | -- The best usage example is a VMM developer realizing that a change causes the
|
---|
993 | -- host to panic, hang, or otherwise misbehave. To prevent the testbox sheriff
|
---|
994 | -- from repeatedly having to reboot testboxes, the builds gets blacklisted
|
---|
995 | -- until there is a working build again. This may mean adding an open ended
|
---|
996 | -- blacklist spec and then updating it with the final revision number once the
|
---|
997 | -- fix has been committed.
|
---|
998 | --
|
---|
999 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
1000 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
1001 | -- current_timestamp. To select the currently valid entries use
|
---|
1002 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
1003 | --
|
---|
1004 | -- @todo Would be nice if we could replace the text strings below with a set of
|
---|
1005 | -- BuildCategories, or sore it in any other way which would enable us to
|
---|
1006 | -- do a negative join with build category... The way it is specified
|
---|
1007 | -- now, it looks like we have to open a cursor of prospecitve builds and
|
---|
1008 | -- filter then thru this table one by one.
|
---|
1009 | --
|
---|
1010 | -- Any better representation is welcome, but this is low prioirty for
|
---|
1011 | -- now, as it's relatively easy to change this later one.
|
---|
1012 | --
|
---|
1013 | CREATE SEQUENCE BuildBlacklistIdSeq
|
---|
1014 | START 1
|
---|
1015 | INCREMENT BY 1
|
---|
1016 | NO MAXVALUE
|
---|
1017 | NO MINVALUE
|
---|
1018 | CACHE 1;
|
---|
1019 | CREATE TABLE BuildBlacklist (
|
---|
1020 | --- The blacklist entry id.
|
---|
1021 | -- This stays constant over time.
|
---|
1022 | idBlacklisting INTEGER DEFAULT NEXTVAL('BuildBlacklistIdSeq') NOT NULL,
|
---|
1023 | --- When this row starts taking effect (inclusive).
|
---|
1024 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
1025 | --- When this row stops being tsEffective (exclusive).
|
---|
1026 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
1027 | --- The user id of the one who created/modified this entry.
|
---|
1028 | -- Non-unique foreign key: Users(uid)
|
---|
1029 | uidAuthor INTEGER NOT NULL,
|
---|
1030 |
|
---|
1031 | --- The reason for the blacklisting.
|
---|
1032 | -- Non-unique foreign key: FailureReasons(idFailureReason)
|
---|
1033 | idFailureReason INTEGER NOT NULL,
|
---|
1034 |
|
---|
1035 | --- Which product.
|
---|
1036 | -- ASSUME that it is okay to limit a blacklisting to a single product.
|
---|
1037 | sProduct text NOT NULL,
|
---|
1038 | --- Which branch.
|
---|
1039 | -- ASSUME that it is okay to limit a blacklisting to a branch.
|
---|
1040 | sBranch text NOT NULL,
|
---|
1041 |
|
---|
1042 | --- Build types to include, all matches if NULL.
|
---|
1043 | asTypes text ARRAY DEFAULT NULL,
|
---|
1044 | --- Array of the 'sOs.sCpuArch' to match, all matches if NULL.
|
---|
1045 | -- See KBUILD_OSES in kBuild for a list of standard target OSes, and
|
---|
1046 | -- KBUILD_ARCHES for a list of standard architectures.
|
---|
1047 | --
|
---|
1048 | -- @remarks See marks on 'os-agnostic' and 'noarch' in BuildCategories.
|
---|
1049 | asOsArches text ARRAY DEFAULT NULL,
|
---|
1050 |
|
---|
1051 | --- The first subversion tree revision to blacklist.
|
---|
1052 | iFirstRevision INTEGER NOT NULL,
|
---|
1053 | --- The last subversion tree revision to blacklist, no upper limit if NULL.
|
---|
1054 | iLastRevision INTEGER NOT NULL,
|
---|
1055 |
|
---|
1056 | PRIMARY KEY (idBlacklisting, tsExpire)
|
---|
1057 | );
|
---|
1058 | CREATE INDEX BuildBlacklistIdx ON BuildBlacklist (iLastRevision DESC, iFirstRevision ASC, sProduct, sBranch,
|
---|
1059 | tsExpire DESC, tsEffective ASC);
|
---|
1060 |
|
---|
1061 | --- @table BuildCategories
|
---|
1062 | -- Build categories.
|
---|
1063 | --
|
---|
1064 | -- The purpose of this table is saving space in the Builds table and hopefully
|
---|
1065 | -- speed things up when selecting builds as well (compared to selecting on 4
|
---|
1066 | -- text fields in the much larger Builds table).
|
---|
1067 | --
|
---|
1068 | -- Insert only table, no update, no delete. History is not needed.
|
---|
1069 | --
|
---|
1070 | CREATE SEQUENCE BuildCategoryIdSeq
|
---|
1071 | START 1
|
---|
1072 | INCREMENT BY 1
|
---|
1073 | NO MAXVALUE
|
---|
1074 | NO MINVALUE
|
---|
1075 | CACHE 1;
|
---|
1076 | CREATE TABLE BuildCategories (
|
---|
1077 | --- The build type identifier.
|
---|
1078 | idBuildCategory INTEGER PRIMARY KEY DEFAULT NEXTVAL('BuildCategoryIdSeq') NOT NULL,
|
---|
1079 | --- Product.
|
---|
1080 | -- The product name. For instance 'VBox' or 'VBoxTestSuite'.
|
---|
1081 | sProduct TEXT NOT NULL,
|
---|
1082 | --- The version control repository name.
|
---|
1083 | sRepository TEXT NOT NULL,
|
---|
1084 | --- The branch name (in the version control system).
|
---|
1085 | sBranch TEXT NOT NULL,
|
---|
1086 | --- The build type.
|
---|
1087 | -- See KBUILD_BLD_TYPES in kBuild for a list of standard build types.
|
---|
1088 | sType TEXT NOT NULL,
|
---|
1089 | --- Array of the 'sOs.sCpuArch' supported by the build.
|
---|
1090 | -- See KBUILD_OSES in kBuild for a list of standard target OSes, and
|
---|
1091 | -- KBUILD_ARCHES for a list of standard architectures.
|
---|
1092 | --
|
---|
1093 | -- @remarks 'os-agnostic' is used if the build doesn't really target any
|
---|
1094 | -- specific OS or if it targets all applicable OSes.
|
---|
1095 | -- 'noarch' is used if the build is architecture independent or if
|
---|
1096 | -- all applicable architectures are handled.
|
---|
1097 | -- Thus, 'os-agnostic.noarch' will run on all build boxes.
|
---|
1098 | --
|
---|
1099 | -- @note The array shall be sorted ascendingly to prevent unnecessary duplicates!
|
---|
1100 | --
|
---|
1101 | asOsArches TEXT ARRAY NOT NULL,
|
---|
1102 |
|
---|
1103 | UNIQUE (sProduct, sRepository, sBranch, sType, asOsArches)
|
---|
1104 | );
|
---|
1105 |
|
---|
1106 |
|
---|
1107 | --- @table Builds
|
---|
1108 | -- The builds table contains builds from the tinderboxes and oaccasionally from
|
---|
1109 | -- developers.
|
---|
1110 | --
|
---|
1111 | -- The tinderbox side could be fed by a batch job enumerating the build output
|
---|
1112 | -- directories every so often, looking for new builds. Or we could query them
|
---|
1113 | -- from the tinderbox database. Yet another alternative is making the
|
---|
1114 | -- tinderbox server or client side software inform us about all new builds.
|
---|
1115 | --
|
---|
1116 | -- The developer builds are entered manually thru the TM web UI. They are used
|
---|
1117 | -- for subjecting new code to some larger scale testing before commiting,
|
---|
1118 | -- enabling, or merging a private branch.
|
---|
1119 | --
|
---|
1120 | -- The builds are being selected from this table by the via the build source
|
---|
1121 | -- specification that SchedGroups.idBuildSrc and
|
---|
1122 | -- SchedGroups.idBuildSrcTestSuite links to.
|
---|
1123 | --
|
---|
1124 | -- @remarks This table stores history. Never update or delete anything. The
|
---|
1125 | -- equivalent of deleting is done by setting the 'tsExpire' field to
|
---|
1126 | -- current_timestamp. To select the currently valid entries use
|
---|
1127 | -- tsExpire = TIMESTAMP WITH TIME ZONE 'infinity'.
|
---|
1128 | --
|
---|
1129 | CREATE SEQUENCE BuildIdSeq
|
---|
1130 | START 1
|
---|
1131 | INCREMENT BY 1
|
---|
1132 | NO MAXVALUE
|
---|
1133 | NO MINVALUE
|
---|
1134 | CACHE 1;
|
---|
1135 | CREATE TABLE Builds (
|
---|
1136 | --- The build identifier.
|
---|
1137 | -- This remains unchanged
|
---|
1138 | idBuild INTEGER DEFAULT NEXTVAL('BuildIdSeq') NOT NULL,
|
---|
1139 | --- When this build was created or entered into the database.
|
---|
1140 | -- This remains unchanged
|
---|
1141 | tsCreated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
1142 | --- When this row starts taking effect (inclusive).
|
---|
1143 | tsEffective TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
1144 | --- When this row stops being tsEffective (exclusive).
|
---|
1145 | tsExpire TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'infinity' NOT NULL,
|
---|
1146 | --- The user id of the one who created/modified this entry.
|
---|
1147 | -- Non-unique foreign key: Users(uid)
|
---|
1148 | -- @note This is NULL if added by a batch job / tinderbox.
|
---|
1149 | uidAuthor INTEGER DEFAULT NULL,
|
---|
1150 | --- The build category.
|
---|
1151 | idBuildCategory INTEGER REFERENCES BuildCategories(idBuildCategory) NOT NULL,
|
---|
1152 | --- The subversion tree revision of the build.
|
---|
1153 | iRevision INTEGER NOT NULL,
|
---|
1154 | --- The product version number (suitable for RTStrVersionCompare).
|
---|
1155 | sVersion TEXT NOT NULL,
|
---|
1156 | --- The link to the tinderbox log of this build.
|
---|
1157 | sLogUrl TEXT,
|
---|
1158 | --- Comma separated list of binaries.
|
---|
1159 | -- The binaries have paths relative to the TESTBOX_PATH_BUILDS or full URLs.
|
---|
1160 | sBinaries TEXT NOT NULL,
|
---|
1161 | --- Set when the binaries gets deleted by the build quota script.
|
---|
1162 | fBinariesDeleted BOOLEAN DEFAULT FALSE NOT NULL,
|
---|
1163 |
|
---|
1164 | UNIQUE (idBuild, tsExpire)
|
---|
1165 | );
|
---|
1166 | CREATE INDEX BuildsLookupIdx ON Builds (idBuildCategory, iRevision);
|
---|
1167 |
|
---|
1168 |
|
---|
1169 | --- @table VcsRevisions
|
---|
1170 | -- This table is for translating build revisions into commit details.
|
---|
1171 | --
|
---|
1172 | -- For graphs and test results, it would be useful to translate revisions into
|
---|
1173 | -- dates and maybe provide commit message and the committer.
|
---|
1174 | --
|
---|
1175 | -- Data is entered exclusively thru one or more batch jobs, so no internal
|
---|
1176 | -- authorship needed. Also, since we're mirroring data from external sources
|
---|
1177 | -- here, the batch job is allowed to update/replace existing records.
|
---|
1178 | --
|
---|
1179 | -- @todo We we could collect more info from the version control systems, if we
|
---|
1180 | -- believe it's useful and can be presented in a reasonable manner.
|
---|
1181 | -- Getting a list of affected files would be simple (requires
|
---|
1182 | -- a separate table with a M:1 relationship to this table), or try
|
---|
1183 | -- associate a commit to a branch.
|
---|
1184 | --
|
---|
1185 | CREATE TABLE VcsRevisions (
|
---|
1186 | --- The version control tree name.
|
---|
1187 | sRepository TEXT NOT NULL,
|
---|
1188 | --- The version control tree revision number.
|
---|
1189 | iRevision INTEGER NOT NULL,
|
---|
1190 | --- When the revision was created (committed).
|
---|
1191 | tsCreated TIMESTAMP WITH TIME ZONE NOT NULL,
|
---|
1192 | --- The name of the committer.
|
---|
1193 | -- @note Not to be confused with uidAuthor and test manager users.
|
---|
1194 | sAuthor TEXT,
|
---|
1195 | --- The commit message.
|
---|
1196 | sMessage TEXT,
|
---|
1197 |
|
---|
1198 | UNIQUE (sRepository, iRevision)
|
---|
1199 | );
|
---|
1200 |
|
---|
1201 |
|
---|
1202 |
|
---|
1203 |
|
---|
1204 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
1205 | --
|
---|
1206 | -- T e s t R e s u l t s
|
---|
1207 | --
|
---|
1208 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
1209 |
|
---|
1210 |
|
---|
1211 | --- @table TestResultStrTab
|
---|
1212 | -- String table for the test results.
|
---|
1213 | --
|
---|
1214 | -- This is a string cache for value names, test names and possible more, that
|
---|
1215 | -- is frequently repated in the test results record for each test run. The
|
---|
1216 | -- purpose is not only to save space, but to make datamining queries faster by
|
---|
1217 | -- giving them integer fields to work on instead of text fields. There may
|
---|
1218 | -- possibly be some benefits on INSERT as well as there are only integer
|
---|
1219 | -- indexes.
|
---|
1220 | --
|
---|
1221 | -- Nothing is ever deleted from this table.
|
---|
1222 | --
|
---|
1223 | -- @note Should use a stored procedure to query/insert a string.
|
---|
1224 | --
|
---|
1225 | CREATE SEQUENCE TestResultStrTabIdSeq
|
---|
1226 | START 1
|
---|
1227 | INCREMENT BY 1
|
---|
1228 | NO MAXVALUE
|
---|
1229 | NO MINVALUE
|
---|
1230 | CACHE 1;
|
---|
1231 | CREATE TABLE TestResultStrTab (
|
---|
1232 | --- The ID of this string.
|
---|
1233 | idStr INTEGER PRIMARY KEY DEFAULT NEXTVAL('TestResultStrTabIdSeq'),
|
---|
1234 | --- The string value.
|
---|
1235 | sValue text NOT NULL,
|
---|
1236 | --- Creation time stamp.
|
---|
1237 | tsCreated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL
|
---|
1238 | );
|
---|
1239 | CREATE UNIQUE INDEX TestResultStrTabNameIdx ON TestResultStrTab (sValue);
|
---|
1240 |
|
---|
1241 | --- Empty string with ID 0.
|
---|
1242 | INSERT INTO TestResultStrTab (idStr, sValue) VALUES (0, '');
|
---|
1243 |
|
---|
1244 |
|
---|
1245 | --- @type TestStatus_T
|
---|
1246 | -- The status of a test (set / result).
|
---|
1247 | --
|
---|
1248 | CREATE TYPE TestStatus_T AS ENUM (
|
---|
1249 | -- Initial status:
|
---|
1250 | 'running',
|
---|
1251 | -- Final statuses:
|
---|
1252 | 'success',
|
---|
1253 | -- Final status: Test didn't fail as such, it was something else.
|
---|
1254 | 'skipped',
|
---|
1255 | 'bad-testbox',
|
---|
1256 | 'aborted',
|
---|
1257 | -- Final status: Test failed.
|
---|
1258 | 'failure',
|
---|
1259 | 'timed-out',
|
---|
1260 | 'rebooted'
|
---|
1261 | );
|
---|
1262 |
|
---|
1263 |
|
---|
1264 | --- @table TestResults
|
---|
1265 | -- Test results - a recursive bundle of joy!
|
---|
1266 | --
|
---|
1267 | -- A test case will be created when the testdriver calls reporter.testStart and
|
---|
1268 | -- concluded with reporter.testDone. The testdriver (or it subordinates) can
|
---|
1269 | -- use these methods to create nested test results. For IPRT based test cases,
|
---|
1270 | -- RTTestCreate, RTTestInitAndCreate and RTTestSub will both create new test
|
---|
1271 | -- result records, where as RTTestSubDone, RTTestSummaryAndDestroy and
|
---|
1272 | -- RTTestDestroy will conclude records.
|
---|
1273 | --
|
---|
1274 | -- By concluding is meant updating the status. When the test driver reports
|
---|
1275 | -- success, we check it against reported results. (paranoia strikes again!)
|
---|
1276 | --
|
---|
1277 | -- Nothing is ever deleted from this table.
|
---|
1278 | --
|
---|
1279 | -- @note As seen below, several other tables associate data with a
|
---|
1280 | -- test result, and the top most test result is referenced by the
|
---|
1281 | -- test set.
|
---|
1282 | --
|
---|
1283 | CREATE SEQUENCE TestResultIdSeq
|
---|
1284 | START 1
|
---|
1285 | INCREMENT BY 1
|
---|
1286 | NO MAXVALUE
|
---|
1287 | NO MINVALUE
|
---|
1288 | CACHE 1;
|
---|
1289 | CREATE TABLE TestResults (
|
---|
1290 | --- The ID of this test result.
|
---|
1291 | idTestResult INTEGER PRIMARY KEY DEFAULT NEXTVAL('TestResultIdSeq'),
|
---|
1292 | --- The parent test result.
|
---|
1293 | -- This is NULL for the top test result.
|
---|
1294 | idTestResultParent INTEGER REFERENCES TestResults(idTestResult),
|
---|
1295 | --- The testsest this result is a part of.
|
---|
1296 | -- Note! This is a foreign key, but we have to add it after TestSets has
|
---|
1297 | -- been created, see further down.
|
---|
1298 | idTestSet INTEGER NOT NULL,
|
---|
1299 | --- Creation time stamp. This may also be the timestamp of when the test started.
|
---|
1300 | tsCreated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
1301 | --- The elapsed time for this test.
|
---|
1302 | -- This is either reported by the directly (with some sanity checking) or
|
---|
1303 | -- calculated (current_timestamp - created_ts).
|
---|
1304 | -- @todo maybe use a nanosecond field here, check with what
|
---|
1305 | tsElapsed interval DEFAULT NULL,
|
---|
1306 | --- The test name.
|
---|
1307 | idStrName INTEGER REFERENCES TestResultStrTab(idStr) NOT NULL,
|
---|
1308 | --- The error count.
|
---|
1309 | cErrors INTEGER DEFAULT 0 NOT NULL,
|
---|
1310 | --- The test status.
|
---|
1311 | enmStatus TestStatus_T DEFAULT 'running'::TestStatus_T NOT NULL,
|
---|
1312 | --- Nesting depth.
|
---|
1313 | iNestingDepth smallint NOT NULL CHECK (iNestingDepth >= 0 AND iNestingDepth < 16),
|
---|
1314 | -- Make sure errors and status match up.
|
---|
1315 | CONSTRAINT CheckStatusMatchesErrors
|
---|
1316 | CHECK ( (cErrors > 0 AND enmStatus IN ('running'::TestStatus_T,
|
---|
1317 | 'failure'::TestStatus_T, 'timed-out'::TestStatus_T, 'rebooted'::TestStatus_T ))
|
---|
1318 | OR (cErrors = 0 AND enmStatus IN ('running'::TestStatus_T, 'success'::TestStatus_T,
|
---|
1319 | 'skipped'::TestStatus_T, 'aborted'::TestStatus_T, 'bad-testbox'::TestStatus_T))
|
---|
1320 | ),
|
---|
1321 | -- The following is for the TestResultFailures foreign key.
|
---|
1322 | -- Note! This was added with the name TestResults_idTestResult_idTestSet_key in the tmdb-r16 update script.
|
---|
1323 | UNIQUE (idTestResult, idTestSet)
|
---|
1324 | );
|
---|
1325 |
|
---|
1326 | CREATE INDEX TestResultsSetIdx ON TestResults (idTestSet, idStrName, idTestResult);
|
---|
1327 | CREATE INDEX TestResultsParentIdx ON TestResults (idTestResultParent);
|
---|
1328 | -- The TestResultsNameIdx and TestResultsNameIdx2 are for speeding up the result graph & reporting code.
|
---|
1329 | CREATE INDEX TestResultsNameIdx ON TestResults (idStrName, tsCreated DESC);
|
---|
1330 | CREATE INDEX TestResultsNameIdx2 ON TestResults (idTestResult, idStrName);
|
---|
1331 |
|
---|
1332 | ALTER TABLE TestResultFailures ADD CONSTRAINT TestResultFailures_idTestResult_idTestSet_fkey
|
---|
1333 | FOREIGN KEY (idTestResult, idTestSet) REFERENCES TestResults(idTestResult, idTestSet) MATCH FULL;
|
---|
1334 |
|
---|
1335 |
|
---|
1336 | --- @table TestResultValues
|
---|
1337 | -- Test result values.
|
---|
1338 | --
|
---|
1339 | -- A testdriver or subordinate may report a test value via
|
---|
1340 | -- reporter.testValue(), while IPRT based test will use RTTestValue and
|
---|
1341 | -- associates.
|
---|
1342 | --
|
---|
1343 | -- This is an insert only table, no deletes, no updates.
|
---|
1344 | --
|
---|
1345 | CREATE SEQUENCE TestResultValueIdSeq
|
---|
1346 | START 1
|
---|
1347 | INCREMENT BY 1
|
---|
1348 | NO MAXVALUE
|
---|
1349 | NO MINVALUE
|
---|
1350 | CACHE 1;
|
---|
1351 | CREATE TABLE TestResultValues (
|
---|
1352 | --- The ID of this value.
|
---|
1353 | idTestResultValue INTEGER PRIMARY KEY DEFAULT NEXTVAL('TestResultValueIdSeq'),
|
---|
1354 | --- The test result it was reported within.
|
---|
1355 | idTestResult INTEGER REFERENCES TestResults(idTestResult) NOT NULL,
|
---|
1356 | --- The test result it was reported within.
|
---|
1357 | -- Note! This is a foreign key, but we have to add it after TestSets has
|
---|
1358 | -- been created, see further down.
|
---|
1359 | idTestSet INTEGER NOT NULL,
|
---|
1360 | --- Creation time stamp.
|
---|
1361 | tsCreated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
1362 | --- The name.
|
---|
1363 | idStrName INTEGER REFERENCES TestResultStrTab(idStr) NOT NULL,
|
---|
1364 | --- The value.
|
---|
1365 | lValue bigint NOT NULL,
|
---|
1366 | --- The unit.
|
---|
1367 | -- @todo This is currently not defined properly. Will fix/correlate this
|
---|
1368 | -- with the other places we use unit (IPRT/testdriver/VMMDev).
|
---|
1369 | iUnit smallint NOT NULL CHECK (iUnit >= 0 AND iUnit < 1024)
|
---|
1370 | );
|
---|
1371 |
|
---|
1372 | CREATE INDEX TestResultValuesIdx ON TestResultValues(idTestResult);
|
---|
1373 | -- The TestResultValuesGraphIdx is for speeding up the result graph & reporting code.
|
---|
1374 | CREATE INDEX TestResultValuesGraphIdx ON TestResultValues(idStrName, tsCreated);
|
---|
1375 |
|
---|
1376 |
|
---|
1377 | --- @table TestResultFiles
|
---|
1378 | -- Test result files.
|
---|
1379 | --
|
---|
1380 | -- A testdriver or subordinate may report a file by using
|
---|
1381 | -- reporter.addFile() or reporter.addLogFile().
|
---|
1382 | --
|
---|
1383 | -- The files stored here as well as the primary log file will be processed by a
|
---|
1384 | -- batch job and compressed if considered compressable. Thus, TM will look for
|
---|
1385 | -- files with a .gz/.bz2 suffix first and then without a suffix.
|
---|
1386 | --
|
---|
1387 | -- This is an insert only table, no deletes, no updates.
|
---|
1388 | --
|
---|
1389 | CREATE SEQUENCE TestResultFileId
|
---|
1390 | START 1
|
---|
1391 | INCREMENT BY 1
|
---|
1392 | NO MAXVALUE
|
---|
1393 | NO MINVALUE
|
---|
1394 | CACHE 1;
|
---|
1395 | CREATE TABLE TestResultFiles (
|
---|
1396 | --- The ID of this file.
|
---|
1397 | idTestResultFile INTEGER PRIMARY KEY DEFAULT NEXTVAL('TestResultFileId'),
|
---|
1398 | --- The test result it was reported within.
|
---|
1399 | idTestResult INTEGER REFERENCES TestResults(idTestResult) NOT NULL,
|
---|
1400 | --- Creation time stamp.
|
---|
1401 | tsCreated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
1402 | --- The filename relative to TestSets(sBaseFilename) + '-'.
|
---|
1403 | -- The set of valid filename characters should be very limited so that no
|
---|
1404 | -- file system issues can occure either on the TM side or the user when
|
---|
1405 | -- loading the files. Tests trying to use other characters will fail.
|
---|
1406 | -- Valid character regular expession: '^[a-zA-Z0-9_-(){}#@+,.=]*$'
|
---|
1407 | idStrFile INTEGER REFERENCES TestResultStrTab(idStr) NOT NULL,
|
---|
1408 | --- The description.
|
---|
1409 | idStrDescription INTEGER REFERENCES TestResultStrTab(idStr) NOT NULL,
|
---|
1410 | --- The kind of file.
|
---|
1411 | -- For instance: 'log/release/vm',
|
---|
1412 | -- 'screenshot/failure',
|
---|
1413 | -- 'screencapture/failure',
|
---|
1414 | -- 'xmllog/somestuff'
|
---|
1415 | idStrKind INTEGER REFERENCES TestResultStrTab(idStr) NOT NULL,
|
---|
1416 | --- The mime type for the file.
|
---|
1417 | -- For instance: 'text/plain',
|
---|
1418 | -- 'image/png',
|
---|
1419 | -- 'video/webm',
|
---|
1420 | -- 'text/xml'
|
---|
1421 | idStrMime INTEGER REFERENCES TestResultStrTab(idStr) NOT NULL
|
---|
1422 | );
|
---|
1423 |
|
---|
1424 | CREATE INDEX TestResultFilesIdx ON TestResultFiles(idTestResult);
|
---|
1425 |
|
---|
1426 |
|
---|
1427 | --- @table TestResultMsgs
|
---|
1428 | -- Test result message.
|
---|
1429 | --
|
---|
1430 | -- A testdriver or subordinate may report a message via the sDetails parameter
|
---|
1431 | -- of the reporter.testFailure() method, while IPRT test cases will use
|
---|
1432 | -- RTTestFailed, RTTestPrintf and their friends. For RTTestPrintf, we will
|
---|
1433 | -- ignore the more verbose message levels since these can also be found in one
|
---|
1434 | -- of the logs.
|
---|
1435 | --
|
---|
1436 | -- This is an insert only table, no deletes, no updates.
|
---|
1437 | --
|
---|
1438 | CREATE TYPE TestResultMsgLevel_T AS ENUM (
|
---|
1439 | 'failure',
|
---|
1440 | 'info'
|
---|
1441 | );
|
---|
1442 | CREATE SEQUENCE TestResultMsgIdSeq
|
---|
1443 | START 1
|
---|
1444 | INCREMENT BY 1
|
---|
1445 | NO MAXVALUE
|
---|
1446 | NO MINVALUE
|
---|
1447 | CACHE 1;
|
---|
1448 | CREATE TABLE TestResultMsgs (
|
---|
1449 | --- The ID of this file.
|
---|
1450 | idTestResultMsg INTEGER PRIMARY KEY DEFAULT NEXTVAL('TestResultMsgIdSeq'),
|
---|
1451 | --- The test result it was reported within.
|
---|
1452 | idTestResult INTEGER REFERENCES TestResults(idTestResult) NOT NULL,
|
---|
1453 | --- Creation time stamp.
|
---|
1454 | tsCreated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
1455 | --- The message string.
|
---|
1456 | idStrMsg INTEGER REFERENCES TestResultStrTab(idStr) NOT NULL,
|
---|
1457 | --- The message level.
|
---|
1458 | enmLevel TestResultMsgLevel_T NOT NULL
|
---|
1459 | );
|
---|
1460 |
|
---|
1461 | CREATE INDEX TestResultMsgsIdx ON TestResultMsgs(idTestResult);
|
---|
1462 |
|
---|
1463 |
|
---|
1464 | --- @table TestSets
|
---|
1465 | -- Test sets / Test case runs.
|
---|
1466 | --
|
---|
1467 | -- This is where we collect data about test runs.
|
---|
1468 | --
|
---|
1469 | -- @todo Not entirely sure where the 'test set' term came from. Consider
|
---|
1470 | -- finding something more appropriate.
|
---|
1471 | --
|
---|
1472 | CREATE SEQUENCE TestSetIdSeq
|
---|
1473 | START 1
|
---|
1474 | INCREMENT BY 1
|
---|
1475 | NO MAXVALUE
|
---|
1476 | NO MINVALUE
|
---|
1477 | CACHE 1;
|
---|
1478 | CREATE TABLE TestSets (
|
---|
1479 | --- The ID of this test set.
|
---|
1480 | idTestSet INTEGER PRIMARY KEY DEFAULT NEXTVAL('TestSetIdSeq') NOT NULL,
|
---|
1481 |
|
---|
1482 | --- The test config timestamp, used when reading test config.
|
---|
1483 | tsConfig TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP NOT NULL,
|
---|
1484 | --- When this test set was scheduled.
|
---|
1485 | -- idGenTestBox is valid at this point.
|
---|
1486 | tsCreated TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP NOT NULL,
|
---|
1487 | --- When this test completed, i.e. testing stopped. This should only be set once.
|
---|
1488 | tsDone TIMESTAMP WITH TIME ZONE DEFAULT NULL,
|
---|
1489 | --- The current status.
|
---|
1490 | enmStatus TestStatus_T DEFAULT 'running'::TestStatus_T NOT NULL,
|
---|
1491 |
|
---|
1492 | --- The build we're testing.
|
---|
1493 | -- Non-unique foreign key: Builds(idBuild)
|
---|
1494 | idBuild INTEGER NOT NULL,
|
---|
1495 | --- The build category of idBuild when the test started.
|
---|
1496 | -- This is for speeding up graph data collection, i.e. avoid idBuild
|
---|
1497 | -- the WHERE part of the selection.
|
---|
1498 | idBuildCategory INTEGER REFERENCES BuildCategories(idBuildCategory) NOT NULL,
|
---|
1499 | --- The test suite build we're using to do the testing.
|
---|
1500 | -- This is NULL if the test suite zip wasn't referred or if a test suite
|
---|
1501 | -- build source wasn't configured.
|
---|
1502 | -- Non-unique foreign key: Builds(idBuild)
|
---|
1503 | idBuildTestSuite INTEGER DEFAULT NULL,
|
---|
1504 |
|
---|
1505 | --- The exact testbox configuration.
|
---|
1506 | idGenTestBox INTEGER REFERENCES TestBoxes(idGenTestBox) NOT NULL,
|
---|
1507 | --- The testbox ID for joining with (valid: tsStarted).
|
---|
1508 | -- Non-unique foreign key: TestBoxes(idTestBox)
|
---|
1509 | idTestBox INTEGER NOT NULL,
|
---|
1510 |
|
---|
1511 | --- The testgroup (valid: tsConfig).
|
---|
1512 | -- Non-unique foreign key: TestBoxes(idTestGroup)
|
---|
1513 | -- Note! This also gives the member ship entry, since a testcase can only
|
---|
1514 | -- have one membership per test group.
|
---|
1515 | idTestGroup INTEGER NOT NULL,
|
---|
1516 |
|
---|
1517 | --- The exact test case config we executed in this test run.
|
---|
1518 | idGenTestCase INTEGER REFERENCES TestCases(idGenTestCase) NOT NULL,
|
---|
1519 | --- The test case ID for joining with (valid: tsConfig).
|
---|
1520 | -- Non-unique foreign key: TestBoxes(idTestCase)
|
---|
1521 | idTestCase INTEGER NOT NULL,
|
---|
1522 |
|
---|
1523 | --- The arguments (and requirements++) we executed this test case with.
|
---|
1524 | idGenTestCaseArgs INTEGER REFERENCES TestCaseArgs(idGenTestCaseArgs) NOT NULL,
|
---|
1525 | --- The argument variation ID (valid: tsConfig).
|
---|
1526 | -- Non-unique foreign key: TestCaseArgs(idTestCaseArgs)
|
---|
1527 | idTestCaseArgs INTEGER NOT NULL,
|
---|
1528 |
|
---|
1529 | --- The root of the test result tree.
|
---|
1530 | -- @note This will only be NULL early in the transaction setting up the testset.
|
---|
1531 | -- @note If the test reports more than one top level test result, we'll
|
---|
1532 | -- fail the whole test run and let the test developer fix it.
|
---|
1533 | idTestResult INTEGER REFERENCES TestResults(idTestResult) DEFAULT NULL,
|
---|
1534 |
|
---|
1535 | --- The base filename used for storing files related to this test set.
|
---|
1536 | -- This is a path relative to wherever TM is dumping log files. In order
|
---|
1537 | -- to not become a file system test case, we will try not to put too many
|
---|
1538 | -- hundred thousand files in a directory. A simple first approach would
|
---|
1539 | -- be to just use the current date (tsCreated) like this:
|
---|
1540 | -- TM_FILE_DIR/year/month/day/TestSets.idTestSet
|
---|
1541 | --
|
---|
1542 | -- The primary log file for the test is this name suffixed by '.log'.
|
---|
1543 | --
|
---|
1544 | -- The files in the testresultfile table gets their full names like this:
|
---|
1545 | -- TM_FILE_DIR/sBaseFilename-testresultfile.id-TestResultStrTab(testresultfile.idStrFilename)
|
---|
1546 | --
|
---|
1547 | -- @remarks We store this explicitly in case we change the directly layout
|
---|
1548 | -- at some later point.
|
---|
1549 | sBaseFilename text UNIQUE NOT NULL,
|
---|
1550 |
|
---|
1551 | --- The gang member number number, 0 is the leader.
|
---|
1552 | iGangMemberNo SMALLINT DEFAULT 0 NOT NULL CHECK (iGangMemberNo >= 0 AND iGangMemberNo < 1024),
|
---|
1553 | --- The test set of the gang leader, NULL if no gang involved.
|
---|
1554 | -- @note This is set by the gang leader as well, so that we can find all
|
---|
1555 | -- gang members by WHERE idTestSetGangLeader = :id.
|
---|
1556 | idTestSetGangLeader INTEGER REFERENCES TestSets(idTestSet) DEFAULT NULL
|
---|
1557 |
|
---|
1558 | );
|
---|
1559 | CREATE INDEX TestSetsGangIdx ON TestSets (idTestSetGangLeader);
|
---|
1560 | CREATE INDEX TestSetsBoxIdx ON TestSets (idTestBox, idTestResult);
|
---|
1561 | CREATE INDEX TestSetsBuildIdx ON TestSets (idBuild, idTestResult);
|
---|
1562 | CREATE INDEX TestSetsTestCaseIdx ON TestSets (idTestCase, idTestResult);
|
---|
1563 | CREATE INDEX TestSetsTestVarIdx ON TestSets (idTestCaseArgs, idTestResult);
|
---|
1564 | --- The TestSetsDoneCreatedBuildCatIdx is for testbox results, graph options and such.
|
---|
1565 | CREATE INDEX TestSetsDoneCreatedBuildCatIdx ON TestSets (tsDone DESC NULLS FIRST, tsCreated ASC, idBuildCategory);
|
---|
1566 | --- For graphs.
|
---|
1567 | CREATE INDEX TestSetsGraphBoxIdx ON TestSets (idTestBox, tsCreated DESC, tsDone ASC NULLS LAST, idBuildCategory, idTestCase);
|
---|
1568 |
|
---|
1569 | ALTER TABLE TestResults ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
|
---|
1570 | ALTER TABLE TestResultValues ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
|
---|
1571 | ALTER TABLE TestResultFailures ADD CONSTRAINT idTestSetFk FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
|
---|
1572 |
|
---|
1573 |
|
---|
1574 |
|
---|
1575 |
|
---|
1576 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
1577 | --
|
---|
1578 | -- T e s t M a n g e r P e r s i s t e n t S t o r a g e
|
---|
1579 | --
|
---|
1580 | -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
|
---|
1581 |
|
---|
1582 | --- @type TestBoxState_T
|
---|
1583 | -- TestBox state.
|
---|
1584 | --
|
---|
1585 | -- @todo Consider drawing a state diagram for this.
|
---|
1586 | --
|
---|
1587 | CREATE TYPE TestBoxState_T AS ENUM (
|
---|
1588 | --- Nothing to do.
|
---|
1589 | -- Prev: testing, gang-cleanup, rebooting, upgrading,
|
---|
1590 | -- upgrading-and-rebooting, doing-special-cmd.
|
---|
1591 | -- Next: testing, gang-gathering, rebooting, upgrading,
|
---|
1592 | -- upgrading-and-rebooting, doing-special-cmd.
|
---|
1593 | 'idle',
|
---|
1594 | --- Executing a test.
|
---|
1595 | -- Prev: idle
|
---|
1596 | -- Next: idle
|
---|
1597 | 'testing',
|
---|
1598 |
|
---|
1599 | -- Gang scheduling statuses:
|
---|
1600 | --- The gathering of a gang.
|
---|
1601 | -- Prev: idle
|
---|
1602 | -- Next: gang-gathering-timedout, gang-testing
|
---|
1603 | 'gang-gathering',
|
---|
1604 | --- The gathering timed out, the testbox needs to cleanup and move on.
|
---|
1605 | -- Prev: gang-gathering
|
---|
1606 | -- Next: idle
|
---|
1607 | -- This is set on all gathered members by the testbox who triggers the
|
---|
1608 | -- timeout.
|
---|
1609 | 'gang-gathering-timedout',
|
---|
1610 | --- The gang scheduling equivalent of 'testing'.
|
---|
1611 | -- Prev: gang-gathering
|
---|
1612 | -- Next: gang-cleanup
|
---|
1613 | 'gang-testing',
|
---|
1614 | --- Waiting for the other gang members to stop testing so that cleanups
|
---|
1615 | -- can be performed and members safely rescheduled.
|
---|
1616 | -- Prev: gang-testing
|
---|
1617 | -- Next: idle
|
---|
1618 | --
|
---|
1619 | -- There are two resource clean up issues being targeted here:
|
---|
1620 | -- 1. Global resources will be allocated by the leader when he enters the
|
---|
1621 | -- 'gang-gathering' state. If the leader quits and frees the resource
|
---|
1622 | -- while someone is still using it, bad things will happen. Imagine a
|
---|
1623 | -- global resource without any access checks and relies exclusivly on
|
---|
1624 | -- the TM doing its job.
|
---|
1625 | -- 2. TestBox resource accessed by other gang members may also be used in
|
---|
1626 | -- other tests. Should a gang member leave early and embark on a
|
---|
1627 | -- testcase using the same resources, bad things will happen. Example:
|
---|
1628 | -- Live migration. One partner leaves early because it detected some
|
---|
1629 | -- fatal failure, the other one is still trying to connect to him.
|
---|
1630 | -- The testbox is scheduled again on the same live migration testcase,
|
---|
1631 | -- only with different arguments (VM config), it will try migrate using
|
---|
1632 | -- the same TCP ports. Confusion ensues.
|
---|
1633 | --
|
---|
1634 | -- To figure out whether to remain in this status because someone is
|
---|
1635 | -- still testing:
|
---|
1636 | -- SELECT COUNT(*) FROM TestBoxStatuses, TestSets
|
---|
1637 | -- WHERE TestSets.idTestSetGangLeader = :idGangLeader
|
---|
1638 | -- AND TestSets.idTestBox = TestBoxStatuses.idTestBox
|
---|
1639 | -- AND TestSets.idTestSet = TestBoxStatuses.idTestSet
|
---|
1640 | -- AND TestBoxStatuses.enmState = 'gang-testing'::TestBoxState_T;
|
---|
1641 | 'gang-cleanup',
|
---|
1642 |
|
---|
1643 | -- Command related statuses (all command status changes comes from 'idle'
|
---|
1644 | -- and goes back to 'idle'):
|
---|
1645 | 'rebooting',
|
---|
1646 | 'upgrading',
|
---|
1647 | 'upgrading-and-rebooting',
|
---|
1648 | 'doing-special-cmd'
|
---|
1649 | );
|
---|
1650 |
|
---|
1651 | --- @table TestBoxStatuses
|
---|
1652 | -- Testbox status table.
|
---|
1653 | --
|
---|
1654 | -- History is not planned on this table.
|
---|
1655 | --
|
---|
1656 | CREATE TABLE TestBoxStatuses (
|
---|
1657 | --- The testbox.
|
---|
1658 | idTestBox INTEGER PRIMARY KEY NOT NULL,
|
---|
1659 | --- The testbox generation ID.
|
---|
1660 | idGenTestBox INTEGER REFERENCES TestBoxes(idGenTestBox) NOT NULL,
|
---|
1661 | --- When this status was last updated.
|
---|
1662 | -- This is updated everytime the testbox talks to the test manager, thus it
|
---|
1663 | -- can easily be used to find testboxes which has stopped responding.
|
---|
1664 | --
|
---|
1665 | -- This is used for timeout calculation during gang-gathering, so in that
|
---|
1666 | -- scenario it won't be updated until the gang is gathered or we time out.
|
---|
1667 | tsUpdated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
|
---|
1668 | --- The current state.
|
---|
1669 | enmState TestBoxState_T DEFAULT 'idle'::TestBoxState_T NOT NULL,
|
---|
1670 | --- Reference to the test set
|
---|
1671 | idTestSet INTEGER REFERENCES TestSets(idTestSet)
|
---|
1672 | );
|
---|
1673 |
|
---|
1674 |
|
---|
1675 | --- @table GlobalResourceStatuses
|
---|
1676 | -- Global resource status, tracks which test set resources are allocated by.
|
---|
1677 | --
|
---|
1678 | -- History is not planned on this table.
|
---|
1679 | --
|
---|
1680 | CREATE TABLE GlobalResourceStatuses (
|
---|
1681 | --- The resource ID.
|
---|
1682 | -- Non-unique foreign key: GlobalResources(idGlobalRsrc).
|
---|
1683 | idGlobalRsrc INTEGER PRIMARY KEY NOT NULL,
|
---|
1684 | --- The resource owner.
|
---|
1685 | -- @note This is going thru testboxstatus to be able to use the testbox ID
|
---|
1686 | -- as a foreign key.
|
---|
1687 | idTestBox INTEGER REFERENCES TestBoxStatuses(idTestBox) NOT NULL,
|
---|
1688 | --- When the allocation took place.
|
---|
1689 | tsAllocated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL
|
---|
1690 | );
|
---|
1691 |
|
---|
1692 |
|
---|
1693 | --- @table SchedQueues
|
---|
1694 | -- Scheduler queue.
|
---|
1695 | --
|
---|
1696 | -- The queues are currently associated with a scheduling group, it could
|
---|
1697 | -- alternative be changed to hook on to a testbox instead. It depends on what
|
---|
1698 | -- kind of scheduling method we prefer. The former method aims at test case
|
---|
1699 | -- thruput, making sacrifices in the hardware distribution area. The latter is
|
---|
1700 | -- more like the old buildbox style testing, making sure that each test case is
|
---|
1701 | -- executed on each testbox.
|
---|
1702 | --
|
---|
1703 | -- When there are configuration changes, TM will regenerate the scheduling
|
---|
1704 | -- queue for the affected scheduling groups. We do not concern ourselves with
|
---|
1705 | -- trying to continue at the approximately same queue position, we simply take
|
---|
1706 | -- it from the top.
|
---|
1707 | --
|
---|
1708 | -- When a testbox ask for work, we will open a cursor on the queue and take the
|
---|
1709 | -- first test in the queue that can be executed on that testbox. The test will
|
---|
1710 | -- be moved to the end of the queue (getting a new item_id).
|
---|
1711 | --
|
---|
1712 | -- If a test is manually changed to the head of the queue, the item will get a
|
---|
1713 | -- item_id which is 1 lower than the head of the queue. Unless someone does
|
---|
1714 | -- this a couple of billion times, we shouldn't have any trouble running out of
|
---|
1715 | -- number space. :-)
|
---|
1716 | --
|
---|
1717 | -- Manually moving a test to the end of the queue is easy, just get a new
|
---|
1718 | -- 'item_id'.
|
---|
1719 | --
|
---|
1720 | -- History is not planned on this table.
|
---|
1721 | --
|
---|
1722 | CREATE SEQUENCE SchedQueueItemIdSeq
|
---|
1723 | START 1
|
---|
1724 | INCREMENT BY 1
|
---|
1725 | NO MAXVALUE
|
---|
1726 | NO MINVALUE
|
---|
1727 | CACHE 1;
|
---|
1728 | CREATE TABLE SchedQueues (
|
---|
1729 | --- The scheduling queue (one queue per scheduling group).
|
---|
1730 | -- Non-unique foreign key: SchedGroups(idSchedGroup)
|
---|
1731 | idSchedGroup INTEGER NOT NULL,
|
---|
1732 | --- The scheduler queue entry ID.
|
---|
1733 | -- Lower numbers means early queue position.
|
---|
1734 | idItem INTEGER DEFAULT NEXTVAL('SchedQueueItemIdSeq') NOT NULL,
|
---|
1735 | --- The queue offset.
|
---|
1736 | -- This is used for repositining the queue when recreating it. It can also
|
---|
1737 | -- be used to figure out how jumbled the queue gets after real life has had
|
---|
1738 | -- it's effect on it.
|
---|
1739 | offQueue INTEGER NOT NULL,
|
---|
1740 | --- The test case argument variation to execute.
|
---|
1741 | idGenTestCaseArgs INTEGER REFERENCES TestCaseArgs(idGenTestCaseArgs) NOT NULL,
|
---|
1742 | --- The relevant testgroup.
|
---|
1743 | -- Non-unique foreign key: TestGroups(idTestGroup).
|
---|
1744 | idTestGroup INTEGER NOT NULL,
|
---|
1745 | --- Aggregated test group dependencies (NULL if none).
|
---|
1746 | -- Non-unique foreign key: TestGroups(idTestGroup).
|
---|
1747 | -- See also comments on SchedGroupMembers.idTestGroupPreReq.
|
---|
1748 | aidTestGroupPreReqs INTEGER ARRAY DEFAULT NULL,
|
---|
1749 | --- The scheduling time constraints (see SchedGroupMembers.bmHourlySchedule).
|
---|
1750 | bmHourlySchedule bit(168) DEFAULT NULL,
|
---|
1751 | --- When the queue entry was created and for which config is valid.
|
---|
1752 | -- This is the timestamp that should be used when reading config info.
|
---|
1753 | tsConfig TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP NOT NULL,
|
---|
1754 | --- When this status was last scheduled.
|
---|
1755 | -- This is set to current_timestamp when moving the entry to the end of the
|
---|
1756 | -- queue. It's initial value is unix-epoch. Not entirely sure if it's
|
---|
1757 | -- useful beyond introspection and non-unique foreign key hacking.
|
---|
1758 | tsLastScheduled TIMESTAMP WITH TIME ZONE DEFAULT TIMESTAMP WITH TIME ZONE 'epoch' NOT NULL,
|
---|
1759 |
|
---|
1760 | --- This is used in gang scheduling.
|
---|
1761 | idTestSetGangLeader INTEGER REFERENCES TestSets(idTestSet) DEFAULT NULL UNIQUE,
|
---|
1762 | --- The number of gang members still missing.
|
---|
1763 | --
|
---|
1764 | -- This saves calculating the number of missing members via selects like:
|
---|
1765 | -- SELECT COUNT(*) FROM TestSets WHERE idTestSetGangLeader = :idGang;
|
---|
1766 | -- and
|
---|
1767 | -- SELECT cGangMembers FROM TestCaseArgs WHERE idGenTestCaseArgs = :idTest;
|
---|
1768 | -- to figure out whether to remain in 'gather-gang'::TestBoxState_T.
|
---|
1769 | --
|
---|
1770 | cMissingGangMembers smallint DEFAULT 1 NOT NULL,
|
---|
1771 |
|
---|
1772 |
|
---|
1773 | PRIMARY KEY (idSchedGroup, idItem)
|
---|
1774 | );
|
---|
1775 | CREATE INDEX SchedQueuesItemIdx ON SchedQueues(idItem);
|
---|
1776 | CREATE INDEX SchedQueuesSchedGroupIdx ON SchedQueues(idSchedGroup);
|
---|
1777 |
|
---|