]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/kyua/store/schema_v1.sql
Import the kyua test framework.
[FreeBSD/FreeBSD.git] / contrib / kyua / store / schema_v1.sql
1 -- Copyright 2011 The Kyua Authors.
2 -- All rights reserved.
3 --
4 -- Redistribution and use in source and binary forms, with or without
5 -- modification, are permitted provided that the following conditions are
6 -- met:
7 --
8 -- * Redistributions of source code must retain the above copyright
9 --   notice, this list of conditions and the following disclaimer.
10 -- * Redistributions in binary form must reproduce the above copyright
11 --   notice, this list of conditions and the following disclaimer in the
12 --   documentation and/or other materials provided with the distribution.
13 -- * Neither the name of Google Inc. nor the names of its contributors
14 --   may be used to endorse or promote products derived from this software
15 --   without specific prior written permission.
16 --
17 -- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18 -- "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19 -- LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20 -- A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21 -- OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22 -- SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23 -- LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 -- DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 -- THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 -- (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27 -- OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
29 -- \file store/schema_v1.sql
30 -- Definition of the database schema.
31 --
32 -- The whole contents of this file are wrapped in a transaction.  We want
33 -- to ensure that the initial contents of the database (the table layout as
34 -- well as any predefined values) are written atomically to simplify error
35 -- handling in our code.
36
37
38 BEGIN TRANSACTION;
39
40
41 -- -------------------------------------------------------------------------
42 -- Metadata.
43 -- -------------------------------------------------------------------------
44
45
46 -- Database-wide properties.
47 --
48 -- Rows in this table are immutable: modifying the metadata implies writing
49 -- a new record with a larger timestamp value, and never updating previous
50 -- records.  When extracting data from this table, the only "valid" row is
51 -- the one with the highest timestamp.  All the other rows are meaningless.
52 --
53 -- In other words, this table keeps the history of the database metadata.
54 -- The only reason for doing this is for debugging purposes.  It may come
55 -- in handy to know when a particular database-wide operation happened if
56 -- it turns out that the database got corrupted.
57 CREATE TABLE metadata (
58     timestamp TIMESTAMP PRIMARY KEY CHECK (timestamp >= 0),
59     schema_version INTEGER NOT NULL CHECK (schema_version >= 1)
60 );
61
62
63 -- -------------------------------------------------------------------------
64 -- Contexts.
65 -- -------------------------------------------------------------------------
66
67
68 -- Execution contexts.
69 --
70 -- A context represents the execution environment of a particular action.
71 -- Because every action is invoked by the user, the context may have
72 -- changed.  We record such information for information and debugging
73 -- purposes.
74 CREATE TABLE contexts (
75     context_id INTEGER PRIMARY KEY AUTOINCREMENT,
76     cwd TEXT NOT NULL
77
78     -- TODO(jmmv): Record the run-time configuration.
79 );
80
81
82 -- Environment variables of a context.
83 CREATE TABLE env_vars (
84     context_id INTEGER REFERENCES contexts,
85     var_name TEXT NOT NULL,
86     var_value TEXT NOT NULL,
87
88     PRIMARY KEY (context_id, var_name)
89 );
90
91
92 -- -------------------------------------------------------------------------
93 -- Actions.
94 -- -------------------------------------------------------------------------
95
96
97 -- Representation of user-initiated actions.
98 --
99 -- An action is an operation initiated by the user.  At the moment, the
100 -- only operation Kyua supports is the "test" operation (in the future we
101 -- should be able to store, e.g. build logs).  To keep things simple the
102 -- database schema is restricted to represent one single action.
103 CREATE TABLE actions (
104     action_id INTEGER PRIMARY KEY AUTOINCREMENT,
105     context_id INTEGER REFERENCES contexts
106 );
107
108
109 -- -------------------------------------------------------------------------
110 -- Test suites.
111 --
112 -- The tables in this section represent all the components that form a test
113 -- suite.  This includes data about the test suite itself (test programs
114 -- and test cases), and also the data about particular runs (test results).
115 --
116 -- As you will notice, every object belongs to a particular action, has a
117 -- unique identifier and there is no attempt to deduplicate data.  This
118 -- comes from the fact that a test suite is not "stable" over time: i.e. on
119 -- each execution of the test suite, test programs and test cases may have
120 -- come and gone.  This has the interesting result of making the
121 -- distinction of a test case and a test result a pure syntactic
122 -- difference, because there is always a 1:1 relation.
123 --
124 -- The code that performs the processing of the actions is the component in
125 -- charge of finding correlations between test programs and test cases
126 -- across different actions.
127 -- -------------------------------------------------------------------------
128
129
130 -- Representation of a test program.
131 --
132 -- At the moment, there are no substantial differences between the
133 -- different interfaces, so we can simplify the design by with having a
134 -- single table representing all test caes.  We may need to revisit this in
135 -- the future.
136 CREATE TABLE test_programs (
137     test_program_id INTEGER PRIMARY KEY AUTOINCREMENT,
138     action_id INTEGER REFERENCES actions,
139
140     -- The absolute path to the test program.  This should not be necessary
141     -- because it is basically the concatenation of root and relative_path.
142     -- However, this allows us to very easily search for test programs
143     -- regardless of where they were executed from.  (I.e. different
144     -- combinations of root + relative_path can map to the same absolute path).
145     absolute_path NOT NULL,
146
147     -- The path to the root of the test suite (where the Kyuafile lives).
148     root TEXT NOT NULL,
149
150     -- The path to the test program, relative to the root.
151     relative_path NOT NULL,
152
153     -- Name of the test suite the test program belongs to.
154     test_suite_name TEXT NOT NULL,
155
156     -- The name of the test program interface.
157     --
158     -- Note that this indicates both the interface for the test program and
159     -- its test cases.  See below for the corresponding detail tables.
160     interface TEXT NOT NULL
161 );
162
163
164 -- Representation of a test case.
165 --
166 -- At the moment, there are no substantial differences between the
167 -- different interfaces, so we can simplify the design by with having a
168 -- single table representing all test caes.  We may need to revisit this in
169 -- the future.
170 CREATE TABLE test_cases (
171     test_case_id INTEGER PRIMARY KEY AUTOINCREMENT,
172     test_program_id INTEGER REFERENCES test_programs,
173     name TEXT NOT NULL
174 );
175
176
177 -- Representation of test case results.
178 --
179 -- Note that there is a 1:1 relation between test cases and their results.
180 -- This is a result of storing the information of a test case on every
181 -- single action.
182 CREATE TABLE test_results (
183     test_case_id INTEGER PRIMARY KEY REFERENCES test_cases,
184     result_type TEXT NOT NULL,
185     result_reason TEXT,
186
187     start_time TIMESTAMP NOT NULL,
188     end_time TIMESTAMP NOT NULL
189 );
190
191
192 -- Collection of output files of the test case.
193 CREATE TABLE test_case_files (
194     test_case_id INTEGER NOT NULL REFERENCES test_cases,
195
196     -- The raw name of the file.
197     --
198     -- The special names '__STDOUT__' and '__STDERR__' are reserved to hold
199     -- the stdout and stderr of the test case, respectively.  If any of
200     -- these are empty, there will be no corresponding entry in this table
201     -- (hence why we do not allow NULLs in these fields).
202     file_name TEXT NOT NULL,
203
204     -- Pointer to the file itself.
205     file_id INTEGER NOT NULL REFERENCES files,
206
207     PRIMARY KEY (test_case_id, file_name)
208 );
209
210
211 -- -------------------------------------------------------------------------
212 -- Detail tables for the 'atf' test interface.
213 -- -------------------------------------------------------------------------
214
215
216 -- Properties specific to 'atf' test cases.
217 --
218 -- This table contains the representation of singly-valued properties such
219 -- as 'timeout'.  Properties that can have more than one (textual) value
220 -- are stored in the atf_test_cases_multivalues table.
221 --
222 -- Note that all properties can be NULL because test cases are not required
223 -- to define them.
224 CREATE TABLE atf_test_cases (
225     test_case_id INTEGER PRIMARY KEY REFERENCES test_cases,
226
227     -- Free-form description of the text case.
228     description TEXT,
229
230     -- Either 'true' or 'false', indicating whether the test case has a
231     -- cleanup routine or not.
232     has_cleanup TEXT,
233
234     -- The timeout for the test case in microseconds.
235     timeout INTEGER,
236
237     -- The amount of physical memory required by the test case.
238     required_memory INTEGER,
239
240     -- Either 'root' or 'unprivileged', indicating the privileges required by
241     -- the test case.
242     required_user TEXT
243 );
244
245
246 -- Representation of test case properties that have more than one value.
247 --
248 -- While we could store the flattened values of the properties as provided
249 -- by the test case itself, we choose to store the processed, split
250 -- representation.  This allows us to perform queries about the test cases
251 -- directly on the database without doing text processing; for example,
252 -- "get all test cases that require /bin/ls".
253 CREATE TABLE atf_test_cases_multivalues (
254     test_case_id INTEGER REFERENCES test_cases,
255
256     -- The name of the property; for example, 'require.progs'.
257     property_name TEXT NOT NULL,
258
259     -- One of the values of the property.
260     property_value TEXT NOT NULL
261 );
262
263
264 -- -------------------------------------------------------------------------
265 -- Detail tables for the 'plain' test interface.
266 -- -------------------------------------------------------------------------
267
268
269 -- Properties specific to 'plain' test programs.
270 CREATE TABLE plain_test_programs (
271     test_program_id INTEGER PRIMARY KEY REFERENCES test_programs,
272
273     -- The timeout for the test cases in this test program.  While this
274     -- setting has a default value for test programs, we explicitly record
275     -- the information here.  The "default value" used when the test
276     -- program was run might change over time, so we want to know what it
277     -- was exactly when this was run.
278     timeout INTEGER NOT NULL
279 );
280
281
282 -- -------------------------------------------------------------------------
283 -- Verbatim files.
284 -- -------------------------------------------------------------------------
285
286
287 -- Copies of files or logs generated during testing.
288 --
289 -- TODO(jmmv): This will probably grow to unmanageable sizes.  We should add a
290 -- hash to the file contents and use that as the primary key instead.
291 CREATE TABLE files (
292     file_id INTEGER PRIMARY KEY,
293
294     contents BLOB NOT NULL
295 );
296
297
298 -- -------------------------------------------------------------------------
299 -- Initialization of values.
300 -- -------------------------------------------------------------------------
301
302
303 -- Create a new metadata record.
304 --
305 -- For every new database, we want to ensure that the metadata is valid if
306 -- the database creation (i.e. the whole transaction) succeeded.
307 --
308 -- If you modify the value of the schema version in this statement, you
309 -- will also have to modify the version encoded in the backend module.
310 INSERT INTO metadata (timestamp, schema_version)
311     VALUES (strftime('%s', 'now'), 1);
312
313
314 COMMIT TRANSACTION;