VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/testmanager/db/tmdb-r21-testsets-4.pgsql@ 106061

Last change on this file since 106061 was 106061, checked in by vboxsync, 4 months ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 12.7 KB
Line 
1-- $Id: tmdb-r21-testsets-4.pgsql 106061 2024-09-16 14:03:52Z vboxsync $
2--- @file
3-- VBox Test Manager Database - Adds an idSchedGroup to TestSets in
4-- preparation for testboxes belonging to multiple scheduling queues.
5--
6
7--
8-- Copyright (C) 2013-2024 Oracle and/or its affiliates.
9--
10-- This file is part of VirtualBox base platform packages, as
11-- available from https://www.virtualbox.org.
12--
13-- This program is free software; you can redistribute it and/or
14-- modify it under the terms of the GNU General Public License
15-- as published by the Free Software Foundation, in version 3 of the
16-- License.
17--
18-- This program is distributed in the hope that it will be useful, but
19-- WITHOUT ANY WARRANTY; without even the implied warranty of
20-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21-- General Public License for more details.
22--
23-- You should have received a copy of the GNU General Public License
24-- along with this program; if not, see <https://www.gnu.org/licenses>.
25--
26-- The contents of this file may alternatively be used under the terms
27-- of the Common Development and Distribution License Version 1.0
28-- (CDDL), a copy of it is provided in the "COPYING.CDDL" file included
29-- in the VirtualBox distribution, in which case the provisions of the
30-- CDDL are applicable instead of those of the GPL.
31--
32-- You may elect to license modified versions of this file under the
33-- terms and conditions of either the GPL or the CDDL or both.
34--
35-- SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
36--
37
38--
39-- Cleanup after failed runs.
40--
41DROP TABLE IF EXISTS OldTestSets;
42
43--
44-- Die on error from now on.
45--
46\set ON_ERROR_STOP 1
47\set AUTOCOMMIT 0
48
49
50-- Total grid lock (don't want to deadlock below).
51LOCK TABLE TestBoxStatuses IN ACCESS EXCLUSIVE MODE;
52LOCK TABLE TestSets IN ACCESS EXCLUSIVE MODE;
53LOCK TABLE TestBoxes IN ACCESS EXCLUSIVE MODE;
54LOCK TABLE TestResults IN ACCESS EXCLUSIVE MODE;
55LOCK TABLE TestResultFailures IN ACCESS EXCLUSIVE MODE;
56LOCK TABLE TestResultFiles IN ACCESS EXCLUSIVE MODE;
57LOCK TABLE TestResultMsgs IN ACCESS EXCLUSIVE MODE;
58LOCK TABLE TestResultValues IN ACCESS EXCLUSIVE MODE;
59LOCK TABLE SchedGroups IN ACCESS EXCLUSIVE MODE;
60LOCK TABLE SchedQueues IN ACCESS EXCLUSIVE MODE;
61LOCK TABLE SchedGroupMembers IN ACCESS EXCLUSIVE MODE;
62
63\d+ TestSets;
64
65--
66-- Rename the table, drop foreign keys refering to it, and drop constrains
67-- within the table itself. The latter is mostly for naming and we do it
68-- up front in case the database we're running against has different names
69-- due to previous conversions.
70--
71ALTER TABLE TestSets RENAME TO OldTestSets;
72
73ALTER TABLE TestResultFailures DROP CONSTRAINT IF EXISTS idtestsetfk;
74ALTER TABLE TestResultFailures DROP CONSTRAINT IF EXISTS TestResultFailures_idTestSet_fkey;
75ALTER TABLE SchedQueues DROP CONSTRAINT IF EXISTS SchedQueues_idTestSetGangLeader_fkey;
76ALTER TABLE TestBoxStatuses DROP CONSTRAINT IF EXISTS TestBoxStatuses_idTestSet_fkey;
77ALTER TABLE TestResultFiles DROP CONSTRAINT IF EXISTS TestResultFiles_idTestSet_fkey;
78ALTER TABLE TestResultMsgs DROP CONSTRAINT IF EXISTS TestResultMsgs_idTestSet_fkey;
79ALTER TABLE TestResults DROP CONSTRAINT IF EXISTS TestResults_idTestSet_fkey;
80ALTER TABLE TestResultValues DROP CONSTRAINT IF EXISTS TestResultValues_idTestSet_fkey;
81ALTER TABLE TestResultValues DROP CONSTRAINT IF EXISTS TestResultValues_idTestSet_fkey1;
82
83ALTER TABLE OldTestSets DROP CONSTRAINT testsets_igangmemberno_check;
84
85ALTER TABLE OldTestSets DROP CONSTRAINT TestSets_idBuildCategory_fkey;
86ALTER TABLE OldTestSets DROP CONSTRAINT TestSets_idGenTestBox_fkey;
87ALTER TABLE OldTestSets DROP CONSTRAINT TestSets_idGenTestCase_fkey;
88ALTER TABLE OldTestSets DROP CONSTRAINT TestSets_idGenTestCaseArgs_fkey;
89ALTER TABLE OldTestSets DROP CONSTRAINT TestSets_idTestResult_fkey;
90ALTER TABLE OldTestSets DROP CONSTRAINT TestSets_idTestSetGangLeader_fkey;
91
92ALTER TABLE OldTestSets DROP CONSTRAINT IF EXISTS TestSets_sBaseFilename_key;
93ALTER TABLE OldTestSets DROP CONSTRAINT IF EXISTS NewTestSets_sBaseFilename_key;
94ALTER TABLE OldTestSets DROP CONSTRAINT TestSets_pkey;
95
96DROP INDEX IF EXISTS TestSetsGangIdx;
97DROP INDEX IF EXISTS TestSetsBoxIdx;
98DROP INDEX IF EXISTS TestSetsBuildIdx;
99DROP INDEX IF EXISTS TestSetsTestCaseIdx;
100DROP INDEX IF EXISTS TestSetsTestVarIdx;
101DROP INDEX IF EXISTS TestSetsDoneCreatedBuildCatIdx;
102DROP INDEX IF EXISTS TestSetsGraphBoxIdx;
103
104
105-- This output should be free of indexes, constraints and references from other tables.
106\d+ OldTestSets;
107
108\prompt "Is the above table completely free of indexes, constraints and references? Ctrl-C if not." dummy
109
110--
111-- Create the new table (no foreign keys).
112--
113CREATE TABLE TestSets (
114 --- The ID of this test set.
115 idTestSet INTEGER DEFAULT NEXTVAL('TestSetIdSeq') NOT NULL,
116
117 --- The test config timestamp, used when reading test config.
118 tsConfig TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP NOT NULL,
119 --- When this test set was scheduled.
120 -- idGenTestBox is valid at this point.
121 tsCreated TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP NOT NULL,
122 --- When this test completed, i.e. testing stopped. This should only be set once.
123 tsDone TIMESTAMP WITH TIME ZONE DEFAULT NULL,
124 --- The current status.
125 enmStatus TestStatus_T DEFAULT 'running'::TestStatus_T NOT NULL,
126
127 --- The build we're testing.
128 -- Non-unique foreign key: Builds(idBuild)
129 idBuild INTEGER NOT NULL,
130 --- The build category of idBuild when the test started.
131 -- This is for speeding up graph data collection, i.e. avoid idBuild
132 -- the WHERE part of the selection.
133 idBuildCategory INTEGER NOT NULL,
134 --- The test suite build we're using to do the testing.
135 -- This is NULL if the test suite zip wasn't referred or if a test suite
136 -- build source wasn't configured.
137 -- Non-unique foreign key: Builds(idBuild)
138 idBuildTestSuite INTEGER DEFAULT NULL,
139
140 --- The exact testbox configuration.
141 idGenTestBox INTEGER NOT NULL,
142 --- The testbox ID for joining with (valid: tsStarted).
143 -- Non-unique foreign key: TestBoxes(idTestBox)
144 idTestBox INTEGER NOT NULL,
145 --- The scheduling group ID the test was scheduled thru (valid: tsStarted).
146 -- Non-unique foreign key: SchedGroups(idSchedGroup)
147 idSchedGroup INTEGER NOT NULL,
148
149 --- The testgroup (valid: tsConfig).
150 -- Non-unique foreign key: TestBoxes(idTestGroup)
151 -- Note! This also gives the member ship entry, since a testcase can only
152 -- have one membership per test group.
153 idTestGroup INTEGER NOT NULL,
154
155 --- The exact test case config we executed in this test run.
156 idGenTestCase INTEGER NOT NULL,
157 --- The test case ID for joining with (valid: tsConfig).
158 -- Non-unique foreign key: TestBoxes(idTestCase)
159 idTestCase INTEGER NOT NULL,
160
161 --- The arguments (and requirements++) we executed this test case with.
162 idGenTestCaseArgs INTEGER NOT NULL,
163 --- The argument variation ID (valid: tsConfig).
164 -- Non-unique foreign key: TestCaseArgs(idTestCaseArgs)
165 idTestCaseArgs INTEGER NOT NULL,
166
167 --- The root of the test result tree.
168 -- @note This will only be NULL early in the transaction setting up the testset.
169 -- @note If the test reports more than one top level test result, we'll
170 -- fail the whole test run and let the test developer fix it.
171 idTestResult INTEGER DEFAULT NULL,
172
173 --- The base filename used for storing files related to this test set.
174 -- This is a path relative to wherever TM is dumping log files. In order
175 -- to not become a file system test case, we will try not to put too many
176 -- hundred thousand files in a directory. A simple first approach would
177 -- be to just use the current date (tsCreated) like this:
178 -- TM_FILE_DIR/year/month/day/TestSets.idTestSet
179 --
180 -- The primary log file for the test is this name suffixed by '.log'.
181 --
182 -- The files in the testresultfile table gets their full names like this:
183 -- TM_FILE_DIR/sBaseFilename-testresultfile.id-TestResultStrTab(testresultfile.idStrFilename)
184 --
185 -- @remarks We store this explicitly in case we change the directly layout
186 -- at some later point.
187 sBaseFilename text NOT NULL,
188
189 --- The gang member number number, 0 is the leader.
190 iGangMemberNo SMALLINT DEFAULT 0 NOT NULL, -- CHECK (iGangMemberNo >= 0 AND iGangMemberNo < 1024),
191 --- The test set of the gang leader, NULL if no gang involved.
192 -- @note This is set by the gang leader as well, so that we can find all
193 -- gang members by WHERE idTestSetGangLeader = :id.
194 idTestSetGangLeader INTEGER DEFAULT NULL
195
196);
197
198-- Convert the data.
199INSERT INTO TestSets (
200 idTestSet,
201 tsConfig,
202 tsCreated,
203 tsDone,
204 enmStatus,
205 idBuild,
206 idBuildCategory,
207 idBuildTestSuite,
208 idGenTestBox,
209 idTestBox,
210 idSchedGroup,
211 idTestGroup,
212 idGenTestCase,
213 idTestCase,
214 idGenTestCaseArgs,
215 idTestCaseArgs,
216 idTestResult,
217 sBaseFilename,
218 iGangMemberNo,
219 idTestSetGangLeader
220 )
221SELECT OldTestSets.idTestSet,
222 OldTestSets.tsConfig,
223 OldTestSets.tsCreated,
224 OldTestSets.tsDone,
225 OldTestSets.enmStatus,
226 OldTestSets.idBuild,
227 OldTestSets.idBuildCategory,
228 OldTestSets.idBuildTestSuite,
229 OldTestSets.idGenTestBox,
230 OldTestSets.idTestBox,
231 TestBoxes.idSchedGroup,
232 OldTestSets.idTestGroup,
233 OldTestSets.idGenTestCase,
234 OldTestSets.idTestCase,
235 OldTestSets.idGenTestCaseArgs,
236 OldTestSets.idTestCaseArgs,
237 OldTestSets.idTestResult,
238 OldTestSets.sBaseFilename,
239 OldTestSets.iGangMemberNo,
240 OldTestSets.idTestSetGangLeader
241FROM OldTestSets
242 INNER JOIN TestBoxes
243 ON OldTestSets.idGenTestBox = TestBoxes.idGenTestBox;
244
245-- Restore the primary key and unique constraints.
246ALTER TABLE TestSets ADD PRIMARY KEY (idTestSet);
247ALTER TABLE TestSets ADD UNIQUE (sBaseFilename);
248
249-- Restore check constraints.
250ALTER TABLE TestSets ADD CONSTRAINT TestSets_iGangMemberNo_Check CHECK (iGangMemberNo >= 0 AND iGangMemberNo < 1024);
251
252-- Restore foreign keys in the table.
253ALTER TABLE TestSets ADD FOREIGN KEY (idBuildCategory) REFERENCES BuildCategories(idBuildCategory);
254ALTER TABLE TestSets ADD FOREIGN KEY (idGenTestBox) REFERENCES TestBoxes(idGenTestBox);
255ALTER TABLE TestSets ADD FOREIGN KEY (idGenTestCase) REFERENCES TestCases(idGenTestCase);
256ALTER TABLE TestSets ADD FOREIGN KEY (idGenTestCaseArgs) REFERENCES TestCaseArgs(idGenTestCaseArgs);
257ALTER TABLE TestSets ADD FOREIGN KEY (idTestResult) REFERENCES TestResults(idTestResult);
258ALTER TABLE TestSets ADD FOREIGN KEY (idTestSetGangLeader) REFERENCES TestSets(idTestSet);
259
260-- Restore indexes.
261CREATE INDEX TestSetsGangIdx ON TestSets (idTestSetGangLeader);
262CREATE INDEX TestSetsBoxIdx ON TestSets (idTestBox, idTestResult);
263CREATE INDEX TestSetsBuildIdx ON TestSets (idBuild, idTestResult);
264CREATE INDEX TestSetsTestCaseIdx ON TestSets (idTestCase, idTestResult);
265CREATE INDEX TestSetsTestVarIdx ON TestSets (idTestCaseArgs, idTestResult);
266CREATE INDEX TestSetsDoneCreatedBuildCatIdx ON TestSets (tsDone DESC NULLS FIRST, tsCreated ASC, idBuildCategory);
267CREATE INDEX TestSetsGraphBoxIdx ON TestSets (idTestBox, tsCreated DESC, tsDone ASC NULLS LAST, idBuildCategory, idTestCase);
268
269-- Restore foreign key references to the table.
270ALTER TABLE TestResults ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
271ALTER TABLE TestResultValues ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
272ALTER TABLE TestResultFiles ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
273ALTER TABLE TestResultMsgs ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
274ALTER TABLE TestResultFailures ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
275
276ALTER TABLE TestBoxStatuses ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet) MATCH FULL;
277ALTER TABLE SchedQueues ADD FOREIGN KEY (idTestSetGangLeader) REFERENCES TestSets(idTestSet) MATCH FULL;
278
279-- Drop the old table.
280DROP TABLE OldTestSets;
281
282\prompt "Update python files while everything is locked. Hurry!" dummy
283
284-- Grant access to the new table.
285GRANT ALL PRIVILEGES ON TABLE TestSets TO testmanager;
286
287COMMIT;
288
289\d TestSets;
290
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