gexp: #:references-graphs refers to non-native derivations.

Fixes a regression introduced in
c6d6aee6659acb293eb33f498fdac3b47a19a48, where #:reference-graphs would
end up referring to native inputs.

This would notably break the compilation of systems using a childhurd,
because they would attempt to build the 'hurd' package natively.

* guix/gexp.scm (lower-reference-graphs)[tuple->gexp-input]: Honor TARGET.
* tests/gexp.scm ("gexp->derivation #:references-graphs cross-compilation"):
New test.
This commit is contained in:
Ludovic Courtès 2021-03-03 12:27:18 +01:00
parent d9f1752c55
commit 9fc4e94986
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
2 changed files with 18 additions and 2 deletions

View file

@ -875,9 +875,9 @@ (define* (lower-reference-graphs graphs #:key system target)
(define tuple->gexp-input (define tuple->gexp-input
(match-lambda (match-lambda
((thing) ((thing)
(%gexp-input thing "out" #t)) (%gexp-input thing "out" (not target)))
((thing output) ((thing output)
(%gexp-input thing output #t)))) (%gexp-input thing output (not target)))))
(match graphs (match graphs
(((file-names . inputs) ...) (((file-names . inputs) ...)

View file

@ -1095,6 +1095,22 @@ (define (matching-input drv output)
(call-with-input-file g-guile read) (call-with-input-file g-guile read)
(list (derivation->output-path guile-drv) bash)))))) (list (derivation->output-path guile-drv) bash))))))
(test-assertm "gexp->derivation #:references-graphs cross-compilation"
;; The objects passed in #:references-graphs implicitly refer to
;; cross-compiled derivations. Make sure this is the case.
(mlet* %store-monad ((drv1 (lower-object coreutils (%current-system)
#:target "i586-pc-gnu"))
(drv2 (lower-object coreutils (%current-system)
#:target #f))
(drv3 (gexp->derivation "three"
#~(symlink #$coreutils #$output)
#:target "i586-pc-gnu"
#:references-graphs
`(("coreutils" ,coreutils))))
(refs (references* (derivation-file-name drv3))))
(return (and (member (derivation-file-name drv1) refs)
(not (member (derivation-file-name drv2) refs))))))
(test-assertm "gexp->derivation #:allowed-references" (test-assertm "gexp->derivation #:allowed-references"
(mlet %store-monad ((drv (gexp->derivation "allowed-refs" (mlet %store-monad ((drv (gexp->derivation "allowed-refs"
#~(begin #~(begin