mirror of
git://git.savannah.gnu.org/guix/guix-cuirass.git
synced 2024-12-29 11:40:16 +01:00
schema: Evaluations: Add 'revision' column.
* src/schema.sql (Evaluations): Add 'revision' column. * src/cuirass/database.scm (db-add-evaluation): Adapt. All callers changed.
This commit is contained in:
parent
ad267dc86a
commit
ac4512897c
5 changed files with 18 additions and 12 deletions
|
@ -60,8 +60,10 @@ exec ${GUILE:-@GUILE@} --no-auto-compile -e main -s "$0" "$@"
|
|||
(let* ((proc (module-ref %user-module 'hydra-jobs))
|
||||
(thunks (proc store (assq-ref spec #:arguments)))
|
||||
(db (db-open))
|
||||
(spec-id (assq-ref spec #:id))
|
||||
(eval-id (db-add-evaluation db spec-id)))
|
||||
(commit (assq-ref spec #:current-commit))
|
||||
(eval `((#:specification . ,(assq-ref spec #:id))
|
||||
(#:revision . ,commit)))
|
||||
(eval-id (db-add-evaluation db eval)))
|
||||
(pretty-print
|
||||
(map (λ (thunk)
|
||||
(let* ((job (call-with-time-display thunk))
|
||||
|
|
|
@ -147,7 +147,8 @@ if required."
|
|||
(compile (string-append (%package-cachedir) "/"
|
||||
(assq-ref spec #:name)))
|
||||
(with-store store
|
||||
(let ((jobs (evaluate store db spec)))
|
||||
(let* ((spec* (acons #:current-commit commit spec))
|
||||
(jobs (evaluate store db spec*)))
|
||||
(set-build-options store #:use-substitutes? #f)
|
||||
(build-packages store db jobs))))
|
||||
(db-add-stamp db spec commit)))
|
||||
|
|
|
@ -155,9 +155,11 @@ INSERT INTO Derivations (derivation, job_name, evaluation)\
|
|||
"Retrieve a job in database DB which corresponds to ID."
|
||||
(car (sqlite-exec db "SELECT * FROM Derivations WHERE derivation='~A';" id)))
|
||||
|
||||
(define (db-add-evaluation db spec-id)
|
||||
(sqlite-exec db "INSERT INTO Evaluations (specification) VALUES ('~A');"
|
||||
spec-id)
|
||||
(define (db-add-evaluation db eval)
|
||||
(sqlite-exec db "\
|
||||
INSERT INTO Evaluations (specification, revision) VALUES ('~A', '~A');"
|
||||
(assq-ref eval #:specification)
|
||||
(assq-ref eval #:revision))
|
||||
(last-insert-rowid db))
|
||||
|
||||
(define-syntax-rule (with-database db body ...)
|
||||
|
|
|
@ -23,6 +23,7 @@ CREATE TABLE Stamps (
|
|||
CREATE TABLE Evaluations (
|
||||
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
||||
specification INTEGER NOT NULL,
|
||||
revision TEXT NOT NULL,
|
||||
FOREIGN KEY (specification) REFERENCES Specifications (id)
|
||||
);
|
||||
|
||||
|
|
|
@ -59,12 +59,12 @@
|
|||
|
||||
(test-assert "sqlite-exec"
|
||||
(begin
|
||||
(sqlite-exec (%db)
|
||||
"INSERT INTO Evaluations (specification) VALUES (1);")
|
||||
(sqlite-exec (%db)
|
||||
"INSERT INTO Evaluations (specification) VALUES (2);")
|
||||
(sqlite-exec (%db)
|
||||
"INSERT INTO Evaluations (specification) VALUES (3);")
|
||||
(sqlite-exec (%db) "\
|
||||
INSERT INTO Evaluations (specification, revision) VALUES (1, 1);")
|
||||
(sqlite-exec (%db) "\
|
||||
INSERT INTO Evaluations (specification, revision) VALUES (2, 2);")
|
||||
(sqlite-exec (%db) "\
|
||||
INSERT INTO Evaluations (specification, revision) VALUES (3, 3);")
|
||||
(sqlite-exec (%db) "SELECT * FROM Evaluations;")))
|
||||
|
||||
(test-equal "db-add-specification"
|
||||
|
|
Loading…
Reference in a new issue