hydra: evaluate: Add the checkout to the store.

* build-aux/hydra/evaluate.scm <top level>: Add call to 'add-to-store'.
Use that as the 'file-name' attribute.  Call 'primitive-load' in a
directory excursion to SOURCE.
This commit is contained in:
Ludovic Courtès 2018-11-26 15:49:11 +01:00
parent 59fb5c1cdb
commit 65ff85dcee
No known key found for this signature in database
GPG Key ID: 090B11993D9AEBB5
1 changed files with 33 additions and 22 deletions

View File

@ -22,6 +22,8 @@
;;; arguments and outputs an sexp of the jobs on standard output. ;;; arguments and outputs an sexp of the jobs on standard output.
(use-modules (guix store) (use-modules (guix store)
(guix git-download)
((guix build utils) #:select (with-directory-excursion))
(srfi srfi-19) (srfi srfi-19)
(ice-9 match) (ice-9 match)
(ice-9 pretty-print) (ice-9 pretty-print)
@ -81,11 +83,6 @@ Otherwise return THING."
;; Load FILE, a Scheme file that defines Hydra jobs. ;; Load FILE, a Scheme file that defines Hydra jobs.
(let ((port (current-output-port)) (let ((port (current-output-port))
(real-build-things build-things)) (real-build-things build-things))
(save-module-excursion
(lambda ()
(set-current-module %user-module)
(primitive-load file)))
(with-store store (with-store store
;; Make sure we don't resort to substitutes. ;; Make sure we don't resort to substitutes.
(set-build-options store (set-build-options store
@ -104,6 +101,20 @@ Otherwise return THING."
"'build-things' arguments: ~s~%" args) "'build-things' arguments: ~s~%" args)
(apply real-build-things store args))) (apply real-build-things store args)))
;; Add %TOP-SRCDIR to the store with a proper Git predicate so we work
;; from a clean checkout
(let ((source (add-to-store store "guix-source" #t
"sha256" %top-srcdir
#:select? (git-predicate %top-srcdir))))
(with-directory-excursion source
(save-module-excursion
(lambda ()
(set-current-module %user-module)
(format (current-error-port)
"loading '~a' relative to '~a'...~%"
file source)
(primitive-load file))))
;; Call the entry point of FILE and print the resulting job sexp. ;; Call the entry point of FILE and print the resulting job sexp.
(pretty-print (pretty-print
(match ((module-ref %user-module (match ((module-ref %user-module
@ -111,7 +122,7 @@ Otherwise return THING."
'cuirass-jobs 'cuirass-jobs
'hydra-jobs)) 'hydra-jobs))
store `((guix store `((guix
. ((file-name . ,%top-srcdir))))) . ((file-name . ,source)))))
(((names . thunks) ...) (((names . thunks) ...)
(map (lambda (job thunk) (map (lambda (job thunk)
(format (current-error-port) "evaluating '~a'... " job) (format (current-error-port) "evaluating '~a'... " job)
@ -120,7 +131,7 @@ Otherwise return THING."
(assert-valid-job job (assert-valid-job job
(call-with-time-display thunk)))) (call-with-time-display thunk))))
names thunks))) names thunks)))
port)))) port)))))
((command _ ...) ((command _ ...)
(format (current-error-port) "Usage: ~a FILE [cuirass] (format (current-error-port) "Usage: ~a FILE [cuirass]
Evaluate the Hydra or Cuirass jobs defined in FILE.~%" Evaluate the Hydra or Cuirass jobs defined in FILE.~%"