VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/testmanager/db/TestManagerDatabaseInit.pgsql@ 61407

Last change on this file since 61407 was 61407, checked in by vboxsync, 9 years ago

TestManagerDatabaseInit.pgsql: No need to drop the database, devs can do that themselves if they think they need to.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 75.3 KB
Line 
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
40CREATE 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--
69CREATE 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--
103CREATE SEQUENCE UserIdSeq
104 START 1
105 INCREMENT BY 1
106 NO MAXVALUE
107 NO MINVALUE
108 CACHE 1;
109CREATE 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);
130CREATE 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--
142CREATE SEQUENCE GlobalResourceIdSeq
143 START 1
144 INCREMENT BY 1
145 NO MAXVALUE
146 NO MINVALUE
147 CACHE 1;
148CREATE 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--
183CREATE SEQUENCE BuildSourceIdSeq
184 START 1
185 INCREMENT BY 1
186 NO MAXVALUE
187 NO MINVALUE
188 CACHE 1;
189CREATE 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--
242CREATE SEQUENCE TestCaseIdSeq
243 START 1
244 INCREMENT BY 1
245 NO MAXVALUE
246 NO MINVALUE
247 CACHE 1;
248CREATE SEQUENCE TestCaseGenIdSeq
249 START 1
250 INCREMENT BY 1
251 NO MAXVALUE
252 NO MINVALUE
253 CACHE 1;
254CREATE 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--
353CREATE SEQUENCE TestCaseArgsIdSeq
354 START 1
355 INCREMENT BY 1
356 NO MAXVALUE
357 NO MINVALUE
358 CACHE 1;
359CREATE SEQUENCE TestCaseArgsGenIdSeq
360 START 1
361 INCREMENT BY 1
362 NO MAXVALUE
363 NO MINVALUE
364 CACHE 1;
365CREATE 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);
414CREATE 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--
433CREATE 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--
460CREATE 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--
494CREATE SEQUENCE TestGroupIdSeq
495 START 1
496 INCREMENT BY 1
497 NO MAXVALUE
498 NO MINVALUE
499 CACHE 1;
500CREATE 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);
519CREATE 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--
530CREATE 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--
582CREATE TYPE Scheduler_T AS ENUM (
583 'bestEffortContinousItegration',
584 'reserved'
585);
586CREATE SEQUENCE SchedGroupIdSeq
587 START 2
588 INCREMENT BY 1
589 NO MAXVALUE
590 NO MINVALUE
591 CACHE 1;
592CREATE 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.
626INSERT 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--
646CREATE 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.
684CREATE 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.
696CREATE 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--
722CREATE SEQUENCE TestBoxIdSeq
723 START 1
724 INCREMENT BY 1
725 NO MAXVALUE
726 NO MINVALUE
727 CACHE 1;
728CREATE SEQUENCE TestBoxGenIdSeq
729 START 1
730 INCREMENT BY 1
731 NO MAXVALUE
732 NO MINVALUE
733 CACHE 1;
734CREATE 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);
838CREATE UNIQUE INDEX TestBoxesUuidIdx ON TestBoxes (uuidSystem, tsExpire DESC);
839CREATE 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--
863CREATE SEQUENCE FailureCategoryIdSeq
864 START 1
865 INCREMENT BY 1
866 NO MAXVALUE
867 NO MINVALUE
868 CACHE 1;
869CREATE 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--
903CREATE SEQUENCE FailureReasonIdSeq
904 START 1
905 INCREMENT BY 1
906 NO MAXVALUE
907 NO MINVALUE
908 CACHE 1;
909CREATE 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);
935CREATE 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--
950CREATE 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);
975CREATE INDEX TestResultFailureIdx ON TestResultFailures (idTestSet, tsExpire DESC, tsEffective ASC);
976CREATE INDEX TestResultFailureIdx2 ON TestResultFailures (idTestResult, tsExpire DESC, tsEffective ASC);
977CREATE 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--
1013CREATE SEQUENCE BuildBlacklistIdSeq
1014 START 1
1015 INCREMENT BY 1
1016 NO MAXVALUE
1017 NO MINVALUE
1018 CACHE 1;
1019CREATE 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);
1058CREATE 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--
1070CREATE SEQUENCE BuildCategoryIdSeq
1071 START 1
1072 INCREMENT BY 1
1073 NO MAXVALUE
1074 NO MINVALUE
1075 CACHE 1;
1076CREATE 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--
1129CREATE SEQUENCE BuildIdSeq
1130 START 1
1131 INCREMENT BY 1
1132 NO MAXVALUE
1133 NO MINVALUE
1134 CACHE 1;
1135CREATE 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);
1166CREATE 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--
1185CREATE 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--
1225CREATE SEQUENCE TestResultStrTabIdSeq
1226 START 1
1227 INCREMENT BY 1
1228 NO MAXVALUE
1229 NO MINVALUE
1230 CACHE 1;
1231CREATE 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);
1239CREATE UNIQUE INDEX TestResultStrTabNameIdx ON TestResultStrTab (sValue);
1240
1241--- Empty string with ID 0.
1242INSERT INTO TestResultStrTab (idStr, sValue) VALUES (0, '');
1243
1244
1245--- @type TestStatus_T
1246-- The status of a test (set / result).
1247--
1248CREATE 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--
1283CREATE SEQUENCE TestResultIdSeq
1284 START 1
1285 INCREMENT BY 1
1286 NO MAXVALUE
1287 NO MINVALUE
1288 CACHE 1;
1289CREATE 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
1326CREATE INDEX TestResultsSetIdx ON TestResults (idTestSet, idStrName, idTestResult);
1327CREATE INDEX TestResultsParentIdx ON TestResults (idTestResultParent);
1328-- The TestResultsNameIdx and TestResultsNameIdx2 are for speeding up the result graph & reporting code.
1329CREATE INDEX TestResultsNameIdx ON TestResults (idStrName, tsCreated DESC);
1330CREATE INDEX TestResultsNameIdx2 ON TestResults (idTestResult, idStrName);
1331
1332ALTER 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--
1345CREATE SEQUENCE TestResultValueIdSeq
1346 START 1
1347 INCREMENT BY 1
1348 NO MAXVALUE
1349 NO MINVALUE
1350 CACHE 1;
1351CREATE 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
1372CREATE INDEX TestResultValuesIdx ON TestResultValues(idTestResult);
1373-- The TestResultValuesGraphIdx is for speeding up the result graph & reporting code.
1374CREATE 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--
1389CREATE SEQUENCE TestResultFileId
1390 START 1
1391 INCREMENT BY 1
1392 NO MAXVALUE
1393 NO MINVALUE
1394 CACHE 1;
1395CREATE 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
1424CREATE 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--
1438CREATE TYPE TestResultMsgLevel_T AS ENUM (
1439 'failure',
1440 'info'
1441);
1442CREATE SEQUENCE TestResultMsgIdSeq
1443 START 1
1444 INCREMENT BY 1
1445 NO MAXVALUE
1446 NO MINVALUE
1447 CACHE 1;
1448CREATE 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
1461CREATE 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--
1472CREATE SEQUENCE TestSetIdSeq
1473 START 1
1474 INCREMENT BY 1
1475 NO MAXVALUE
1476 NO MINVALUE
1477 CACHE 1;
1478CREATE 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);
1559CREATE INDEX TestSetsGangIdx ON TestSets (idTestSetGangLeader);
1560CREATE INDEX TestSetsBoxIdx ON TestSets (idTestBox, idTestResult);
1561CREATE INDEX TestSetsBuildIdx ON TestSets (idBuild, idTestResult);
1562CREATE INDEX TestSetsTestCaseIdx ON TestSets (idTestCase, idTestResult);
1563CREATE INDEX TestSetsTestVarIdx ON TestSets (idTestCaseArgs, idTestResult);
1564--- The TestSetsDoneCreatedBuildCatIdx is for testbox results, graph options and such.
1565CREATE INDEX TestSetsDoneCreatedBuildCatIdx ON TestSets (tsDone DESC NULLS FIRST, tsCreated ASC, idBuildCategory);
1566--- For graphs.
1567CREATE INDEX TestSetsGraphBoxIdx ON TestSets (idTestBox, tsCreated DESC, tsDone ASC NULLS LAST, idBuildCategory, idTestCase);
1568
1569ALTER TABLE TestResults ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
1570ALTER TABLE TestResultValues ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
1571ALTER 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--
1587CREATE 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--
1656CREATE 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--
1680CREATE 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--
1722CREATE SEQUENCE SchedQueueItemIdSeq
1723 START 1
1724 INCREMENT BY 1
1725 NO MAXVALUE
1726 NO MINVALUE
1727 CACHE 1;
1728CREATE 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);
1775CREATE INDEX SchedQueuesItemIdx ON SchedQueues(idItem);
1776CREATE INDEX SchedQueuesSchedGroupIdx ON SchedQueues(idSchedGroup);
1777
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette