hydra: 'evaluate' now validates job alists.

* build-aux/hydra/evaluate.scm (assert-valid-job): New procedure.
<top level>: Use it.
This commit is contained in:
Ludovic Courtès 2016-06-21 15:50:51 +02:00
parent 9270298f75
commit 4c9243b688
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5

View file

@ -49,6 +49,17 @@ (define (call-with-time-display thunk)
(/ (time-nanosecond time) 1e9)))
(apply values results))))
(define (assert-valid-job job thing)
"Raise an error if THING is not an alist with a valid 'derivation' entry.
Otherwise return THING."
(unless (and (list? thing)
(and=> (assoc-ref thing 'derivation)
(lambda (value)
(and (string? value)
(string-suffix? ".drv" value)))))
(error "job did not produce a valid alist" job thing))
thing)
;; Without further ado...
(match (command-line)
@ -83,7 +94,9 @@ (define (call-with-time-display thunk)
(map (lambda (job thunk)
(format (current-error-port) "evaluating '~a'... " job)
(force-output (current-error-port))
(cons job (call-with-time-display thunk)))
(cons job
(assert-valid-job job
(call-with-time-display thunk))))
names thunks)))
port))))
((command _ ...)