mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-26 12:39:36 -05:00
pack: 'docker' backend records the profile's search paths.
* guix/docker.scm (config): Add #:environment parameter and honor it. (build-docker-image): Likewise, and pass it to 'config'. * guix/scripts/pack.scm (docker-image): Import (guix profiles) and (guix search-paths). Call 'profile-search-paths' and pass #:environment to 'build-docker-image'. * gnu/tests/docker.scm (run-docker-test)["Load docker image and run it"]: Add example that expects (json) to be available. * gnu/tests/docker.scm (build-tarball&run-docker-test): Replace %BOOTSTRAP-GUILE by GUILE-2.2 and GUILE-JSON in the environment.
This commit is contained in:
parent
9d8ab8034e
commit
b9fcf0c82a
3 changed files with 44 additions and 14 deletions
|
@ -27,7 +27,6 @@ (define-module (gnu tests docker)
|
||||||
#:use-module (gnu services networking)
|
#:use-module (gnu services networking)
|
||||||
#:use-module (gnu services docker)
|
#:use-module (gnu services docker)
|
||||||
#:use-module (gnu services desktop)
|
#:use-module (gnu services desktop)
|
||||||
#:use-module (gnu packages bootstrap) ; %bootstrap-guile
|
|
||||||
#:use-module (gnu packages docker)
|
#:use-module (gnu packages docker)
|
||||||
#:use-module (gnu packages guile)
|
#:use-module (gnu packages guile)
|
||||||
#:use-module (guix gexp)
|
#:use-module (guix gexp)
|
||||||
|
@ -101,7 +100,7 @@ (define marionette
|
||||||
marionette))
|
marionette))
|
||||||
|
|
||||||
(test-equal "Load docker image and run it"
|
(test-equal "Load docker image and run it"
|
||||||
'("hello world" "hi!")
|
'("hello world" "hi!" "JSON!")
|
||||||
(marionette-eval
|
(marionette-eval
|
||||||
`(begin
|
`(begin
|
||||||
(define slurp
|
(define slurp
|
||||||
|
@ -125,8 +124,15 @@ (define slurp
|
||||||
(response2 (slurp ;default entry point
|
(response2 (slurp ;default entry point
|
||||||
,(string-append #$docker-cli "/bin/docker")
|
,(string-append #$docker-cli "/bin/docker")
|
||||||
"run" repository&tag
|
"run" repository&tag
|
||||||
"-c" "(display \"hi!\")")))
|
"-c" "(display \"hi!\")"))
|
||||||
(list response1 response2)))
|
|
||||||
|
;; Check whether (json) is in $GUILE_LOAD_PATH.
|
||||||
|
(response3 (slurp ;default entry point + environment
|
||||||
|
,(string-append #$docker-cli "/bin/docker")
|
||||||
|
"run" repository&tag
|
||||||
|
"-c" "(use-modules (json))
|
||||||
|
(display (json-string->scm (scm->json-string \"JSON!\")))")))
|
||||||
|
(list response1 response2 response3)))
|
||||||
marionette))
|
marionette))
|
||||||
|
|
||||||
(test-end)
|
(test-end)
|
||||||
|
@ -144,7 +150,7 @@ (define (build-tarball&run-docker-test)
|
||||||
(version "0")
|
(version "0")
|
||||||
(source #f)
|
(source #f)
|
||||||
(build-system trivial-build-system)
|
(build-system trivial-build-system)
|
||||||
(arguments `(#:guile ,%bootstrap-guile
|
(arguments `(#:guile ,guile-2.2
|
||||||
#:builder
|
#:builder
|
||||||
(let ((out (assoc-ref %outputs "out")))
|
(let ((out (assoc-ref %outputs "out")))
|
||||||
(mkdir out)
|
(mkdir out)
|
||||||
|
@ -158,7 +164,7 @@ (define (build-tarball&run-docker-test)
|
||||||
(home-page #f)
|
(home-page #f)
|
||||||
(license license:public-domain)))
|
(license license:public-domain)))
|
||||||
(profile (profile-derivation (packages->manifest
|
(profile (profile-derivation (packages->manifest
|
||||||
(list %bootstrap-guile
|
(list guile-2.2 guile-json
|
||||||
guest-script-package))
|
guest-script-package))
|
||||||
#:hooks '()
|
#:hooks '()
|
||||||
#:locales? #f))
|
#:locales? #f))
|
||||||
|
|
|
@ -73,7 +73,7 @@ (define (repositories path id)
|
||||||
`((,(generate-tag path) . ((latest . ,id)))))
|
`((,(generate-tag path) . ((latest . ,id)))))
|
||||||
|
|
||||||
;; See https://github.com/opencontainers/image-spec/blob/master/config.md
|
;; See https://github.com/opencontainers/image-spec/blob/master/config.md
|
||||||
(define* (config layer time arch #:key entry-point)
|
(define* (config layer time arch #:key entry-point (environment '()))
|
||||||
"Generate a minimal image configuration for the given LAYER file."
|
"Generate a minimal image configuration for the given LAYER file."
|
||||||
;; "architecture" must be values matching "platform.arch" in the
|
;; "architecture" must be values matching "platform.arch" in the
|
||||||
;; runtime-spec at
|
;; runtime-spec at
|
||||||
|
@ -81,9 +81,13 @@ (define* (config layer time arch #:key entry-point)
|
||||||
`((architecture . ,arch)
|
`((architecture . ,arch)
|
||||||
(comment . "Generated by GNU Guix")
|
(comment . "Generated by GNU Guix")
|
||||||
(created . ,time)
|
(created . ,time)
|
||||||
(config . ,(if entry-point
|
(config . ,`((env . ,(map (match-lambda
|
||||||
|
((name . value)
|
||||||
|
(string-append name "=" value)))
|
||||||
|
environment))
|
||||||
|
,@(if entry-point
|
||||||
`((entrypoint . ,entry-point))
|
`((entrypoint . ,entry-point))
|
||||||
#nil))
|
'())))
|
||||||
(container_config . #nil)
|
(container_config . #nil)
|
||||||
(os . "linux")
|
(os . "linux")
|
||||||
(rootfs . ((type . "layers")
|
(rootfs . ((type . "layers")
|
||||||
|
@ -113,6 +117,7 @@ (define* (build-docker-image image paths prefix
|
||||||
(system (utsname:machine (uname)))
|
(system (utsname:machine (uname)))
|
||||||
database
|
database
|
||||||
entry-point
|
entry-point
|
||||||
|
(environment '())
|
||||||
compressor
|
compressor
|
||||||
(creation-time (current-time time-utc)))
|
(creation-time (current-time time-utc)))
|
||||||
"Write to IMAGE a Docker image archive containing the given PATHS. PREFIX
|
"Write to IMAGE a Docker image archive containing the given PATHS. PREFIX
|
||||||
|
@ -124,6 +129,9 @@ (define* (build-docker-image image paths prefix
|
||||||
When ENTRY-POINT is true, it must be a list of strings; it is stored as the
|
When ENTRY-POINT is true, it must be a list of strings; it is stored as the
|
||||||
entry point in the Docker image JSON structure.
|
entry point in the Docker image JSON structure.
|
||||||
|
|
||||||
|
ENVIRONMENT must be a list of name/value pairs. It specifies the environment
|
||||||
|
variables that must be defined in the resulting image.
|
||||||
|
|
||||||
SYMLINKS must be a list of (SOURCE -> TARGET) tuples describing symlinks to be
|
SYMLINKS must be a list of (SOURCE -> TARGET) tuples describing symlinks to be
|
||||||
created in the image, where each TARGET is relative to PREFIX.
|
created in the image, where each TARGET is relative to PREFIX.
|
||||||
TRANSFORMATIONS must be a list of (OLD -> NEW) tuples describing how to
|
TRANSFORMATIONS must be a list of (OLD -> NEW) tuples describing how to
|
||||||
|
@ -234,6 +242,7 @@ (define transformation-options
|
||||||
(lambda ()
|
(lambda ()
|
||||||
(scm->json (config (string-append id "/layer.tar")
|
(scm->json (config (string-append id "/layer.tar")
|
||||||
time arch
|
time arch
|
||||||
|
#:environment environment
|
||||||
#:entry-point entry-point))))
|
#:entry-point entry-point))))
|
||||||
(with-output-to-file "manifest.json"
|
(with-output-to-file "manifest.json"
|
||||||
(lambda ()
|
(lambda ()
|
||||||
|
|
|
@ -27,6 +27,7 @@ (define-module (guix scripts pack)
|
||||||
#:use-module (guix utils)
|
#:use-module (guix utils)
|
||||||
#:use-module (guix store)
|
#:use-module (guix store)
|
||||||
#:use-module ((guix status) #:select (with-status-verbosity))
|
#:use-module ((guix status) #:select (with-status-verbosity))
|
||||||
|
#:use-module ((guix self) #:select (make-config.scm))
|
||||||
#:use-module (guix grafts)
|
#:use-module (guix grafts)
|
||||||
#:autoload (guix inferior) (inferior-package?)
|
#:autoload (guix inferior) (inferior-package?)
|
||||||
#:use-module (guix monads)
|
#:use-module (guix monads)
|
||||||
|
@ -440,11 +441,24 @@ (define defmod 'define-module) ;trick Geiser
|
||||||
(define build
|
(define build
|
||||||
;; Guile-JSON and Guile-Gcrypt are required by (guix docker).
|
;; Guile-JSON and Guile-Gcrypt are required by (guix docker).
|
||||||
(with-extensions (list guile-json guile-gcrypt)
|
(with-extensions (list guile-json guile-gcrypt)
|
||||||
(with-imported-modules (source-module-closure '((guix docker)
|
(with-imported-modules `(((guix config) => ,(make-config.scm))
|
||||||
(guix build store-copy))
|
,@(source-module-closure
|
||||||
#:select? not-config?)
|
`((guix docker)
|
||||||
|
(guix build store-copy)
|
||||||
|
(guix profiles)
|
||||||
|
(guix search-paths))
|
||||||
|
#:select? not-config?))
|
||||||
#~(begin
|
#~(begin
|
||||||
(use-modules (guix docker) (srfi srfi-19) (guix build store-copy))
|
(use-modules (guix docker) (guix build store-copy)
|
||||||
|
(guix profiles) (guix search-paths)
|
||||||
|
(srfi srfi-19) (ice-9 match))
|
||||||
|
|
||||||
|
(define environment
|
||||||
|
(map (match-lambda
|
||||||
|
((spec . value)
|
||||||
|
(cons (search-path-specification-variable spec)
|
||||||
|
value)))
|
||||||
|
(profile-search-paths #$profile)))
|
||||||
|
|
||||||
(setenv "PATH" (string-append #$archiver "/bin"))
|
(setenv "PATH" (string-append #$archiver "/bin"))
|
||||||
|
|
||||||
|
@ -455,6 +469,7 @@ (define build
|
||||||
#$profile
|
#$profile
|
||||||
#:database #+database
|
#:database #+database
|
||||||
#:system (or #$target (utsname:machine (uname)))
|
#:system (or #$target (utsname:machine (uname)))
|
||||||
|
#:environment environment
|
||||||
#:entry-point #$(and entry-point
|
#:entry-point #$(and entry-point
|
||||||
#~(string-append #$profile "/"
|
#~(string-append #$profile "/"
|
||||||
#$entry-point))
|
#$entry-point))
|
||||||
|
|
Loading…
Reference in a new issue