File: 10-create-schema.sql

package info (click to toggle)
sqlite3-pcre2 0.1.1~git20220105-e3e02a4a-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 144 kB
  • sloc: sh: 193; ansic: 134; sql: 103; makefile: 58
file content (52 lines) | stat: -rw-r--r-- 2,247 bytes parent folder | download | duplicates (2)
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
DROP TABLE IF EXISTS testcase;
CREATE TABLE `testcase` (
    `id` INTEGER PRIMARY KEY,
    -- Contains an SQL pattern expression.
    -- The SQL pattern uses the printf convention. Literal '%' shall be escaped with '%%'.
    -- The first occurence of %s is replaced by the ID of the testreport.
    -- In case of crash test, the expression may crash.
    -- Returns: a scalar value that will be stored in testreport.report_value.
    -- Example:
    --      '%s LIKE ''1%%'''   -- return 1 if the testreport ID starts with a 1
    `execute_sql` TEXT NOT NULL,
    -- Contains an SQL pattern expression.
    -- The SQL pattern uses the printf convention. Literal '%' shall be escaped with '%%'.
    -- The first occurence of %s is replaced by the ID of the testreport.
    -- The expression shall not crash.
    -- Returns: a scalar boolean value that will be stored in testreport.evaluation
    -- Example:
    --      '%s LIKE ''1%%'''   -- return 1 if the testreport ID starts with a 1
    `evaluate_sql` TEXT NOT NULL,
    -- Name of the table that contains more information about the testcase.
    `src_table` TEXT,
    -- ID in the table src_table linking to the row that originates the testcase.
    `src_id`,
    `description` TEXT
);

DROP TABLE IF EXISTS testcampaign;
CREATE TABLE `testcampaign` (
    id INTEGER PRIMARY KEY,
    -- Julian day that identifies the begining of the test campaign.
    started_at FLOAT,
    -- Julian day that identifies the end of the test campaign.
    ended_at FLOAT,
    -- Text that identify the library that was used for the test.
    lib TEXT
);

DROP TABLE IF EXISTS testreport;
CREATE TABLE testreport (
    `id` INTEGER PRIMARY KEY,
    `testcase` INTEGER NOT NULL REFERENCES testcase,
    `testcampaign` INTEGER NOT NULL REFERENCES testcampaign,
    -- Standard error that is returned by SQLite after the execution of testcase.execute_sql
    `stderr`,
    -- Exit code that is returned by SQLite after the execution of testcase.execute_sql
    `exit_code` INTEGER,
    -- Value that is returned by the execution of testcase.execute_sql.
    `report_value`,
    -- Value that is returned by the execution of testcase.evaluate_sql.
    `evaluation` INTEGER,
    UNIQUE (testcase, testcampaign)
);