mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
pack: 'squashfs' backend records the profile's search paths.
* guix/scripts/pack.scm (singularity-environment-file): New procedure. (squashfs-image): Use it, and create /.singularity/env/90-environment.sh. * gnu/tests/singularity.scm (run-singularity-test)["singularity run, with environment"]: New test, currently skipped. * gnu/tests/singularity.scm (build-tarball&run-singularity-test): Add GUILE-JSON to the profile.
This commit is contained in:
parent
b9fcf0c82a
commit
dea62932bc
2 changed files with 57 additions and 2 deletions
|
@ -111,6 +111,21 @@ (define marionette
|
||||||
"run" #$image "-c" "(exit 42)"))
|
"run" #$image "-c" "(exit 42)"))
|
||||||
marionette))
|
marionette))
|
||||||
|
|
||||||
|
;; FIXME: Singularity 2.x doesn't directly honor
|
||||||
|
;; /.singularity.d/env/*.sh. Instead, you have to load those files
|
||||||
|
;; manually, which we don't do. Remove 'test-skip' call once we've
|
||||||
|
;; switch to Singularity 3.x.
|
||||||
|
(test-skip 1)
|
||||||
|
(test-equal "singularity run, with environment"
|
||||||
|
0
|
||||||
|
(marionette-eval
|
||||||
|
;; Check whether GUILE_LOAD_PATH is properly set, allowing us to
|
||||||
|
;; find the (json) module.
|
||||||
|
`(status:exit-val
|
||||||
|
(system* #$(file-append singularity "/bin/singularity")
|
||||||
|
"--debug" "run" #$image "-c" "(use-modules (json))"))
|
||||||
|
marionette))
|
||||||
|
|
||||||
(test-end)
|
(test-end)
|
||||||
(exit (= (test-runner-fail-count (test-runner-current)) 0)))))
|
(exit (= (test-runner-fail-count (test-runner-current)) 0)))))
|
||||||
|
|
||||||
|
@ -122,7 +137,8 @@ (define (build-tarball&run-singularity-test)
|
||||||
(guile (set-guile-for-build (default-guile)))
|
(guile (set-guile-for-build (default-guile)))
|
||||||
;; 'singularity exec' insists on having /bin/sh in the image.
|
;; 'singularity exec' insists on having /bin/sh in the image.
|
||||||
(profile (profile-derivation (packages->manifest
|
(profile (profile-derivation (packages->manifest
|
||||||
(list bash-minimal guile-2.2))
|
(list bash-minimal
|
||||||
|
guile-2.2 guile-json))
|
||||||
#:hooks '()
|
#:hooks '()
|
||||||
#:locales? #f))
|
#:locales? #f))
|
||||||
(tarball (squashfs-image "singularity-pack" profile
|
(tarball (squashfs-image "singularity-pack" profile
|
||||||
|
|
|
@ -286,6 +286,32 @@ (define tar-supports-sort?
|
||||||
build
|
build
|
||||||
#:references-graphs `(("profile" ,profile))))
|
#:references-graphs `(("profile" ,profile))))
|
||||||
|
|
||||||
|
(define (singularity-environment-file profile)
|
||||||
|
"Return a shell script that defines the environment variables corresponding
|
||||||
|
to the search paths of PROFILE."
|
||||||
|
(define build
|
||||||
|
(with-extensions (list guile-gcrypt)
|
||||||
|
(with-imported-modules `(((guix config) => ,(make-config.scm))
|
||||||
|
,@(source-module-closure
|
||||||
|
`((guix profiles)
|
||||||
|
(guix search-paths))
|
||||||
|
#:select? not-config?))
|
||||||
|
#~(begin
|
||||||
|
(use-modules (guix profiles) (guix search-paths)
|
||||||
|
(ice-9 match))
|
||||||
|
|
||||||
|
(call-with-output-file #$output
|
||||||
|
(lambda (port)
|
||||||
|
(for-each (match-lambda
|
||||||
|
((spec . value)
|
||||||
|
(format port "~a=~a~%export ~a~%"
|
||||||
|
(search-path-specification-variable spec)
|
||||||
|
value
|
||||||
|
(search-path-specification-variable spec))))
|
||||||
|
(profile-search-paths #$profile))))))))
|
||||||
|
|
||||||
|
(computed-file "singularity-environment.sh" build))
|
||||||
|
|
||||||
(define* (squashfs-image name profile
|
(define* (squashfs-image name profile
|
||||||
#:key target
|
#:key target
|
||||||
(profile-name "guix-profile")
|
(profile-name "guix-profile")
|
||||||
|
@ -305,6 +331,9 @@ (define database
|
||||||
(file-append (store-database (list profile))
|
(file-append (store-database (list profile))
|
||||||
"/db/db.sqlite")))
|
"/db/db.sqlite")))
|
||||||
|
|
||||||
|
(define environment
|
||||||
|
(singularity-environment-file profile))
|
||||||
|
|
||||||
(define build
|
(define build
|
||||||
(with-imported-modules (source-module-closure
|
(with-imported-modules (source-module-closure
|
||||||
'((guix build utils)
|
'((guix build utils)
|
||||||
|
@ -339,6 +368,7 @@ (define entry-point #$entry-point)
|
||||||
`(,@(map store-info-item
|
`(,@(map store-info-item
|
||||||
(call-with-input-file "profile"
|
(call-with-input-file "profile"
|
||||||
read-reference-graph))
|
read-reference-graph))
|
||||||
|
#$environment
|
||||||
,#$output
|
,#$output
|
||||||
|
|
||||||
;; Do not perform duplicate checking because we
|
;; Do not perform duplicate checking because we
|
||||||
|
@ -379,10 +409,19 @@ (define entry-point #$entry-point)
|
||||||
target)))))))
|
target)))))))
|
||||||
'#$symlinks)
|
'#$symlinks)
|
||||||
|
|
||||||
|
"-p" "/.singularity.d d 555 0 0"
|
||||||
|
|
||||||
|
;; Create the environment file.
|
||||||
|
"-p" "/.singularity.d/env d 555 0 0"
|
||||||
|
"-p" ,(string-append
|
||||||
|
"/.singularity.d/env/90-environment.sh s 777 0 0 "
|
||||||
|
(relative-file-name "/.singularity.d/env"
|
||||||
|
#$environment))
|
||||||
|
|
||||||
;; Create /.singularity.d/actions, and optionally the 'run'
|
;; Create /.singularity.d/actions, and optionally the 'run'
|
||||||
;; script, used by 'singularity run'.
|
;; script, used by 'singularity run'.
|
||||||
"-p" "/.singularity.d d 555 0 0"
|
|
||||||
"-p" "/.singularity.d/actions d 555 0 0"
|
"-p" "/.singularity.d/actions d 555 0 0"
|
||||||
|
|
||||||
,@(if entry-point
|
,@(if entry-point
|
||||||
`(;; This one if for Singularity 2.x.
|
`(;; This one if for Singularity 2.x.
|
||||||
"-p"
|
"-p"
|
||||||
|
|
Loading…
Reference in a new issue