-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathschema.sql
64 lines (56 loc) · 2.08 KB
/
schema.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/*-
* Copyright (c) 2021-2022, 2024
* Benny Siegert <[email protected]>
*
* Provided that these terms and disclaimer and all copyright notices
* are retained or reproduced in an accompanying document, permission
* is granted to deal in this work without restriction, including un-
* limited rights to use, publicly perform, distribute, sell, modify,
* merge, give away, or sublicence.
*
* This work is provided "AS IS" and WITHOUT WARRANTY of any kind, to
* the utmost extent permitted by applicable law, neither express nor
* implied; without malicious intent or gross negligence. In no event
* may a licensor, author or contributor be held liable for indirect,
* direct, other damage, loss, or other issues arising in any way out
* of dealing in the work, even if advised of the possibility of such
* damage or existence of a defect, except proven that it results out
* of said person's immediate fault when using the work as intended.
*/
CREATE TABLE IF NOT EXISTS builds (
build_id INTEGER PRIMARY KEY ASC,
platform text NOT NULL,
build_ts timestamp NOT NULL,
branch text NOT NULL,
compiler text NOT NULL,
build_user text NOT NULL,
report_url text NOT NULL,
num_ok INTEGER NOT NULL,
num_prefailed INTEGER NOT NULL,
num_failed INTEGER NOT NULL,
num_indirect_failed INTEGER NOT NULL,
num_indirect_prefailed INTEGER NOT NULL,
last_error text
);
-- Schema update:
-- ALTER TABLE builds ADD COLUMN last_error text;
CREATE TABLE IF NOT EXISTS pkgs (
pkg_id INTEGER PRIMARY KEY ASC,
category text NOT NULL,
dir text NOT NULL,
UNIQUE (category, dir)
);
CREATE VIEW IF NOT EXISTS pkgpaths (
pkgpath
) AS SELECT (category || dir) AS pkgpath FROM pkgs;
CREATE TABLE IF NOT EXISTS results (
result_id INTEGER PRIMARY KEY ASC,
build_id INTEGER REFERENCES builds,
pkg_id INTEGER REFERENCES pkgs,
pkg_name text NOT NULL,
build_status INTEGER NOT NULL,
failed_deps text NOT NULL,
breaks INTEGER NOT NULL
);
CREATE INDEX results_i_build_pkg ON results (build_id, pkg_id);
CREATE INDEX pkg_id ON results (pkg_id);