VirtualBox

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

Last change on this file since 55341 was 52776, checked in by vboxsync, 10 years ago

fix OSE

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