mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 21:59:08 -05:00
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:
parent
9be470b5d2
commit
7046e77721
2 changed files with 28 additions and 4 deletions
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue