mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 21:59:08 -05:00
derivations: Fix 'derivation-prerequisites-to-build' when #:local-build?.
* guix/derivations.scm (derivation-prerequisites-to-build)[derivation-substitutable?]: Call 'substitutable-derivation?'. <body>: When 'substitutable-derivation?' returns #f, add DRV to BUILD.
This commit is contained in:
parent
e6740741d1
commit
d2d0514b58
2 changed files with 32 additions and 3 deletions
|
@ -217,7 +217,8 @@ (define (derivation-built? drv sub-drvs)
|
|||
(every built? (derivation-output-paths drv sub-drvs)))
|
||||
|
||||
(define (derivation-substitutable? drv sub-drvs)
|
||||
(every substitutable? (derivation-output-paths drv sub-drvs)))
|
||||
(and (substitutable-derivation? drv)
|
||||
(every substitutable? (derivation-output-paths drv sub-drvs))))
|
||||
|
||||
(let loop ((drv drv)
|
||||
(sub-drvs outputs)
|
||||
|
@ -230,7 +231,12 @@ (define (derivation-substitutable? drv sub-drvs)
|
|||
(append (derivation-output-paths drv sub-drvs)
|
||||
substitute)))
|
||||
(else
|
||||
(let ((inputs (remove (lambda (i)
|
||||
(let ((build (if (substitutable-derivation? drv)
|
||||
build
|
||||
(cons (make-derivation-input
|
||||
(derivation-file-name drv) sub-drvs)
|
||||
build)))
|
||||
(inputs (remove (lambda (i)
|
||||
(or (member i build) ; XXX: quadratic
|
||||
(input-built? i)
|
||||
(input-substitutable? i)))
|
||||
|
|
|
@ -562,7 +562,6 @@ (define %coreutils
|
|||
;; prerequisite to build because DRV itself is already built.
|
||||
(null? (derivation-prerequisites-to-build %store drv)))))
|
||||
|
||||
(test-skip (if (getenv "GUIX_BINARY_SUBSTITUTE_URL") 0 1))
|
||||
(test-assert "derivation-prerequisites-to-build and substitutes"
|
||||
(let* ((store (open-connection))
|
||||
(drv (build-expression->derivation store "prereq-subst"
|
||||
|
@ -583,6 +582,30 @@ (define %coreutils
|
|||
(null? download*)
|
||||
(null? build*))))))
|
||||
|
||||
(test-assert "derivation-prerequisites-to-build and substitutes, local build"
|
||||
(let* ((store (open-connection))
|
||||
(drv (build-expression->derivation store "prereq-subst-local"
|
||||
(random 1000)
|
||||
;; XXX: Adjust once
|
||||
;; <http://bugs.gnu.org/18747>
|
||||
;; is fixed.
|
||||
#:local-build? #t))
|
||||
(output (derivation->output-path drv)))
|
||||
|
||||
;; Make sure substitutes are usable.
|
||||
(set-build-options store #:use-substitutes? #t)
|
||||
|
||||
(with-derivation-narinfo drv
|
||||
(let-values (((build download)
|
||||
(derivation-prerequisites-to-build store drv)))
|
||||
;; Despite being available as a substitute, DRV will be built locally
|
||||
;; due to #:local-build?.
|
||||
(and (null? download)
|
||||
(match build
|
||||
(((? derivation-input? input))
|
||||
(string=? (derivation-input-path input)
|
||||
(derivation-file-name drv)))))))))
|
||||
|
||||
(test-assert "build-expression->derivation with expression returning #f"
|
||||
(let* ((builder '(begin
|
||||
(mkdir %output)
|
||||
|
|
Loading…
Reference in a new issue