diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/guix-daemon.sh | 12 | ||||
| -rw-r--r-- | tests/guix-environment.sh | 4 | ||||
| -rw-r--r-- | tests/profiles.scm | 112 | 
3 files changed, 128 insertions, 0 deletions
| diff --git a/tests/guix-daemon.sh b/tests/guix-daemon.sh index 9186ffd585..7212e3eb68 100644 --- a/tests/guix-daemon.sh +++ b/tests/guix-daemon.sh @@ -81,6 +81,18 @@ guile -c "  kill "$daemon_pid" +# Pass several '--listen' options, and make sure they are all honored. +guix-daemon --disable-chroot --listen="$socket" --listen="$socket-second" \ +	    --listen="localhost" --listen="localhost:9876" & +daemon_pid=$! + +for uri in "$socket" "$socket-second" \ +		     "guix://localhost" "guix://localhost:9876" +do +    GUIX_DAEMON_SOCKET="$uri" guix build guile-bootstrap +done + +kill "$daemon_pid"  # Check the failed build cache. diff --git a/tests/guix-environment.sh b/tests/guix-environment.sh index 9115949123..bf5ca17fa5 100644 --- a/tests/guix-environment.sh +++ b/tests/guix-environment.sh @@ -105,6 +105,10 @@ else      test $? = 42  fi +# Make sure we can build the environment of 'guix'.  There may be collisions +# in its profile (e.g., for 'gzip'), but we have to accept them. +guix environment guix --bootstrap -n +  if guile -c '(getaddrinfo "www.gnu.org" "80" AI_NUMERICSERV)' 2> /dev/null  then      # Compute the build environment for the initial GNU Make. diff --git a/tests/profiles.scm b/tests/profiles.scm index 093422792f..f731807e8c 100644 --- a/tests/profiles.scm +++ b/tests/profiles.scm @@ -35,6 +35,7 @@    #:use-module (rnrs io ports)    #:use-module (srfi srfi-1)    #:use-module (srfi srfi-11) +  #:use-module (srfi srfi-34)    #:use-module (srfi srfi-64))  ;; Test the (guix profiles) module. @@ -288,6 +289,117 @@             (manifest-entry-search-paths              (package->manifest-entry mpl))))) +(test-equal "packages->manifest, propagated inputs" +  (map (match-lambda +         ((label package) +          (list (package-name package) (package-version package) +                package))) +       (package-propagated-inputs packages:guile-2.2)) +  (map (lambda (entry) +         (list (manifest-entry-name entry) +               (manifest-entry-version entry) +               (manifest-entry-item entry))) +       (manifest-entry-dependencies +        (package->manifest-entry packages:guile-2.2)))) + +(test-assert "manifest-entry-parent" +  (let ((entry (package->manifest-entry packages:guile-2.2))) +    (match (manifest-entry-dependencies entry) +      ((dependencies ..1) +       (and (every (lambda (parent) +                     (eq? entry (force parent))) +                   (map manifest-entry-parent dependencies)) +            (not (force (manifest-entry-parent entry)))))))) + +(test-assertm "read-manifest" +  (mlet* %store-monad ((manifest -> (packages->manifest +                                     (list (package +                                             (inherit %bootstrap-guile) +                                             (native-search-paths +                                              (package-native-search-paths +                                               packages:guile-2.0)))))) +                       (drv (profile-derivation manifest +                                                #:hooks '() +                                                #:locales? #f)) +                       (out -> (derivation->output-path drv))) +    (define (entry->sexp entry) +      (list (manifest-entry-name entry) +            (manifest-entry-version entry) +            (manifest-entry-search-paths entry) +            (manifest-entry-dependencies entry) +            (force (manifest-entry-parent entry)))) + +    (mbegin %store-monad +      (built-derivations (list drv)) +      (let ((manifest2 (profile-manifest out))) +        (return (equal? (map entry->sexp (manifest-entries manifest)) +                        (map entry->sexp (manifest-entries manifest2)))))))) + +(test-equal "collision" +  '(("guile-bootstrap" "2.0") ("guile-bootstrap" "42")) +  (guard (c ((profile-collision-error? c) +             (let ((entry1 (profile-collision-error-entry c)) +                   (entry2 (profile-collision-error-conflict c))) +               (list (list (manifest-entry-name entry1) +                           (manifest-entry-version entry1)) +                     (list (manifest-entry-name entry2) +                           (manifest-entry-version entry2)))))) +    (run-with-store %store +      (mlet* %store-monad ((p0 -> (package +                                    (inherit %bootstrap-guile) +                                    (version "42"))) +                           (p1 -> (dummy-package "p1" +                                    (propagated-inputs `(("p0" ,p0))))) +                           (manifest -> (packages->manifest +                                         (list %bootstrap-guile p1))) +                           (drv (profile-derivation manifest +                                                    #:hooks '() +                                                    #:locales? #f))) +        (return #f))))) + +(test-equal "collision of propagated inputs" +  '(("guile-bootstrap" "2.0") ("guile-bootstrap" "42")) +  (guard (c ((profile-collision-error? c) +             (let ((entry1 (profile-collision-error-entry c)) +                   (entry2 (profile-collision-error-conflict c))) +               (list (list (manifest-entry-name entry1) +                           (manifest-entry-version entry1)) +                     (list (manifest-entry-name entry2) +                           (manifest-entry-version entry2)))))) +    (run-with-store %store +      (mlet* %store-monad ((p0 -> (package +                                    (inherit %bootstrap-guile) +                                    (version "42"))) +                           (p1 -> (dummy-package "p1" +                                    (propagated-inputs +                                     `(("guile" ,%bootstrap-guile))))) +                           (p2 -> (dummy-package "p2" +                                    (propagated-inputs +                                     `(("guile" ,p0))))) +                           (manifest -> (packages->manifest (list p1 p2))) +                           (drv (profile-derivation manifest +                                                    #:hooks '() +                                                    #:locales? #f))) +        (return #f))))) + +(test-assertm "no collision" +  ;; Here we have an entry that is "lowered" (its 'item' field is a store file +  ;; name) and another entry (its 'item' field is a package) that is +  ;; equivalent. +  (mlet* %store-monad ((p -> (dummy-package "p" +                               (propagated-inputs +                                `(("guile" ,%bootstrap-guile))))) +                       (guile    (package->derivation %bootstrap-guile)) +                       (entry -> (manifest-entry +                                   (inherit (package->manifest-entry +                                             %bootstrap-guile)) +                                   (item (derivation->output-path guile)))) +                       (manifest -> (manifest +                                     (list entry +                                           (package->manifest-entry p)))) +                       (drv (profile-derivation manifest))) +    (return (->bool drv)))) +  (test-assertm "etc/profile"    ;; Make sure we get an 'etc/profile' file that at least defines $PATH.    (mlet* %store-monad | 
