gnu: libvpx: Set size limit to avoid CVE-2015-1258.
[jackhill/guix/guix.git] / tests / guix-system.sh
CommitLineData
c1202fb1 1# GNU Guix --- Functional package management for GNU
116244df 2# Copyright © 2014, 2015 Ludovic Courtès <ludo@gnu.org>
c1202fb1
LC
3#
4# This file is part of GNU Guix.
5#
6# GNU Guix is free software; you can redistribute it and/or modify it
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#
11# GNU Guix is distributed in the hope that it will be useful, but
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
17# along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
18
19#
122c87ea 20# Test the daemon and its interaction with 'guix substitute'.
c1202fb1
LC
21#
22
23set -e
24
25guix system --version
26
27tmpfile="t-guix-system-$$"
28errorfile="t-guix-system-error-$$"
29trap 'rm -f "$tmpfile" "$errorfile"' EXIT
30
116244df
LC
31# Reporting of syntax errors.
32
c1202fb1
LC
33cat > "$tmpfile"<<EOF
34;; This is line 1, and the next one is line 2.
35 (operating-system)
36;; The 'T' is at column 3.
37EOF
38
39if guix system vm "$tmpfile" 2> "$errorfile"
40then
41 # This must not succeed.
42 exit 1
43else
44 grep "$tmpfile:2:3:.*missing.* initializers" "$errorfile"
45fi
116244df
LC
46
47
2abcc97f
LC
48# Reporting of unbound variables.
49
50cat > "$tmpfile" <<EOF
51(use-modules (gnu)) ; 1
52(use-service-modules networking) ; 2
53
54(operating-system ; 4
55 (host-name "antelope") ; 5
56 (timezone "Europe/Paris") ; 6
57 (locale "en_US.UTF-8") ; 7
58
59 (bootloader (GRUB-config (device "/dev/sdX"))) ; 9
60 (file-systems (cons (file-system
61 (device "root")
62 (title 'label)
63 (mount-point "/")
64 (type "ext4"))
65 %base-file-systems)))
66EOF
67
68if guix system build "$tmpfile" -n 2> "$errorfile"
69then false
70else
71 grep "$tmpfile:9:.*[Uu]nbound variable.*GRUB-config" "$errorfile"
72fi
73
116244df
LC
74# Reporting of duplicate service identifiers.
75
76cat > "$tmpfile" <<EOF
77(use-modules (gnu))
78(use-service-modules networking)
79
80(operating-system
81 (host-name "antelope")
82 (timezone "Europe/Paris")
83 (locale "en_US.UTF-8")
84
85 (bootloader (grub-configuration (device "/dev/sdX")))
86 (file-systems (cons (file-system
87 (device "root")
88 (title 'label)
89 (mount-point "/")
90 (type "ext4"))
91 %base-file-systems))
92
93 (services (cons* (dhcp-client-service)
94 (dhcp-client-service) ;twice!
95 %base-services)))
96EOF
97
98if guix system vm "$tmpfile" 2> "$errorfile"
99then
100 # This must not succeed.
101 exit 1
102else
103 grep "service 'networking'.*more than once" "$errorfile"
104fi
0c09a306
LC
105
106make_user_config ()
107{
108 cat > "$tmpfile" <<EOF
109(use-modules (gnu))
110(use-service-modules networking)
111
112(operating-system
113 (host-name "antelope")
114 (timezone "Europe/Paris")
115 (locale "en_US.UTF-8")
116
117 (bootloader (grub-configuration (device "/dev/sdX")))
118 (file-systems (cons (file-system
119 (device "root")
120 (title 'label)
121 (mount-point "/")
122 (type "ext4"))
123 %base-file-systems))
124 (users (list (user-account
125 (name "dave")
126 (home-directory "/home/dave")
127 (group "$1")
128 (supplementary-groups '("$2"))))))
129EOF
130}
131
132make_user_config "users" "wheel"
133guix system build "$tmpfile" -n # succeeds
134
135make_user_config "group-that-does-not-exist" "users"
136if guix system build "$tmpfile" -n 2> "$errorfile"
137then false
138else grep "primary group.*group-that-does-not-exist.*undeclared" "$errorfile"; fi
139
140make_user_config "users" "group-that-does-not-exist"
141if guix system build "$tmpfile" -n 2> "$errorfile"
142then false
143else grep "supplementary group.*group-that-does-not-exist.*undeclared" "$errorfile"; fi