system: <operating-system> compiler truly honors the 'system' argument.

Fixes <https://issues.guix.gnu.org/55951>.

* gnu/system.scm (operating-system-compiler): Parameterize
'%current-system' and '%current-target-system' before calling
'operating-system-derivation'.
* tests/system.scm ("lower-object, %current-system sensitivity"): New
test.
This commit is contained in:
Ludovic Courtès 2022-06-14 08:55:03 +02:00
parent 9be470b5d2
commit 7046e77721
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
2 changed files with 28 additions and 4 deletions

View file

@ -1582,8 +1582,13 @@ (define-gexp-compiler (operating-system-compiler (os <operating-system>)
(lambda (store) (lambda (store)
;; XXX: This is not super elegant but we can't pass SYSTEM and TARGET to ;; XXX: This is not super elegant but we can't pass SYSTEM and TARGET to
;; 'operating-system-derivation'. ;; 'operating-system-derivation'.
(run-with-store store (operating-system-derivation os) (parameterize ((%current-system system)
#:system system (%current-target-system target))
#:target target))))) (run-with-store store
(mbegin %store-monad
(set-guile-for-build (default-guile))
(operating-system-derivation os))
#:system system
#:target target))))))
;;; system.scm ends here ;;; system.scm ends here

View file

@ -1,5 +1,5 @@
;;; GNU Guix --- Functional package management for GNU ;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2016, 2018 Ludovic Courtès <ludo@gnu.org> ;;; Copyright © 2016, 2018, 2022 Ludovic Courtès <ludo@gnu.org>
;;; Copyright © 2017 Tobias Geerinckx-Rice <me@tobias.gr> ;;; Copyright © 2017 Tobias Geerinckx-Rice <me@tobias.gr>
;;; ;;;
;;; This file is part of GNU Guix. ;;; This file is part of GNU Guix.
@ -21,6 +21,10 @@ (define-module (test-system)
#:use-module (gnu) #:use-module (gnu)
#:use-module ((gnu services) #:select (service-value)) #:use-module ((gnu services) #:select (service-value))
#:use-module (guix store) #:use-module (guix store)
#:use-module (guix monads)
#:use-module ((guix gexp) #:select (lower-object))
#:use-module ((guix utils) #:select (%current-system))
#:use-module (guix grafts)
#:use-module (srfi srfi-1) #:use-module (srfi srfi-1)
#:use-module (srfi srfi-64)) #:use-module (srfi srfi-64))
@ -64,6 +68,8 @@ (define %os-with-mapped-device
%base-file-systems)) %base-file-systems))
(users %base-user-accounts))) (users %base-user-accounts)))
(%graft? #f)
(test-begin "system") (test-begin "system")
@ -140,4 +146,17 @@ (define %os-with-mapped-device
(type "ext4") (type "ext4")
(dependencies (list %luks-device)))))))))) (dependencies (list %luks-device))))))))))
(test-assert "lower-object, %current-system sensitivity"
;; Make sure that 'lower-object' returns the same derivation, no matter what
;; '%current-system' is. See <https://issues.guix.gnu.org/55951>.
(let ((drv1 (with-store store
(parameterize ((%current-system "x86_64-linux"))
(run-with-store store
(lower-object %os "aarch64-linux")))))
(drv2 (with-store store
(parameterize ((%current-system "aarch64-linux"))
(run-with-store store
(lower-object %os "aarch64-linux"))))))
(eq? drv1 drv2)))
(test-end) (test-end)