gnu: time: Update to 1.9.
[jackhill/guix/guix.git] / tests / guix-build.sh
CommitLineData
233e7676 1# GNU Guix --- Functional package management for GNU
f6396d86 2# Copyright © 2012, 2013, 2014, 2016, 2017 Ludovic Courtès <ludo@gnu.org>
97298ffa 3#
233e7676 4# This file is part of GNU Guix.
97298ffa 5#
233e7676 6# GNU Guix is free software; you can redistribute it and/or modify it
97298ffa
LC
7# under the terms of the GNU General Public License as published by
8# the Free Software Foundation; either version 3 of the License, or (at
9# your option) any later version.
10#
233e7676 11# GNU Guix is distributed in the hope that it will be useful, but
97298ffa
LC
12# WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14# GNU General Public License for more details.
15#
16# You should have received a copy of the GNU General Public License
233e7676 17# along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
97298ffa
LC
18
19#
e49951eb 20# Test the `guix build' command-line utility.
97298ffa
LC
21#
22
e49951eb 23guix build --version
97298ffa
LC
24
25# Should fail.
e49951eb 26if guix build -e +;
912209ee
LC
27then false; else true; fi
28
d223ac4a
LC
29# Source-less packages are accepted; they just return nothing.
30guix build -e '(@ (gnu packages bootstrap) %bootstrap-glibc)' -S
31test "`guix build -e '(@ (gnu packages bootstrap) %bootstrap-glibc)' -S`" = ""
97298ffa
LC
32
33# Should pass.
af9142dc 34guix build -e '(@@ (gnu packages bootstrap) %bootstrap-guile)' | \
97298ffa 35 grep -e '-guile-'
e49951eb 36guix build hello -d | \
97298ffa
LC
37 grep -e '-hello-[0-9\.]\+\.drv$'
38
1397b422
LC
39# Passing a URI.
40GUIX_DAEMON_SOCKET="file://$NIX_STATE_DIR/daemon-socket/socket" \
41guix build -e '(@@ (gnu packages bootstrap) %bootstrap-guile)'
42
43( if GUIX_DAEMON_SOCKET="weird://uri" \
44 guix build -e '(@@ (gnu packages bootstrap) %bootstrap-guile)'; \
45 then exit 1; fi )
46
2cdfe13d
EB
47# Check --sources option with its arguments
48module_dir="t-guix-build-$$"
49mkdir "$module_dir"
50trap "rm -rf $module_dir" EXIT
51
52cat > "$module_dir/foo.scm"<<EOF
53(define-module (foo)
94d609ab 54 #:use-module (guix tests)
2cdfe13d
EB
55 #:use-module (guix packages)
56 #:use-module (guix download)
57 #:use-module (guix build-system trivial))
58
59(define-public foo
60 (package
61 (name "foo")
62 (version "42")
63 (source (origin
64 (method url-fetch)
65 (uri "http://www.example.com/foo.tar.gz")
66 (sha256
67 (base32
68 "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"))))
69 (build-system trivial-build-system)
70 (inputs
71 (quasiquote (("bar" ,bar))))
72 (home-page "www.example.com")
73 (synopsis "Dummy package")
74 (description "foo is a dummy package for testing.")
75 (license #f)))
76
77(define-public bar
78 (package
79 (name "bar")
80 (version "9001")
81 (source (origin
82 (method url-fetch)
83 (uri "http://www.example.com/bar.tar.gz")
84 (sha256
85 (base32
86 "yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy"))))
87 (build-system trivial-build-system)
88 (inputs
89 (quasiquote
90 (("data" ,(origin
91 (method url-fetch)
92 (uri "http://www.example.com/bar.dat")
93 (sha256
94 (base32
95 "zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz")))))))
96 (home-page "www.example.com")
97 (synopsis "Dummy package")
98 (description "bar is a dummy package for testing.")
99 (license #f)))
94d609ab
LC
100
101(define-public baz
102 (dummy-package "baz" (replacement foo)))
103
01afdab8
LC
104(define-public superseded
105 (deprecated-package "superseded" bar))
106
2cdfe13d
EB
107EOF
108
109GUIX_PACKAGE_PATH="$module_dir"
110export GUIX_PACKAGE_PATH
111
112# foo.tar.gz
113guix build -d -S foo
114guix build -d -S foo | grep -e 'foo\.tar\.gz'
115
94d609ab
LC
116# 'baz' has a replacement so we should be getting the replacement's source.
117(unset GUIX_BUILD_OPTIONS;
118 test "`guix build -d -S baz`" = "`guix build -d -S foo`")
119
2cdfe13d
EB
120guix build -d --sources=package foo
121guix build -d --sources=package foo | grep -e 'foo\.tar\.gz'
122
123# bar.tar.gz and bar.dat
124guix build -d --sources bar
125test `guix build -d --sources bar \
126 | grep -e 'bar\.tar\.gz' -e 'bar\.dat' \
127 | wc -l` -eq 2
128
129# bar.tar.gz and bar.dat
130guix build -d --sources=all bar
131test `guix build -d --sources bar \
132 | grep -e 'bar\.tar\.gz' -e 'bar\.dat' \
133 | wc -l` -eq 2
134
135# Should include foo.tar.gz, bar.tar.gz, and bar.dat
136guix build -d --sources=transitive foo
137test `guix build -d --sources=transitive foo \
138 | grep -e 'foo\.tar\.gz' -e 'bar\.tar\.gz' -e 'bar\.dat' \
139 | wc -l` -eq 3
140
bf421152 141# Should all return valid log files.
af9142dc
LC
142drv="`guix build -d -e '(@@ (gnu packages bootstrap) %bootstrap-guile)'`"
143out="`guix build -e '(@@ (gnu packages bootstrap) %bootstrap-guile)'`"
bf421152
LC
144log="`guix build --log-file $drv`"
145echo "$log" | grep log/.*guile.*drv
146test -f "$log"
af9142dc 147test "`guix build -e '(@@ (gnu packages bootstrap) %bootstrap-guile)' --log-file`" \
bf421152
LC
148 = "$log"
149test "`guix build --log-file guile-bootstrap`" = "$log"
150test "`guix build --log-file $out`" = "$log"
151
97298ffa 152# Should fail because the name/version combination could not be found.
e49951eb 153if guix build hello-0.0.1 -n; then false; else true; fi
97298ffa
LC
154
155# Keep a symlink to the result, registered as a root.
156result="t-result-$$"
e49951eb 157guix build -r "$result" \
af9142dc 158 -e '(@@ (gnu packages bootstrap) %bootstrap-guile)'
97298ffa
LC
159test -x "$result/bin/guile"
160
161# Should fail, because $result already exists.
af9142dc 162if guix build -r "$result" -e '(@@ (gnu packages bootstrap) %bootstrap-guile)'
97298ffa
LC
163then false; else true; fi
164
165rm -f "$result"
5401dd75 166
e55ec43d
LC
167# Cross building.
168guix build coreutils --target=mips64el-linux-gnu --dry-run --no-substitutes
169
47c0f92c 170# Replacements.
f6396d86 171drv1=`guix build guix --with-input=guile@2.0=guile@2.2 -d`
47c0f92c
LC
172drv2=`guix build guix -d`
173test "$drv1" != "$drv2"
174
175drv1=`guix build guile -d`
176drv2=`guix build guile --with-input=gimp=ruby -d`
177test "$drv1" = "$drv2"
178
179if guix build guile --with-input=libunistring=something-really-silly
180then false; else true; fi
181
01afdab8
LC
182# Deprecated/superseded packages.
183test "`guix build superseded -d`" = "`guix build bar -d`"
184
5401dd75 185# Parsing package names and versions.
e49951eb 186guix build -n time # PASS
64f925cb 187guix build -n time@1.9 # PASS, version found
1b846da8 188if guix build -n time@3.2; # FAIL, version not found
5401dd75 189then false; else true; fi
e49951eb 190if guix build -n something-that-will-never-exist; # FAIL
5401dd75 191then false; else true; fi
ac5de156
LC
192
193# Invoking a monadic procedure.
194guix build -e "(begin
ada3df03 195 (use-modules (guix gexp))
ac5de156 196 (lambda ()
ada3df03
LC
197 (gexp->derivation \"test\"
198 (gexp (mkdir (ungexp output))))))" \
ac5de156 199 --dry-run
56b82106
LC
200
201# Running a gexp.
202guix build -e '#~(mkdir #$output)' -d
203guix build -e '#~(mkdir #$output)' -d | grep 'gexp\.drv'
16eb115e 204
34a1783f
DT
205# Building from a package file.
206cat > "$module_dir/package.scm"<<EOF
207(use-modules (gnu))
208(use-package-modules bootstrap)
209
210%bootstrap-guile
211EOF
212guix build --file="$module_dir/package.scm"
213
214# Building from a monadic procedure file.
215cat > "$module_dir/proc.scm"<<EOF
216(use-modules (guix gexp))
217(lambda ()
218 (gexp->derivation "test"
219 (gexp (mkdir (ungexp output)))))
220EOF
221guix build --file="$module_dir/proc.scm" --dry-run
222
223# Building from a gexp file.
224cat > "$module_dir/gexp.scm"<<EOF
225(use-modules (guix gexp))
226
227(gexp (mkdir (ungexp output)))
228EOF
229guix build --file="$module_dir/gexp.scm" -d
230guix build --file="$module_dir/gexp.scm" -d | grep 'gexp\.drv'
231
16eb115e 232# Using 'GUIX_BUILD_OPTIONS'.
442a6ff5 233GUIX_BUILD_OPTIONS="--dry-run --no-grafts"
16eb115e
DP
234export GUIX_BUILD_OPTIONS
235
236guix build emacs
237
238GUIX_BUILD_OPTIONS="--something-completely-crazy"
239if guix build emacs;
240then false; else true; fi