aboutsummaryrefslogtreecommitdiff
path: root/gnu/installer/aux-files/logo.txt
blob: 52418d88c11a10e21f344c8f4184683500212c1a (about) (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
 ░░░                                     ░░░
 ░░▒▒░░░░░░░░░               ░░░░░░░░░▒▒░░
  ░░▒▒▒▒▒░░░░░░░           ░░░░░░░▒▒▒▒▒░
      ░▒▒▒░░▒▒▒▒▒         ░░░░░░░▒▒░
            ░▒▒▒▒░       ░░░░░░
             ▒▒▒▒▒      ░░░░░░
              ▒▒▒▒▒     ░░░░░
              ░▒▒▒▒▒   ░░░░░
               ▒▒▒▒▒   ░░░░░
                ▒▒▒▒▒ ░░░░░
                ░▒▒▒▒▒░░░░░
                 ▒▒▒▒▒▒░░░
                  ▒▒▒▒▒▒░
  _____ _   _ _    _    _____       _
 / ____| \ | | |  | |  / ____|     (_)
| |  __|  \| | |  | | | |  __ _   _ ___  __
| | |_ | . ' | |  | | | | |_ | | | | \ \/ /
| |__| | |\  | |__| | | |__| | |_| | |>  <
 \_____|_| \_|\____/   \_____|\__,_|_/_/\_\
(union-build (assoc-ref %outputs "out") (list (assoc-ref %build-inputs "one") (assoc-ref %build-inputs "two"))))) (drv (build-expression->derivation %store "union-collision-symlink" builder #:inputs `(("one" ,one) ("two" ,two)) #:modules '((guix build union))))) (and (build-derivations %store (list drv)) (with-directory-excursion (pk (derivation->output-path drv)) (and (string=? "one" (call-with-input-file "foo/one" get-string-all)) (string=? "two" (call-with-input-file "foo/two" get-string-all)) (string=? "two" (call-with-input-file "bar/two" get-string-all)) (not (file-exists? "bar/one"))))))) (test-skip (if (and %store (network-reachable?)) 0 1)) (test-assert "union-build" (let* ((inputs (map (match-lambda ((name package) `(,name ,(package-derivation %store package)))) ;; Purposefully leave duplicate entries. (filter (compose package? cadr) (append %bootstrap-inputs-for-tests (take %bootstrap-inputs-for-tests 3))))) (builder `(begin (use-modules (guix build union)) (union-build (assoc-ref %outputs "out") (map cdr %build-inputs)))) (drv (build-expression->derivation %store "union-test" builder #:inputs inputs #:modules '((guix build union))))) (and (build-derivations %store (list (pk 'drv drv))) (with-directory-excursion (derivation->output-path drv) (and (file-exists? "bin/touch") (file-exists? "bin/gcc") (file-exists? "bin/ld") (file-exists? "lib/libc.so") (directory-exists? "lib/gcc") (file-exists? "include/unistd.h") ;; The 'include/c++' sub-directory is only found in ;; gcc-bootstrap, so it should be unified in a ;; straightforward way, without traversing it. (eq? 'symlink (stat:type (lstat "include/c++"))) ;; Conversely, several inputs have a 'bin' sub-directory, so ;; unifying it requires traversing them all, and creating a ;; new 'bin' sub-directory in the profile. (eq? 'directory (stat:type (lstat "bin")))))))) (test-assert "union-build collision first & last" (let* ((guile (package-derivation %store %bootstrap-guile)) (fake (build-expression->derivation %store "fake-guile" '(begin (use-modules (guix build utils)) (let ((out (assoc-ref %outputs "out"))) (mkdir-p (string-append out "/bin")) (call-with-output-file (string-append out "/bin/guile") (const #t)))) #:modules '((guix build utils)))) (builder (lambda (policy) `(begin (use-modules (guix build union) (srfi srfi-1)) (union-build (assoc-ref %outputs "out") (map cdr %build-inputs) #:resolve-collision ,policy)))) (drv1 (build-expression->derivation %store "union-first" (builder 'first) #:inputs `(("guile" ,guile) ("fake" ,fake)) #:modules '((guix build union)))) (drv2 (build-expression->derivation %store "union-last" (builder 'last) #:inputs `(("guile" ,guile) ("fake" ,fake)) #:modules '((guix build union))))) (and (build-derivations %store (list drv1 drv2)) (with-directory-excursion (derivation->output-path drv1) (string=? (readlink "bin/guile") (string-append (derivation->output-path guile) "/bin/guile"))) (with-directory-excursion (derivation->output-path drv2) (string=? (readlink "bin/guile") (string-append (derivation->output-path fake) "/bin/guile")))))) (test-assert "union-build #:create-all-directories? #t" (let* ((build `(begin (use-modules (guix build union)) (union-build (assoc-ref %outputs "out") (map cdr %build-inputs) #:create-all-directories? #t))) (input (package-derivation %store %bootstrap-guile)) (drv (build-expression->derivation %store "union-test-all-dirs" build #:modules '((guix build union)) #:inputs `(("g" ,input))))) (and (build-derivations %store (list drv)) (with-directory-excursion (derivation->output-path drv) ;; Even though there's only one input to the union, ;; #:create-all-directories? #t must have created bin/ rather than ;; making it a symlink to Guile's bin/. (and (file-exists? "bin/guile") (file-is-directory? "bin") (eq? 'symlink (stat:type (lstat "bin/guile")))))))) (letrec-syntax ((test-relative-file-name (syntax-rules (=>) ((_ (reference file => expected) rest ...) (begin (test-equal (string-append "relative-file-name " reference " " file) expected (relative-file-name reference file)) (test-relative-file-name rest ...))) ((_) #t)))) (test-relative-file-name ("/a/b" "/a/c/d" => "../c/d") ("/a/b" "/a/b" => "") ("/a/b" "/a" => "..") ("/a/b" "/a/b/c/d" => "c/d") ("/a/b/c" "/a/d/e/f" => "../../d/e/f"))) (test-end)