]> git.saurik.com Git - apt.git/blob - test/integration/framework
add proper MSGLEVEL handling by overriding methods dynamic
[apt.git] / test / integration / framework
1 #!/bin/sh -- # no runable script, just for vi
2
3 # we all like colorful messages
4 CERROR="\e[1;31m" # red
5 CWARNING="\e[1;33m" # yellow
6 CMSG="\e[1;32m" # green
7 CINFO="\e[1;96m" # light blue
8 CDEBUG="\e[1;94m" # blue
9 CNORMAL="\e[0;39m" # default system console color
10 CDONE="\e[1;32m" # green
11 CPASS="\e[1;32m" # green
12 CFAIL="\e[1;31m" # red
13 CCMD="\e[1;35m" # pink
14
15 msgdie() { echo "${CERROR}E: $1${CNORMAL}" >&2; exit 1; }
16 msgwarn() { echo "${CWARNING}W: $1${CNORMAL}" >&2; }
17 msgmsg() { echo "${CMSG}$1${CNORMAL}" >&2; }
18 msginfo() { echo "${CINFO}I: $1${CNORMAL}" >&2; }
19 msgdebug() { echo "${CDEBUG}D: $1${CNORMAL}" >&2; }
20 msgdone() { echo "${CDONE}DONE${CNORMAL}" >&2; }
21 msgnwarn() { echo -n "${CWARNING}W: $1${CNORMAL}" >&2; }
22 msgnmsg() { echo -n "${CMSG}$1${CNORMAL}" >&2; }
23 msgninfo() { echo -n "${CINFO}I: $1${CNORMAL}" >&2; }
24 msgndebug() { echo -n "${CDEBUG}D: $1${CNORMAL}" >&2; }
25 msgtest() { echo -n "${CINFO}$1 ${CCMD}$(echo "$2" | sed -e 's/^aptc/apt-c/' -e 's/^aptg/apt-g/' -e 's/^aptf/apt-f/')${CINFO} ${CNORMAL} " >&2; }
26 msgpass() { echo "${CPASS}PASS${CNORMAL}" >&2; }
27 msgskip() { echo "${CWARNING}SKIP${CNORMAL}" >&2; }
28 msgfail() { echo "${CFAIL}FAIL${CNORMAL}" >&2; }
29
30 # enable / disable Debugging
31 MSGLEVEL=${MSGLEVEL:-3}
32 if [ $MSGLEVEL -le 0 ]; then
33 msgdie() { true; }
34 fi
35 if [ $MSGLEVEL -le 1 ]; then
36 msgwarn() { true; }
37 msgnwarn() { true; }
38 fi
39 if [ $MSGLEVEL -le 2 ]; then
40 msgmsg() { true; }
41 msgnmsg() { true; }
42 fi
43 if [ $MSGLEVEL -le 3 ]; then
44 msginfo() { true; }
45 msgninfo() { true; }
46 fi
47 if [ $MSGLEVEL -le 4 ]; then
48 msgdebug() { true; }
49 msgndebug() { true; }
50 fi
51 msgdone() {
52 if [ "$1" = "debug" -a $MSGLEVEL -le 4 ] ||
53 [ "$1" = "info" -a $MSGLEVEL -le 3 ] ||
54 [ "$1" = "msg" -a $MSGLEVEL -le 2 ] ||
55 [ "$1" = "warn" -a $MSGLEVEL -le 1 ] ||
56 [ "$1" = "die" -a $MSGLEVEL -le 0 ]; then
57 true;
58 else
59 echo "${CDONE}DONE${CNORMAL}" >&2;
60 fi
61 }
62
63 runapt() {
64 msgdebug "Executing: ${CCMD}$*${CDEBUG} "
65 if [ -f ./aptconfig.conf ]; then
66 APT_CONFIG=aptconfig.conf LD_LIBRARY_PATH=${BUILDDIRECTORY} ${BUILDDIRECTORY}/$*
67 else
68 LD_LIBRARY_PATH=${BUILDDIRECTORY} ${BUILDDIRECTORY}/$*
69 fi
70 }
71 aptconfig() { runapt apt-config $*; }
72 aptcache() { runapt apt-cache $*; }
73 aptget() { runapt apt-get $*; }
74 aptftparchive() { runapt apt-ftparchive $*; }
75
76 setupenvironment() {
77 local TMPWORKINGDIRECTORY=$(mktemp -d)
78 local TESTDIR=$(readlink -f $(dirname $0))
79 msgninfo "Preparing environment for ${CCMD}$0${CINFO} in ${TMPWORKINGDIRECTORY}… "
80 BUILDDIRECTORY="${TESTDIR}/../../build/bin"
81 test -x "${BUILDDIRECTORY}/apt-get" || msgdie "You need to build tree first"
82 local OLDWORKINGDIRECTORY=$(pwd)
83 trap "cd /; rm -rf $TMPWORKINGDIRECTORY; cd $OLDWORKINGDIRECTORY" 0 HUP INT QUIT ILL ABRT FPE SEGV PIPE TERM
84 cd $TMPWORKINGDIRECTORY
85 mkdir rootdir aptarchive
86 cd rootdir
87 mkdir -p etc/apt/apt.conf.d etc/apt/sources.list.d etc/apt/trusted.gpg.d etc/apt/preferences.d var/cache var/lib/dpkg
88 mkdir -p var/cache/apt/archives/partial var/lib/apt/lists/partial
89 local STATUSFILE=$(echo "$(basename $0)" | sed 's/^test-/status-/')
90 if [ -f "${TESTDIR}/${STATUSFILE}" ]; then
91 cp "${TESTDIR}/${STATUSFILE}" var/lib/dpkg/status
92 else
93 touch var/lib/dpkg/status
94 fi
95 mkdir -p usr/lib/apt
96 ln -s ${BUILDDIRECTORY}/methods usr/lib/apt/methods
97 cd ..
98 local PACKAGESFILE=$(echo "$(basename $0)" | sed 's/^test-/Packages-/')
99 if [ -f "${TESTDIR}/${PACKAGESFILE}" ]; then
100 cp "${TESTDIR}/${PACKAGESFILE}" aptarchive/Packages
101 else
102 touch aptarchive/Packages
103 fi
104 echo "RootDir \"${TMPWORKINGDIRECTORY}/rootdir\";" > aptconfig.conf
105 echo "Debug::NoLocking \"true\";" >> aptconfig.conf
106 echo "APT::Get::Show-User-Simulation-Note \"false\";" >> aptconfig.conf
107 export LC_ALL=C
108 msgdone "info"
109 }
110
111 configarchitecture() {
112 local CONFFILE=rootdir/etc/apt/apt.conf.d/01multiarch.conf
113 echo "APT::Architecture \"$1\";" > $CONFFILE
114 shift
115 while [ -n "$1" ]; do
116 echo "APT::Architectures:: \"$1\";" >> $CONFFILE
117 shift
118 done
119 }
120
121 buildsimplenativepackage() {
122 local NAME="$1"
123 local ARCH="$2"
124 local VERSION="$3"
125 local RELEASE="${4:-unstable}"
126 local DEPENDENCIES="$5"
127 local DESCRIPTION="$6"
128 msgndebug "Build package ${CCMD}${NAME}=${VERSION}/${RELEASE}${CDEBUG}… "
129 local BUILDDIR=incoming/${NAME}-${VERSION}
130 mkdir -p ${BUILDDIR}/debian/source
131 cd ${BUILDDIR}
132 echo "* most suckless software product ever" > FEATURES
133 test -e debian/copyright || (echo "Copyleft by Joe Sixpack $(date +%Y)" > debian/copyright)
134 test -e debian/changelog || (echo "$NAME ($VERSION) $RELEASE; urgency=low
135
136 * Initial release
137
138 -- Joe Sixpack <joe@example.org> $(date -R)" > debian/changelog)
139 test -e debian/control || (echo "Source: $NAME
140 Section: admin
141 Priority: optional
142 Maintainer: Joe Sixpack <joe@example.org>
143 Build-Depends: debhelper (>= 7)
144 Standards-Version: 3.9.1
145
146 Package: $NAME
147 Architecture: $ARCH" > debian/control)
148 test -z "$DEPENDENCIES" || echo "$DEPENDENCIES" >> debian/control
149 if [ -z "$DESCRIPTION" ]; then
150 echo "Description: an autogenerated dummy ${NAME}=${VERSION}/${RELEASE}
151 If you find such a package installed on your system,
152 YOU did something horribly wrong! They are autogenerated
153 und used only by testcases for APT and surf no other propose…" >> debian/control
154 else
155 echo "Description: $DESCRIPTION" >> debian/control
156 fi
157 test -e debian/compat || (echo "7" > debian/compat)
158 test -e debian/source/format || (echo "3.0 (native)" > debian/source/format)
159 test -e debian/rules || cp /usr/share/doc/debhelper/examples/rules.tiny debian/rules
160 dpkg-buildpackage -uc -us -a$ARCH > /dev/null 2> /dev/null
161 cd - > /dev/null
162 rm -rf $BUILDDIR
163 msgdone "debug"
164 }
165
166 buildaptarchive() {
167 msgninfo "Build APT archive for ${CCMD}$0${CINFO} based on "
168 if [ -d incoming ]; then
169 buildaptarchivefromincoming $*
170 else
171 buildaptarchivefromfiles $*
172 fi
173 }
174
175 createaptftparchiveconfig() {
176 local ARCHS="$(find pool/ -name '*.deb' | grep -oE '_[a-z0-9-]+\.deb$' | sort | uniq | sed -e '/^_all.deb$/ d' -e 's#^_\([a-z0-9-]*\)\.deb$#\1#' | tr '\n' ' ')"
177 echo -n 'Dir {
178 ArchiveDir "' >> ftparchive.conf
179 echo -n $(readlink -f .) >> ftparchive.conf
180 echo -n '";
181 CacheDir "' >> ftparchive.conf
182 echo -n $(readlink -f ..) >> ftparchive.conf
183 echo -n '";
184 };
185 TreeDefault {
186 Directory "pool/";
187 SrcDirectory "pool/";
188 };
189 APT {
190 FTPArchive {
191 Release {
192 Origin "joesixpack";
193 Label "apttestcases";
194 Suite "unstable";
195 Description "repository with dummy packages";
196 Architectures "' >> ftparchive.conf
197 echo -n "$ARCHS" >> ftparchive.conf
198 echo 'source";
199 };
200 };
201 };' >> ftparchive.conf
202 if [ -z "$1" ]; then
203 echo -n 'tree "dists/unstable" {
204 Architectures "' >> ftparchive.conf
205 echo -n "$ARCHS" >> ftparchive.conf
206 echo 'source";
207 Sections "main";
208 };' >> ftparchive.conf
209 fi
210 }
211
212 buildaptftparchivedirectorystructure() {
213 local ARCHS="$(find pool/ -name '*.deb' | grep -oE '_[a-z0-9-]+\.deb$' | sort | uniq | sed -e '/^_all.deb$/ d' -e 's#^_\([a-z0-9-]*\)\.deb$#\1#')"
214 for arch in $ARCHS; do
215 mkdir -p dists/unstable/main/binary-${arch}
216 done
217 mkdir -p dists/unstable/main/source
218 mkdir -p dists/unstable/main/i18n
219 }
220
221 buildaptarchivefromincoming() {
222 msginfo "incoming packages…"
223 cd aptarchive
224 [ -e pool ] || ln -s ../incoming pool
225 [ -e ftparchive.conf ] || createaptftparchiveconfig
226 [ -e dists ] || buildaptftparchivedirectorystructure
227 aptftparchive -qq generate ftparchive.conf
228 for dir in $(find ./dists -mindepth 1 -maxdepth 1 -type d); do
229 aptftparchive -qq release $dir > $dir/Release
230 sed -i -e '/0 Release$/ d' $dir/Release # remove the self reference
231 done
232 cd - > /dev/null
233 msgdone "info"
234 }
235
236 buildaptarchivefromfiles() {
237 msginfo "prebuild files…"
238 cd aptarchive
239 if [ -f Packages ]; then
240 msgninfo "\tPackages file… "
241 cat Packages | gzip > Packages.gz
242 cat Packages | bzip2 > Packages.bz2
243 cat Packages | lzma > Packages.lzma
244 msgdone "info"
245 fi
246 if [ -f Sources ]; then
247 msgninfo "\tSources file… "
248 cat Sources | gzip > Sources.gz
249 cat Sources | bzip2 > Sources.bz2
250 cat Sources | lzma > Sources.lzma
251 msgdone "info"
252 fi
253 aptftparchive -qq release . > Release
254 sed -i -e '/0 Release$/ d' Release # remove the self reference
255 cd ..
256 }
257
258 setupaptarchive() {
259 buildaptarchive
260 local APTARCHIVE=$(readlink -f ./aptarchive)
261 if [ -f ${APTARCHIVE}/Packages ]; then
262 msgninfo "\tadd deb sources.list line… "
263 echo "deb file://$APTARCHIVE /" > rootdir/etc/apt/sources.list.d/apt-test-archive-deb.list
264 msgdone "info"
265 else
266 rm -f rootdir/etc/apt/sources.list.d/apt-test-archive-deb.list
267 fi
268 if [ -f ${APTARCHIVE}/Sources ]; then
269 msgninfo "\tadd deb-src sources.list line… "
270 echo "deb-src file://$APTARCHIVE /" > rootdir/etc/apt/sources.list.d/apt-test-archive-deb-src.list
271 msgdone "info"
272 else
273 rm -f rootdir/etc/apt/sources.list.d/apt-test-archive-deb-src.list
274 fi
275 aptget update -qq
276 }
277
278 diff() {
279 local DIFFTEXT="$($(which diff) -u $* | sed -e '/^---/ d' -e '/^+++/ d' -e '/^@@/ d')"
280 if [ -n "$DIFFTEXT" ]; then
281 echo
282 echo "$DIFFTEXT"
283 return 1
284 else
285 return 0
286 fi
287 }
288
289 testequal() {
290 local COMPAREFILE=$(mktemp)
291 echo "$1" > $COMPAREFILE
292 shift
293 msgtest "Test for equality of" "$*"
294 $* 2>&1 | diff $COMPAREFILE - && msgpass || msgfail
295 rm $COMPAREFILE
296 }
297
298 testequalor2() {
299 local COMPAREFILE1=$(mktemp)
300 local COMPAREFILE2=$(mktemp)
301 local COMPAREAGAINST=$(mktemp)
302 echo "$1" > $COMPAREFILE1
303 echo "$2" > $COMPAREFILE2
304 shift 2
305 msgtest "Test for equality OR of" "$*"
306 $* 2>&1 1> $COMPAREAGAINST
307 (diff $COMPAREFILE1 $COMPAREAGAINST 1> /dev/null ||
308 diff $COMPAREFILE2 $COMPAREAGAINST 1> /dev/null) && msgpass ||
309 ( echo "\n${CINFO}Diff against OR 1${CNORMAL}" "$(diff $COMPAREFILE1 $COMPAREAGAINST)" \
310 "\n${CINFO}Diff against OR 2${CNORMAL}" "$(diff $COMPAREFILE2 $COMPAREAGAINST)" &&
311 msgfail )
312 rm $COMPAREFILE1 $COMPAREFILE2 $COMPAREAGAINST
313 }
314
315 testshowvirtual() {
316 local VIRTUAL="N: Can't select versions from package '$1' as it purely virtual"
317 local PACKAGE="$1"
318 shift
319 while [ -n "$1" ]; do
320 VIRTUAL="${VIRTUAL}
321 N: Can't select versions from package '$1' as it purely virtual"
322 PACKAGE="${PACKAGE} $1"
323 shift
324 done
325 msgtest "Test for virtual packages" "apt-cache show $PACKAGE"
326 VIRTUAL="${VIRTUAL}
327 N: No packages found"
328 local COMPAREFILE=$(mktemp)
329 local ARCH=$(dpkg-architecture -qDEB_HOST_ARCH_CPU)
330 eval `apt-config shell ARCH APT::Architecture`
331 echo "$VIRTUAL" | sed -e "s/:$ARCH//" -e 's/:all//' > $COMPAREFILE
332 aptcache show $PACKAGE 2>&1 | diff $COMPAREFILE - && msgpass || msgfail
333 rm $COMPAREFILE
334 }
335
336 testnopackage() {
337 msgtest "Test for non-existent packages" "apt-cache show $*"
338 local SHOWPKG="$(aptcache show $* 2>&1 | grep '^Package: ')"
339 if [ -n "$SHOWPKG" ]; then
340 echo
341 echo "$SHOWPKG"
342 msgfail
343 return 1
344 fi
345 msgpass
346 }