* debian/apt.cron.daily:
[ntk/apt.git] / test / integration / framework
CommitLineData
8d876415
DK
1#!/bin/sh -- # no runable script, just for vi
2
3# we all like colorful messages
4CERROR="\e[1;31m" # red
5CWARNING="\e[1;33m" # yellow
6CMSG="\e[1;32m" # green
7CINFO="\e[1;96m" # light blue
8CDEBUG="\e[1;94m" # blue
9CNORMAL="\e[0;39m" # default system console color
10CDONE="\e[1;32m" # green
11CPASS="\e[1;32m" # green
12CFAIL="\e[1;31m" # red
13CCMD="\e[1;35m" # pink
14
15msgdie() { echo "${CERROR}E: $1${CNORMAL}" >&2; exit 1; }
16msgwarn() { echo "${CWARNING}W: $1${CNORMAL}" >&2; }
17msgmsg() { echo "${CMSG}$1${CNORMAL}" >&2; }
18msginfo() { echo "${CINFO}I: $1${CNORMAL}" >&2; }
19msgdebug() { echo "${CDEBUG}D: $1${CNORMAL}" >&2; }
20msgdone() { echo "${CDONE}DONE${CNORMAL}" >&2; }
21msgnwarn() { echo -n "${CWARNING}W: $1${CNORMAL}" >&2; }
22msgnmsg() { echo -n "${CMSG}$1${CNORMAL}" >&2; }
23msgninfo() { echo -n "${CINFO}I: $1${CNORMAL}" >&2; }
24msgndebug() { echo -n "${CDEBUG}D: $1${CNORMAL}" >&2; }
25msgtest() { 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; }
26msgpass() { echo "${CPASS}PASS${CNORMAL}" >&2; }
27msgskip() { echo "${CWARNING}SKIP${CNORMAL}" >&2; }
28msgfail() { echo "${CFAIL}FAIL${CNORMAL}" >&2; }
29
30# enable / disable Debugging
31msginfo() { true; }
32msgdebug() { true; }
33msgninfo() { true; }
34msgndebug() { true; }
35msgdone() { if [ "$1" = "debug" -o "$1" = "info" ]; then true; else echo "${CDONE}DONE${CNORMAL}" >&2; fi }
36
37runapt() {
38 msgdebug "Executing: ${CCMD}$*${CDEBUG} "
7d0627b6
DK
39 if [ -f ./aptconfig.conf ]; then
40 APT_CONFIG=aptconfig.conf LD_LIBRARY_PATH=${BUILDDIRECTORY} ${BUILDDIRECTORY}/$*
41 else
42 LD_LIBRARY_PATH=${BUILDDIRECTORY} ${BUILDDIRECTORY}/$*
43 fi
8d876415
DK
44}
45aptconfig() { runapt apt-config $*; }
46aptcache() { runapt apt-cache $*; }
47aptget() { runapt apt-get $*; }
48aptftparchive() { runapt apt-ftparchive $*; }
49
50setupenvironment() {
51 local TMPWORKINGDIRECTORY=$(mktemp -d)
8f8169ac 52 local TESTDIR=$(readlink -f $(dirname $0))
8d876415 53 msgninfo "Preparing environment for ${CCMD}$0${CINFO} in ${TMPWORKINGDIRECTORY}… "
8f8169ac 54 BUILDDIRECTORY="${TESTDIR}/../../build/bin"
8d876415
DK
55 test -x "${BUILDDIRECTORY}/apt-get" || msgdie "You need to build tree first"
56 local OLDWORKINGDIRECTORY=$(pwd)
57 trap "cd /; rm -rf $TMPWORKINGDIRECTORY; cd $OLDWORKINGDIRECTORY" 0 HUP INT QUIT ILL ABRT FPE SEGV PIPE TERM
58 cd $TMPWORKINGDIRECTORY
59 mkdir rootdir aptarchive
60 cd rootdir
61 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
62 mkdir -p var/cache/apt/archives/partial var/lib/apt/lists/partial
8f8169ac
DK
63 local STATUSFILE=$(echo "$(basename $0)" | sed 's/^test-/status-/')
64 if [ -f "${TESTDIR}/${STATUSFILE}" ]; then
65 cp "${TESTDIR}/${STATUSFILE}" var/lib/dpkg/status
66 else
67 touch var/lib/dpkg/status
68 fi
8d876415
DK
69 mkdir -p usr/lib/apt
70 ln -s ${BUILDDIRECTORY}/methods usr/lib/apt/methods
71 cd ..
8f8169ac
DK
72 local PACKAGESFILE=$(echo "$(basename $0)" | sed 's/^test-/Packages-/')
73 if [ -f "${TESTDIR}/${PACKAGESFILE}" ]; then
74 cp "${TESTDIR}/${PACKAGESFILE}" aptarchive/Packages
75 else
4bec02c2 76 touch aptarchive/Packages
8f8169ac 77 fi
8d876415
DK
78 echo "RootDir \"${TMPWORKINGDIRECTORY}/rootdir\";" > aptconfig.conf
79 echo "Debug::NoLocking \"true\";" >> aptconfig.conf
80 echo "APT::Get::Show-User-Simulation-Note \"false\";" >> aptconfig.conf
81 export LC_ALL=C
82 msgdone "info"
83}
84
85configarchitecture() {
86 local CONFFILE=rootdir/etc/apt/apt.conf.d/01multiarch.conf
87 echo "APT::Architecture \"$1\";" > $CONFFILE
88 shift
89 while [ -n "$1" ]; do
90 echo "APT::Architectures:: \"$1\";" >> $CONFFILE
91 shift
92 done
93}
94
95buildflataptarchive() {
96 msginfo "Build APT archive for ${CCMD}$0${CINFO}…"
97 cd aptarchive
98 APTARCHIVE=$(readlink -f .)
99 if [ -f Packages ]; then
100 msgninfo "\tPackages file… "
101 cat Packages | gzip > Packages.gz
102 cat Packages | bzip2 > Packages.bz2
103 cat Packages | lzma > Packages.lzma
104 msgdone "info"
105 fi
106 if [ -f Sources ]; then
107 msgninfo "\tSources file… "
108 cat Sources | gzip > Sources.gz
109 cat Sources | bzip2 > Sources.bz2
110 cat Sources | lzma > Sources.lzma
111 msgdone "info"
112 fi
113 cd ..
114 aptftparchive release . > Release
115}
116
117setupflataptarchive() {
118 buildflataptarchive
119 APTARCHIVE=$(readlink -f ./aptarchive)
120 if [ -f ${APTARCHIVE}/Packages ]; then
121 msgninfo "\tadd deb sources.list line… "
122 echo "deb file://$APTARCHIVE /" > rootdir/etc/apt/sources.list.d/apt-test-archive-deb.list
123 msgdone "info"
124 else
125 rm -f rootdir/etc/apt/sources.list.d/apt-test-archive-deb.list
126 fi
127 if [ -f ${APTARCHIVE}/Sources ]; then
128 msgninfo "\tadd deb-src sources.list line… "
129 echo "deb-src file://$APTARCHIVE /" > rootdir/etc/apt/sources.list.d/apt-test-archive-deb-src.list
130 msgdone "info"
131 else
132 rm -f rootdir/etc/apt/sources.list.d/apt-test-archive-deb-src.list
133 fi
134 aptget update -qq
135}
136
137diff() {
138 local DIFFTEXT="$($(which diff) -u $* | sed -e '/^---/ d' -e '/^+++/ d' -e '/^@@/ d')"
139 if [ -n "$DIFFTEXT" ]; then
140 echo
141 echo "$DIFFTEXT"
142 return 1
143 else
144 return 0
145 fi
146}
147
148testequal() {
149 local COMPAREFILE=$(mktemp)
150 echo "$1" > $COMPAREFILE
151 shift
152 msgtest "Test for equality of" "$*"
153 $* 2>&1 | diff $COMPAREFILE - && msgpass || msgfail
8e86786b 154 rm $COMPAREFILE
8d876415
DK
155}
156
685625bd
DK
157testequalor2() {
158 local COMPAREFILE1=$(mktemp)
159 local COMPAREFILE2=$(mktemp)
160 local COMPAREAGAINST=$(mktemp)
161 echo "$1" > $COMPAREFILE1
162 echo "$2" > $COMPAREFILE2
163 shift 2
164 msgtest "Test for equality OR of" "$*"
165 $* 2>&1 1> $COMPAREAGAINST
166 (diff $COMPAREFILE1 $COMPAREAGAINST 1> /dev/null ||
167 diff $COMPAREFILE2 $COMPAREAGAINST 1> /dev/null) && msgpass ||
168 ( echo "\n${CINFO}Diff against OR 1${CNORMAL}" "$(diff $COMPAREFILE1 $COMPAREAGAINST)" \
169 "\n${CINFO}Diff against OR 2${CNORMAL}" "$(diff $COMPAREFILE2 $COMPAREAGAINST)" &&
170 msgfail )
8e86786b 171 rm $COMPAREFILE1 $COMPAREFILE2 $COMPAREAGAINST
685625bd
DK
172}
173
8d876415 174testshowvirtual() {
4bec02c2 175 local VIRTUAL="N: Can't select versions from package '$1' as it purely virtual"
8d876415
DK
176 local PACKAGE="$1"
177 shift
178 while [ -n "$1" ]; do
179 VIRTUAL="${VIRTUAL}
4bec02c2 180N: Can't select versions from package '$1' as it purely virtual"
8d876415
DK
181 PACKAGE="${PACKAGE} $1"
182 shift
183 done
184 msgtest "Test for virtual packages" "apt-cache show $PACKAGE"
185 VIRTUAL="${VIRTUAL}
4bec02c2 186N: No packages found"
8d876415
DK
187 local COMPAREFILE=$(mktemp)
188 local ARCH=$(dpkg-architecture -qDEB_HOST_ARCH_CPU)
189 eval `apt-config shell ARCH APT::Architecture`
190 echo "$VIRTUAL" | sed -e "s/:$ARCH//" -e 's/:all//' > $COMPAREFILE
191 aptcache show $PACKAGE 2>&1 | diff $COMPAREFILE - && msgpass || msgfail
8e86786b 192 rm $COMPAREFILE
8d876415
DK
193}
194
195testnopackage() {
196 msgtest "Test for non-existent packages" "apt-cache show $*"
197 local SHOWPKG="$(aptcache show $* 2>&1 | grep '^Package: ')"
198 if [ -n "$SHOWPKG" ]; then
199 echo
200 echo "$SHOWPKG"
201 msgfail
202 return 1
203 fi
204 msgpass
205}