1 | #!/bin/sh
|
---|
2 | # $Id: tstInstallInit.sh 44088 2012-12-11 10:09:39Z vboxsync $
|
---|
3 | #
|
---|
4 | # VirtualBox init file creator unit test.
|
---|
5 | #
|
---|
6 | # Copyright (C) 2012 Oracle Corporation
|
---|
7 | #
|
---|
8 | # This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
9 | # available from http://www.virtualbox.org. This file is free software;
|
---|
10 | # you can redistribute it and/or modify it under the terms of the GNU
|
---|
11 | # General Public License (GPL) as published by the Free Software
|
---|
12 | # Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
13 | # VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
14 | # hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
15 | #
|
---|
16 |
|
---|
17 | # This will initially be a skeleton with a couple of tests - add more for quick
|
---|
18 | # debugging when you suspect that something isn't working as specified.
|
---|
19 |
|
---|
20 | tab=" "
|
---|
21 | tmpbase="/tmp/tstInstallInit 99" # Space in the name for a little stress...
|
---|
22 |
|
---|
23 | ## The function definition at the start of every non-trivial shell script!
|
---|
24 | abort()
|
---|
25 | {
|
---|
26 | ## $1 Error text to output to standard error in printf format.
|
---|
27 | cat >&2 << EOF
|
---|
28 | ${TEST_NAME}: $1
|
---|
29 | EOF
|
---|
30 | exit 1
|
---|
31 | }
|
---|
32 |
|
---|
33 | ## Print a TESTING line.
|
---|
34 | print_line()
|
---|
35 | {
|
---|
36 | cat >&2 << EOF
|
---|
37 | ${TEST_NAME}: TESTING $1
|
---|
38 | EOF
|
---|
39 | }
|
---|
40 |
|
---|
41 | ## Set the failure message if it is not yet set.
|
---|
42 | fail_msg()
|
---|
43 | {
|
---|
44 | test -z "${failed}" && failed="FAILED: ${1}"
|
---|
45 | }
|
---|
46 |
|
---|
47 | # Get the directory where the script is located and the parent.
|
---|
48 | OUR_FOLDER=`dirname "$0"`
|
---|
49 | OUR_FOLDER=`cd "${OUR_FOLDER}" && pwd`
|
---|
50 | VBOX_FOLDER=`cd "${OUR_FOLDER}/.." && pwd`
|
---|
51 | [ -d "${VBOX_FOLDER}" ] ||
|
---|
52 | abort "Failed to change to directory ${VBOX_FOLDER}.\n"
|
---|
53 | cd "${VBOX_FOLDER}"
|
---|
54 |
|
---|
55 | # Get our name for output.
|
---|
56 | TEST_NAME="$(basename "$0" .sh)"
|
---|
57 |
|
---|
58 | # Create a trivial test service in temporary directory $1 with name $2.
|
---|
59 | test_service()
|
---|
60 | {
|
---|
61 | cat > "${1}/${2}" << EOF
|
---|
62 | #!/bin/sh
|
---|
63 | trap "touch \"${1}/stopped\"; exit" TERM
|
---|
64 | echo "1: \${1} 2: \${2} 3: \${3}" > "${1}/started"
|
---|
65 | while true; do true; done
|
---|
66 | EOF
|
---|
67 | chmod u+x "${1}/${2}"
|
---|
68 | }
|
---|
69 |
|
---|
70 | # Test some dodgy input values against generate_service_file.
|
---|
71 | print_line "generation of shell script from template."
|
---|
72 | input='TEST1%DESCRIPTION%%%%SERVICE_NAME% TST2 TEST %ARGUMENTS%%COMMAND%'
|
---|
73 | out=`echo "${input}" |
|
---|
74 | helpers/generate_service_file --command '/usr/bin
|
---|
75 | aries/hello
|
---|
76 | world' --arguments 'p\x0a0\n\ \t' --format shell --description ''`
|
---|
77 | expected='TEST1%hello
|
---|
78 | world TST2 TEST '\''p
|
---|
79 | 0
|
---|
80 | '"${tab}"\'\''/usr/bin
|
---|
81 | aries/hello
|
---|
82 | world'\'
|
---|
83 | case "${out}" in ${expected})
|
---|
84 | echo "SUCCESS";;
|
---|
85 | *)
|
---|
86 | cat << EOF
|
---|
87 | FAILED: expected
|
---|
88 | ${expected}
|
---|
89 | but got
|
---|
90 | ${out}
|
---|
91 | EOF
|
---|
92 | esac
|
---|
93 |
|
---|
94 | # Create a simulated init system layout.
|
---|
95 | create_simulated_init_tree()
|
---|
96 | {
|
---|
97 | tmpdir="${1}"
|
---|
98 | rm -rf "${tmpdir}"
|
---|
99 | mkdir -m 0700 "${tmpdir}" || abort "Failed to create a temporary folder."
|
---|
100 | mkdir -p "${tmpdir}/init.d/" "${tmpdir}/rc.d/init.d/"
|
---|
101 | for i in 0 1 2 3 4 5 6; do
|
---|
102 | mkdir "${tmpdir}/rc${i}.d/" "${tmpdir}/rc.d/rc${i}.d/"
|
---|
103 | done
|
---|
104 | mkdir "${tmpdir}/run"
|
---|
105 | }
|
---|
106 |
|
---|
107 | # Test an init script installation.
|
---|
108 | print_line "installing an init script."
|
---|
109 | failed=""
|
---|
110 | # Create a simulated init system layout.
|
---|
111 | tmpdir="${tmpbase}0"
|
---|
112 | create_simulated_init_tree "${tmpdir}"
|
---|
113 | # Create the service binary.
|
---|
114 | test_service "${tmpdir}" "service"
|
---|
115 | # And install it.
|
---|
116 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --enable ||
|
---|
117 | fail_msg "\"helpers/install_service\" failed."
|
---|
118 | # Check that the main service file was created as specified.
|
---|
119 | if test -x "${tmpdir}/init.d/service"; then
|
---|
120 | grep "Short-Description: My description" "${tmpdir}/init.d/service" >/dev/null ||
|
---|
121 | fail_msg "Description not set in \"${tmpdir}/init.d/service\""
|
---|
122 | else
|
---|
123 | fail_msg "\"${tmpdir}/init.d/service\" not correctly created."
|
---|
124 | fi
|
---|
125 | test -x "${tmpdir}/init.d/rc.d/service" &&
|
---|
126 | fail_msg "\"${tmpdir}/init.d/rc.d/service\" created but shouldn't have been."
|
---|
127 | # Try to start the service using the symbolic links which should have been
|
---|
128 | # created.
|
---|
129 | if "${tmpdir}/rc3.d/S20service" --prefix "${tmpdir}" --lsb-functions "" start >/dev/null 2>&1; then
|
---|
130 | if grep "1: test 2: of 3: my arguments" "${tmpdir}/started" >/dev/null; then
|
---|
131 | test -f "${tmpdir}/stopped" &&
|
---|
132 | fail_msg "\"${tmpdir}/rc3.d/S20service\" stopped immediately."
|
---|
133 | else
|
---|
134 | fail_msg "\"${tmpdir}/rc3.d/S20service\" did not start correctly."
|
---|
135 | fi
|
---|
136 | else
|
---|
137 | fail_msg "could not start \"${tmpdir}/rc3.d/S20service\"."
|
---|
138 | fi
|
---|
139 | # Check the status.
|
---|
140 | "${tmpdir}/rc.d/rc5.d/S20service" --prefix "${tmpdir}" --lsb-functions "" status >/dev/null 2>&1 ||
|
---|
141 | fail_msg "\"${tmpdir}/rc.d/rc5.d/S20service\" reported the wrong status."
|
---|
142 | # Try to stop the service using the symbolic links which should have been
|
---|
143 | # created.
|
---|
144 | if "${tmpdir}/rc.d/rc6.d/K80service" --prefix "${tmpdir}" --lsb-functions "" stop >/dev/null 2>&1; then
|
---|
145 | test -f "${tmpdir}/stopped" ||
|
---|
146 | echo "\"${tmpdir}/rc.d/rc6.d/K80service\" did not stop correctly."
|
---|
147 | else
|
---|
148 | fail_msg "could not stop \"${tmpdir}/rc.d/rc6.d/K80service\"."
|
---|
149 | fi
|
---|
150 | # Check the status again - now it should be stopped.
|
---|
151 | "${tmpdir}/rc.d/rc3.d/S20service" --prefix "${tmpdir}" --lsb-functions "" status >/dev/null 2>&1 &&
|
---|
152 | fail_msg "\"${tmpdir}/rc.d/rc3.d/S20service\" reported the wrong status."
|
---|
153 | # Final summary.
|
---|
154 | if test -n "${failed}"; then
|
---|
155 | echo "${failed}"
|
---|
156 | else
|
---|
157 | echo SUCCESS
|
---|
158 | fi
|
---|
159 |
|
---|
160 | # Test an init script removal.
|
---|
161 | print_line "removing an init script."
|
---|
162 | failed=""
|
---|
163 | # Create a simulated init system layout.
|
---|
164 | tmpdir="${tmpbase}0"
|
---|
165 | create_simulated_init_tree "${tmpdir}"
|
---|
166 | # Create the service binary.
|
---|
167 | test_service "${tmpdir}" "service"
|
---|
168 | # Install it.
|
---|
169 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --enable ||
|
---|
170 | fail_msg "\"helpers/install_service\" failed."
|
---|
171 | # And remove it again.
|
---|
172 | helpers/install_service --command "${tmpdir}/service" --prefix "${tmpdir}" --remove ||
|
---|
173 | fail_msg "\"helpers/install_service\" failed."
|
---|
174 | # After uninstallation this should be the only file left in the init tree.
|
---|
175 | rm "${tmpdir}/service"
|
---|
176 | test "x`find "${tmpdir}" -type f -o -type l`" = "x" ||
|
---|
177 | fail_msg "not all files were removed."
|
---|
178 | # Final summary.
|
---|
179 | if test -n "${failed}"; then
|
---|
180 | echo "${failed}"
|
---|
181 | else
|
---|
182 | echo SUCCESS
|
---|
183 | fi
|
---|
184 |
|
---|
185 | # Test an enabled init script update with --disable.
|
---|
186 | print_line "updating an enabled init script with --disable."
|
---|
187 | failed=""
|
---|
188 | # Create a simulated init system layout.
|
---|
189 | tmpdir="${tmpbase}1"
|
---|
190 | create_simulated_init_tree "${tmpdir}"
|
---|
191 | # Create the service binary.
|
---|
192 | test_service "${tmpdir}" "service"
|
---|
193 | # Install it.
|
---|
194 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --enable ||
|
---|
195 | fail_msg "\"helpers/install_service\" failed."
|
---|
196 | # Install it disabled without forcing.
|
---|
197 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --disable ||
|
---|
198 | fail_msg "\"helpers/install_service\" failed."
|
---|
199 | test "x`find "${tmpdir}"/rc*.d -type l | wc -l`" = "x14" ||
|
---|
200 | fail_msg "links were removed on non-forced disable."
|
---|
201 | # Final summary.
|
---|
202 | if test -n "${failed}"; then
|
---|
203 | echo "${failed}"
|
---|
204 | else
|
---|
205 | echo SUCCESS
|
---|
206 | fi
|
---|
207 |
|
---|
208 | # Test updating a disabled init script with --enable.
|
---|
209 | print_line "updating a disabled init script with --enable."
|
---|
210 | failed=""
|
---|
211 | # Create a simulated init system layout.
|
---|
212 | tmpdir="${tmpbase}2"
|
---|
213 | create_simulated_init_tree "${tmpdir}"
|
---|
214 | # Create the service binary.
|
---|
215 | test_service "${tmpdir}" "service"
|
---|
216 | # Install it.
|
---|
217 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --disable ||
|
---|
218 | fail_msg "\"helpers/install_service\" failed."
|
---|
219 | # Install it disabled without forcing.
|
---|
220 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --enable ||
|
---|
221 | fail_msg "\"helpers/install_service\" failed."
|
---|
222 | test "x`find "${tmpdir}"/rc*.d -type l`" = "x" ||
|
---|
223 | fail_msg "files were installed on non-forced enable."
|
---|
224 | # Final summary.
|
---|
225 | if test -n "${failed}"; then
|
---|
226 | echo "${failed}"
|
---|
227 | else
|
---|
228 | echo SUCCESS
|
---|
229 | fi
|
---|
230 |
|
---|
231 | # Test an enabled init script update with --force-disable.
|
---|
232 | print_line "updating an enabled init script with --force-disable."
|
---|
233 | failed=""
|
---|
234 | # Create a simulated init system layout.
|
---|
235 | tmpdir="${tmpbase}3"
|
---|
236 | create_simulated_init_tree "${tmpdir}"
|
---|
237 | # Create the service binary.
|
---|
238 | test_service "${tmpdir}" "service"
|
---|
239 | # Install it.
|
---|
240 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --enable ||
|
---|
241 | fail_msg "\"helpers/install_service\" failed."
|
---|
242 | # Install it disabled without forcing.
|
---|
243 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --force-disable ||
|
---|
244 | fail_msg "\"helpers/install_service\" failed."
|
---|
245 | test "x`find "${tmpdir}"/rc*.d -type l`" = "x" ||
|
---|
246 | fail_msg "links were not removed on forced disable."
|
---|
247 | # Final summary.
|
---|
248 | if test -n "${failed}"; then
|
---|
249 | echo "${failed}"
|
---|
250 | else
|
---|
251 | echo SUCCESS
|
---|
252 | fi
|
---|
253 |
|
---|
254 | # Test updating a disabled init script with --force-enable.
|
---|
255 | print_line "updating a disabled init script with --force-enable."
|
---|
256 | failed=""
|
---|
257 | # Create a simulated init system layout.
|
---|
258 | tmpdir="${tmpbase}4"
|
---|
259 | create_simulated_init_tree "${tmpdir}"
|
---|
260 | # Create the service binary.
|
---|
261 | test_service "${tmpdir}" "service"
|
---|
262 | # Install it.
|
---|
263 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --disable ||
|
---|
264 | fail_msg "\"helpers/install_service\" failed."
|
---|
265 | # Install it disabled without forcing.
|
---|
266 | helpers/install_service --command "${tmpdir}/service" --arguments "test of my\ arguments" --description "My description" --prefix "${tmpdir}" --force-enable ||
|
---|
267 | fail_msg "\"helpers/install_service\" failed."
|
---|
268 | test "x`find "${tmpdir}"/rc*.d -type l | wc -l`" = "x14" ||
|
---|
269 | fail_msg "files were not installed on forced enable."
|
---|
270 | # Final summary.
|
---|
271 | if test -n "${failed}"; then
|
---|
272 | echo "${failed}"
|
---|
273 | else
|
---|
274 | echo SUCCESS
|
---|
275 | fi
|
---|