aboutsummaryrefslogtreecommitdiff
path: root/bin
diff options
context:
space:
mode:
authorMathieu Lirzin <mthl@gnu.org>2016-06-12 00:28:21 +0200
committerMathieu Lirzin <mthl@gnu.org>2016-06-13 18:10:14 +0200
commitb4c615fb732ee48b18a513a0e284bbfd789e875c (patch)
tree5eec88582815660b5ba944805b58c4bff007d6b6 /bin
parent64c64d8d7158e29a09e579be113bfe5e9681cd5d (diff)
downloadcuirass-b4c615fb732ee48b18a513a0e284bbfd789e875c.tar
cuirass-b4c615fb732ee48b18a513a0e284bbfd789e875c.tar.gz
cuirass: Use always the same connection to the store.
* bin/cuirass.in (evaluate): Add STORE argument. Move 'open-connection' call to ... (main): ... here.
Diffstat (limited to 'bin')
-rw-r--r--bin/cuirass.in52
1 files changed, 26 insertions, 26 deletions
diff --git a/bin/cuirass.in b/bin/cuirass.in
index d3d585a..8244e3a 100644
--- a/bin/cuirass.in
+++ b/bin/cuirass.in
@@ -82,7 +82,7 @@ DIR if required."
((guix-variable 'derivations 'build-derivations) store (list drv))))
jobs))
-(define (evaluate dir spec)
+(define (evaluate store dir spec)
"Evaluate and build package derivations in directory DIR."
(save-module-excursion
(lambda ()
@@ -91,25 +91,19 @@ DIR if required."
(format #t "prepending ~s to the load path~%" guixdir)
(set! %load-path (cons guixdir %load-path)))
(primitive-load spec)))
- (let ((store ((guix-variable 'store 'open-connection))))
- (dynamic-wind
- (const #t)
- (lambda ()
- ((guix-variable 'store 'set-build-options) store
- #:use-substitutes? #f)
- (build-packages
- store
- (match ((module-ref %user-module 'hydra-jobs) store '())
- (((names . thunks) ...)
- (map (lambda (job thunk)
- (format (current-error-port) "evaluating '~a'... " job)
- (force-output (current-error-port))
- (make-job (symbol->string job)
- (assoc-ref (call-with-time-display thunk)
- 'derivation)))
- names thunks)))))
- (lambda ()
- ((guix-variable 'store 'close-connection) store)))))
+ ((guix-variable 'store 'set-build-options) store
+ #:use-substitutes? #f)
+ (build-packages
+ store
+ (match ((module-ref %user-module 'hydra-jobs) store '())
+ (((names . thunks) ...)
+ (map (lambda (job thunk)
+ (format (current-error-port) "evaluating '~a'... " job)
+ (force-output (current-error-port))
+ (make-job (symbol->string job)
+ (assoc-ref (call-with-time-display thunk)
+ 'derivation)))
+ names thunks)))))
;;;
@@ -127,13 +121,19 @@ DIR if required."
(show-version progname)
(exit 0))
(else
- (let* ((jobfile (option-ref opts 'file "tests/gnu-system.scm"))
+ (let* ((store ((guix-variable 'store 'open-connection)))
+ (jobfile (option-ref opts 'file "tests/gnu-system.scm"))
(args (option-ref opts '() #f))
(cachedir (if (null? args)
(getenv "CUIRASS_CACHEDIR")
(car args))))
- (while #t
- (pull-changes cachedir)
- (compile cachedir)
- (evaluate cachedir jobfile)
- (sleep (string->number (option-ref opts 'interval "60")))))))))
+ (dynamic-wind
+ (const #t)
+ (lambda ()
+ (while #t
+ (pull-changes cachedir)
+ (compile cachedir)
+ (evaluate store cachedir jobfile)
+ (sleep (string->number (option-ref opts 'interval "60")))))
+ (lambda ()
+ ((guix-variable 'store 'close-connection) store))))))))