]> git.saurik.com Git - apt.git/blame - test/integration/test-compressed-indexes
eipp: enable xz-compressed scenario logging
[apt.git] / test / integration / test-compressed-indexes
CommitLineData
f213b6ea
DK
1#!/bin/sh
2set -e
3
3abb6a6a
DK
4TESTDIR="$(readlink -f "$(dirname "$0")")"
5. "$TESTDIR/framework"
f213b6ea
DK
6
7setupenvironment
bdc42211 8configcompression 'ALL'
5f982b9d 9configarchitecture 'i386'
0179cfa8 10LOWCOSTEXT='lz4'
5f982b9d
DK
11
12buildsimplenativepackage 'testpkg' 'i386' '1.0'
13
14buildaptarchive
15setupdistsaptarchive
16# fake a pdiff setup as apt wouldn't try pdiffs otherwise
17find aptarchive -name 'Packages' -o -name 'Sources' | while read file; do
18 mkdir "${file}.diff"
19 PATCHINDEX="${file}.diff/Index"
20 echo 'SHA1-Current: adc83b19e793491b1c6ea0fd8b46cd9f32e592fc 0
21SHA1-History:
22 adc83b19e793491b1c6ea0fd8b46cd9f32e592fc 33053002 2010-08-18-2013.28
23 ecfd1b19e793491b1c6ea123eabdcd9f32e592fc 33053001 2010-08-18-2013.29
24SHA1-Patches:
25 abc1fc0ac57cd83d41c63195a9342e2db5650257 19722 2010-08-18-0814.28
26 dfe3444ac57cd83d41c63195a9342e2db5650257 19722 2010-08-18-0814.29' > $PATCHINDEX
27done
28generatereleasefiles
29signreleasefiles
f213b6ea
DK
30
31testrun() {
32 local F
5f982b9d
DK
33 msgtest 'Check if all index files are' "${1:-uncompressed}"
34 if [ "$1" = 'compressed' ]; then
1dd20368 35 ! test -e rootdir/var/lib/apt/lists/*i386_Packages || F=1
5f982b9d
DK
36 ! test -e rootdir/var/lib/apt/lists/*_Sources || F=1
37 ! test -e rootdir/var/lib/apt/lists/*_Translation-en || F=1
0179cfa8 38 test -e rootdir/var/lib/apt/lists/*i386_Packages.$LOWCOSTEXT || F=1
0179cfa8
DK
39 test -e rootdir/var/lib/apt/lists/*_Sources.$LOWCOSTEXT || F=1
40 test -e rootdir/var/lib/apt/lists/*_Translation-en.$LOWCOSTEXT || F=1
5f982b9d
DK
41 # there is no point in trying pdiff if we have compressed indexes
42 # as we can't patch compressed files (well, we can, but what is the point?)
4d0818cc 43 ! test -e rootdir/var/lib/apt/lists/*diff_Index || F=1
5f982b9d
DK
44 else
45 # clear the faked pdiff indexes so the glob below works
4d0818cc 46 rm -f rootdir/var/lib/apt/lists/*diff_Index
1dd20368 47 test -e rootdir/var/lib/apt/lists/*i386_Packages || F=1
5f982b9d
DK
48 test -e rootdir/var/lib/apt/lists/*_Sources || F=1
49 test -e rootdir/var/lib/apt/lists/*_Translation-en || F=1
1dd20368 50 ! test -e rootdir/var/lib/apt/lists/*i386_Packages.* || F=1
5f982b9d
DK
51 ! test -e rootdir/var/lib/apt/lists/*_Sources.* || F=1
52 ! test -e rootdir/var/lib/apt/lists/*_Translation-en.* || F=1
f213b6ea 53 fi
5f982b9d 54 if [ -n "$F" ]; then
78bc8d6b 55 cat rootdir/tmp/testsuccess.output
5f982b9d
DK
56 ls -laR rootdir/var/lib/apt/lists/
57 msgfail
58 else
59 msgpass
60 fi
61 msgtest 'Check if package is downloadable'
03aa0847 62 cd downloaded
5f982b9d 63 testsuccess --nomsg aptget download testpkg
653ef26c 64 msgtest 'deb file is present'; testsuccess --nomsg test -f testpkg_1.0_i386.deb
a09f6eb8 65 rm -f testpkg_1.0_i386.deb
03aa0847 66 cd - >/dev/null
25b86db1 67 testsuccessequal 'Reading package lists...
5f982b9d
DK
68Building dependency tree...
69The following NEW packages will be installed:
70 testpkg
710 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
72Inst testpkg (1.0 unstable [i386])
eb1f04dd 73Conf testpkg (1.0 unstable [i386])' aptget install testpkg -s -o Debug::pkgAcquire::Auth=0 -o Debug::pkgAcquire::Worker=0
8de79b68 74 rm -f rootdir/var/cache/apt/pkgcache.bin rootdir/var/cache/apt/srcpkgcache.bin
25b86db1
DK
75 testsuccessequal "$GOODSHOW" aptcache show testpkg
76 testsuccessequal "$GOODSHOW" aptcache show testpkg
8de79b68 77 rm -f rootdir/var/cache/apt/pkgcache.bin rootdir/var/cache/apt/srcpkgcache.bin
25b86db1
DK
78 testsuccessequal "$GOODPOLICY" aptcache policy testpkg
79 testsuccessequal "$GOODPOLICY" aptcache policy testpkg
8de79b68 80 rm -f rootdir/var/cache/apt/pkgcache.bin rootdir/var/cache/apt/srcpkgcache.bin
25b86db1
DK
81 testsuccessequal "$GOODSHOWSRC" aptcache showsrc testpkg
82 testsuccessequal "$GOODSHOWSRC" aptcache showsrc testpkg
8de79b68 83 aptget clean
5f982b9d 84 msgtest 'Check if the source is aptgetable'
03aa0847 85 cd downloaded
0440d936 86 testsuccess --nomsg aptget source testpkg
03aa0847
DK
87 testsuccess test -s testpkg_1.0.dsc
88 testsuccess test -d testpkg-1.0
5f982b9d 89 rm -rf testpkg-1.0*
03aa0847 90 cd - >/dev/null
25b86db1 91 testsuccessequal "$(aptcache show testpkg -o Acquire::Languages=none)
4dde2b42 92" aptcache dumpavail
f213b6ea
DK
93}
94
5f982b9d
DK
95echo 'Debug::pkgAcquire::worker "true";
96debug::pkgAcquire::Auth "true";
70b63c57
DK
97Debug::pkgAcquire::Diffs "true";
98Debug::Acquire::http "true";' > rootdir/etc/apt/apt.conf.d/99debugconf
f213b6ea 99
5f982b9d
DK
100testovermethod() {
101 forcecompressor $2
f213b6ea 102
5f982b9d
DK
103 for INDEX in 'false' 'true'; do
104 rm -rf rootdir/var/lib/apt/lists
105 echo "Acquire::GzipIndexes \"${INDEX}\";" > rootdir/etc/apt/apt.conf.d/02compressindex
106 local INDCOMP
70b63c57 107 if [ "$INDEX" = 'false' -o "$1" = 'cdrom' ]; then
5f982b9d
DK
108 INDCOMP='uncompressed'
109 else
110 INDCOMP='compressed'
b2fd8524 111 echo 'APT::Compressor::lz4::Name "lz4";' >> rootdir/etc/apt/apt.conf.d/02compressindex
5f982b9d 112 fi
f213b6ea 113
70b63c57
DK
114 msgmsg "${1}: ${COMPRESSOR}: Test with $INDCOMP indexes gzip=$INDEX"
115 if [ "${1}" = 'cdrom' ]; then
116 testsuccess aptcdrom add </dev/null
117 fi
118 testsuccess aptget update
5f982b9d 119 testrun "$INDCOMP"
f213b6ea 120
70b63c57
DK
121 if [ "${1}" != 'cdrom' ]; then
122 testsuccess aptget update -o Acquire::Pdiffs=1
123 msgmsg "${1}: ${COMPRESSOR}: Test with $INDCOMP indexes gzip=$INDEX (update unchanged with pdiffs)"
124 testrun "$INDCOMP"
f213b6ea 125
70b63c57
DK
126 testsuccess aptget update -o Acquire::Pdiffs=0
127 msgmsg "${1}: ${COMPRESSOR}: Test with $INDCOMP indexes gzip=$INDEX (update unchanged without pdiffs)"
128 testrun "$INDCOMP"
129 fi
f213b6ea 130
5f982b9d
DK
131 rm rootdir/etc/apt/apt.conf.d/02compressindex
132 done
133}
f213b6ea 134
0440d936 135testsuccess aptget update
5f982b9d
DK
136GOODSHOW="$(aptcache show testpkg)
137"
138test $(echo "$GOODSHOW" | grep -e '^Package: testpkg' -e '^Version: 1.0' -e '^Architecture: i386' | wc -l) -eq 3 || msgdie 'show is broken'
25b86db1 139testsuccessequal "$GOODSHOW" aptcache show testpkg
5f982b9d
DK
140GOODSHOWSRC="$(aptcache showsrc testpkg)
141"
142test $(echo "$GOODSHOWSRC" | grep -e '^Package: testpkg' -e '^Format: 3.0 (native)' -e '^Files:' -e '^Checksums-Sha256:' | wc -l) -eq 4 || msgdie 'showsrc is broken'
25b86db1 143testsuccessequal "$GOODSHOWSRC" aptcache showsrc testpkg
718f797c 144GOODPOLICY="$(aptcache policy testpkg)"
af9e40c9 145test $(echo "$GOODPOLICY" | grep -e '^testpkg:' -e '^ Candidate:' -e '^ Installed: (none)' -e '500 file:/' | wc -l) -eq 4 || msgdie 'file policy is broken'
25b86db1 146testsuccessequal "$GOODPOLICY" aptcache policy testpkg
912a6131 147forallsupportedcompressors testovermethod 'file'
f213b6ea 148
af9e40c9 149rewritesourceslist "copy://${TMPWORKINGDIRECTORY}/aptarchive"
f213b6ea 150rm -rf rootdir/var/lib/apt/lists
0440d936 151testsuccess aptget update
5f982b9d 152GOODPOLICY="$(aptcache policy testpkg)"
af9e40c9 153test $(echo "$GOODPOLICY" | grep -e '^testpkg:' -e '^ Candidate:' -e '^ Installed: (none)' -e '500 copy:/' | wc -l) -eq 4 || msgdie 'copy policy is broken'
25b86db1 154testsuccessequal "$GOODPOLICY" aptcache policy testpkg
912a6131 155forallsupportedcompressors testovermethod 'copy'
f213b6ea 156
af9e40c9
DK
157changetowebserver
158rm -rf rootdir/var/lib/apt/lists
159testsuccess aptget update
160GOODPOLICY="$(aptcache policy testpkg)"
161test $(echo "$GOODPOLICY" | grep -e '^testpkg:' -e '^ Candidate:' -e '^ Installed: (none)' -e '500 http://' | wc -l) -eq 4 || msgdie 'http policy is broken'
162testsuccessequal "$GOODPOLICY" aptcache policy testpkg
912a6131 163forallsupportedcompressors testovermethod 'http'
70b63c57 164
af9e40c9
DK
165changetohttpswebserver
166rm -rf rootdir/var/lib/apt/lists
167testsuccess aptget update
168GOODPOLICY="$(aptcache policy testpkg)"
169test $(echo "$GOODPOLICY" | grep -e '^testpkg:' -e '^ Candidate:' -e '^ Installed: (none)' -e '500 https://' | wc -l) -eq 4 || msgdie 'https policy is broken'
170testsuccessequal "$GOODPOLICY" aptcache policy testpkg
912a6131 171forallsupportedcompressors testovermethod 'https'
af9e40c9 172
70b63c57
DK
173changetocdrom 'Debian APT Testdisk 0.8.15'
174rm -rf rootdir/var/lib/apt/lists
175testsuccess aptcdrom add </dev/null
176GOODPOLICY="$(aptcache policy testpkg)"
af9e40c9 177test $(echo "$GOODPOLICY" | grep -e '^testpkg:' -e '^ Candidate:' -e '^ Installed: (none)' -e '500 cdrom://' | wc -l) -eq 4 || msgdie 'cdrom policy is broken'
25b86db1 178testsuccessequal "$GOODPOLICY" aptcache policy testpkg
912a6131 179forallsupportedcompressors testovermethod 'cdrom'