4 TESTDIR
=$(readlink -f $(dirname $0))
8 configarchitecture
'native'
10 cat > aptarchive
/Sources
<<EOF
14 Maintainer: Joe Sixpack <joe@example.org>
17 9604ba9427a280db542279d9ed78400b 3 pkg-md5-ok_1.0.dsc
18 db5570bf61464b46e2bde31ed61a7dc6 3 pkg-md5-ok_1.0.tar.gz
20 Package: pkg-sha256-ok
23 Maintainer: Joe Sixpack <joe@example.org>
26 9604ba9427a280db542279d9ed78400b 3 pkg-sha256-ok_1.0.dsc
27 db5570bf61464b46e2bde31ed61a7dc6 3 pkg-sha256-ok_1.0.tar.gz
29 324f464e6151a92cf57b26ef95dcfcf2059a8c44 3 pkg-sha256-ok_1.0.dsc
30 680254bad1d7ca0d65ec46aaa315d363abf6a50a 3 pkg-sha256-ok_1.0.tar.gz
32 943d3bf22ac661fb0f59bc4ff68cc12b04ff17a838dfcc2537008eb9c7f3770a 3 pkg-sha256-ok_1.0.dsc
33 90aebae315675cbf04612de4f7d5874850f48e0b8dd82becbeaa47ca93f5ebfb 3 pkg-sha256-ok_1.0.tar.gz
35 Package: pkg-sha256-bad
36 Binary: pkg-sha256-bad
38 Maintainer: Joe Sixpack <joe@example.org>
41 9604ba9427a280db542279d9ed78400b 3 pkg-sha256-bad_1.0.dsc
42 db5570bf61464b46e2bde31ed61a7dc6 3 pkg-sha256-bad_1.0.tar.gz
44 324f464e6151a92cf57b26ef95dcfcf2059a8c44 3 pkg-sha256-bad_1.0.dsc
45 680254bad1d7ca0d65ec46aaa315d363abf6a50a 3 pkg-sha256-bad_1.0.tar.gz
47 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 3 pkg-sha256-bad_1.0.dsc
48 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb 3 pkg-sha256-bad_1.0.tar.gz
53 Maintainer: Joe Sixpack <joe@example.org>
56 324f464e6151a92cf57b26ef95dcfcf2059a8c44 3 pkg-no-md5_1.0.dsc
57 680254bad1d7ca0d65ec46aaa315d363abf6a50a 3 pkg-no-md5_1.0.tar.gz
59 943d3bf22ac661fb0f59bc4ff68cc12b04ff17a838dfcc2537008eb9c7f3770a 3 pkg-no-md5_1.0.dsc
60 90aebae315675cbf04612de4f7d5874850f48e0b8dd82becbeaa47ca93f5ebfb 3 pkg-no-md5_1.0.tar.gz
65 Maintainer: Joe Sixpack <joe@example.org>
68 680254bad1d7ca0d65ec46aaa315d363abf6a50a 3 pkg-mixed-ok_1.0.tar.gz
70 943d3bf22ac661fb0f59bc4ff68cc12b04ff17a838dfcc2537008eb9c7f3770a 3 pkg-mixed-ok_1.0.dsc
72 Package: pkg-mixed-sha1-bad
73 Binary: pkg-mixed-sha1-bad
75 Maintainer: Joe Sixpack <joe@example.org>
78 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 3 pkg-mixed-sha1-bad_1.0.dsc
80 90aebae315675cbf04612de4f7d5874850f48e0b8dd82becbeaa47ca93f5ebfb 3 pkg-mixed-sha1-bad_1.0.tar.gz
82 Package: pkg-mixed-sha2-bad
83 Binary: pkg-mixed-sha2-bad
85 Maintainer: Joe Sixpack <joe@example.org>
88 324f464e6151a92cf57b26ef95dcfcf2059a8c44 3 pkg-mixed-sha2-bad_1.0.dsc
90 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb 3 pkg-mixed-sha2-bad_1.0.tar.gz
92 Package: pkg-md5-disagree
93 Binary: pkg-md5-disagree
95 Maintainer: Joe Sixpack <joe@example.org>
98 9604ba9427a280db542279d9ed78400b 3 pkg-md5-disagree_1.0.dsc
99 db5570bf61464b46e2bde31ed61a7dc6 3 pkg-md5-disagree_1.0.tar.gz
100 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 3 pkg-md5-disagree_1.0.dsc
101 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb 3 pkg-md5-disagree_1.0.tar.gz
103 Package: pkg-md5-agree
104 Binary: pkg-md5-agree
106 Maintainer: Joe Sixpack <joe@example.org>
109 9604ba9427a280db542279d9ed78400b 3 pkg-md5-agree_1.0.dsc
110 db5570bf61464b46e2bde31ed61a7dc6 3 pkg-md5-agree_1.0.tar.gz
111 db5570bf61464b46e2bde31ed61a7dc6 3 pkg-md5-agree_1.0.tar.gz
112 9604ba9427a280db542279d9ed78400b 3 pkg-md5-agree_1.0.dsc
114 Package: pkg-sha256-disagree
115 Binary: pkg-sha256-disagree
117 Maintainer: Joe Sixpack <joe@example.org>
120 9604ba9427a280db542279d9ed78400b 3 pkg-sha256-disagree_1.0.dsc
121 db5570bf61464b46e2bde31ed61a7dc6 3 pkg-sha256-disagree_1.0.tar.gz
123 324f464e6151a92cf57b26ef95dcfcf2059a8c44 3 pkg-sha256-disagree_1.0.dsc
124 680254bad1d7ca0d65ec46aaa315d363abf6a50a 3 pkg-sha256-disagree_1.0.tar.gz
126 943d3bf22ac661fb0f59bc4ff68cc12b04ff17a838dfcc2537008eb9c7f3770a 3 pkg-sha256-disagree_1.0.dsc
127 90aebae315675cbf04612de4f7d5874850f48e0b8dd82becbeaa47ca93f5ebfb 3 pkg-sha256-disagree_1.0.tar.gz
128 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 3 pkg-sha256-disagree_1.0.dsc
129 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb 3 pkg-sha256-disagree_1.0.tar.gz
132 # create fetchable files
133 for x
in 'pkg-md5-ok' 'pkg-sha256-ok' 'pkg-sha256-bad' 'pkg-no-md5' \
134 'pkg-mixed-ok' 'pkg-mixed-sha1-bad' 'pkg-mixed-sha2-bad' \
135 'pkg-md5-agree' 'pkg-md5-disagree' 'pkg-sha256-disagree'; do
136 echo -n 'dsc' > aptarchive
/${x}_1.0.dsc
137 echo -n 'tar' > aptarchive
/${x}_1.0.
tar.gz
142 testsuccess aptget update
147 rm -f ${1}_1.0.dsc
${1}_1.0.
tar.gz
148 testsuccessequal
"Reading package lists...
149 Building dependency tree...
150 Need to get 6 B of source archives.
151 Get:1 http://localhost:8080/ $1 1.0 (dsc) [3 B]
152 Get:2 http://localhost:8080/ $1 1.0 (tar) [3 B]
153 Download complete and in download only mode" aptget
source -d "$@"
154 msgtest
'Files were successfully downloaded for' "$1"
155 testsuccess
--nomsg test -e ${1}_1.0.dsc
-a -e ${1}_1.0.
tar.gz
156 rm -f ${1}_1.0.dsc
${1}_1.0.
tar.gz
160 echo -n 'dsc' > ${1}_1.0.dsc
161 echo -n 'tar' > ${1}_1.0.
tar.gz
162 testsuccessequal
"Reading package lists...
163 Building dependency tree...
164 Skipping already downloaded file '${1}_1.0.dsc'
165 Skipping already downloaded file '${1}_1.0.tar.gz'
166 Need to get 0 B of source archives.
167 Download complete and in download only mode" aptget
source -d "$@"
168 msgtest
'Files already downloaded are kept for' "$1"
169 testsuccess
--nomsg test -e ${1}_1.0.dsc
-a -e ${1}_1.0.
tar.gz
170 rm -f ${1}_1.0.dsc
${1}_1.0.
tar.gz
174 rm -f ${1}_1.0.dsc
${1}_1.0.
tar.gz
175 testfailureequal
"Reading package lists...
176 Building dependency tree...
177 Need to get 6 B of source archives.
178 Get:1 http://localhost:8080/ $1 1.0 (dsc) [3 B]
179 Err http://localhost:8080/ $1 1.0 (dsc)
181 Get:2 http://localhost:8080/ $1 1.0 (tar) [3 B]
182 Err http://localhost:8080/ $1 1.0 (tar)
184 E: Failed to fetch http://localhost:8080/${1}_1.0.dsc Hash Sum mismatch
186 E: Failed to fetch http://localhost:8080/${1}_1.0.tar.gz Hash Sum mismatch
188 E: Failed to fetch some archives." aptget
source -d "$@"
189 msgtest
'Files were not download as they have hashsum mismatches for' "$1"
190 testfailure
--nomsg test -e ${1}_1.0.dsc
-a -e ${1}_1.0.
tar.gz
192 rm -f ${1}_1.0.dsc
${1}_1.0.
tar.gz
193 testsuccessequal
"Reading package lists...
194 Building dependency tree...
195 Skipping download of file 'pkg-sha256-bad_1.0.dsc' as requested hashsum is not available for authentication
196 Skipping download of file 'pkg-sha256-bad_1.0.tar.gz' as requested hashsum is not available for authentication
197 Need to get 0 B of source archives.
198 Download complete and in download only mode" aptget
source -d "$@" -o Acquire
::ForceHash
=ROT26
199 msgtest
'Files were not download as hash is unavailable for' "$1"
200 testfailure
--nomsg test -e ${1}_1.0.dsc
-a -e ${1}_1.0.
tar.gz
202 rm -f ${1}_1.0.dsc
${1}_1.0.
tar.gz
203 testsuccessequal
"Reading package lists...
204 Building dependency tree...
205 Need to get 6 B of source archives.
206 Get:1 http://localhost:8080/ $1 1.0 (dsc) [3 B]
207 Get:2 http://localhost:8080/ $1 1.0 (tar) [3 B]
208 Download complete and in download only mode" aptget
source --allow-unauthenticated -d "$@" -o Acquire
::ForceHash
=ROT26
209 msgtest
'Files were downloaded unauthenticated as user allowed it' "$1"
210 testsuccess
--nomsg test -e ${1}_1.0.dsc
-a -e ${1}_1.0.
tar.gz
216 testkeep pkg
-sha256-ok
218 # pkg-sha256-bad has a bad SHA sum, but good MD5 sum. If apt is
219 # checking the best available hash (as it should), this will trigger
221 testmismatch pkg
-sha256-bad
222 testmismatch pkg
-sha256-bad
223 testok pkg
-sha256-bad -o Acquire
::ForceHash
=MD5Sum
225 # not having MD5 sum doesn't mean the file doesn't exist at all …
227 testok pkg
-no-md5 -o Acquire
::ForceHash
=SHA256
228 testsuccessequal
"Reading package lists...
229 Building dependency tree...
230 Skipping download of file 'pkg-no-md5_1.0.dsc' as requested hashsum is not available for authentication
231 Skipping download of file 'pkg-no-md5_1.0.tar.gz' as requested hashsum is not available for authentication
232 Need to get 0 B of source archives.
233 Download complete and in download only mode" aptget
source -d pkg
-no-md5 -o Acquire
::ForceHash
=MD5Sum
234 msgtest
'Files were not download as MD5 is not available for this package' 'pkg-no-md5'
235 testfailure
--nomsg test -e pkg
-no-md5_1.0.dsc
-a -e pkg
-no-md5_1.0.
tar.gz
237 # deal with cases in which we haven't for all files the same checksum type
238 # mostly pathologic as this shouldn't happen, but just to be sure
240 testfailureequal
'Reading package lists...
241 Building dependency tree...
242 Need to get 6 B of source archives.
243 Get:1 http://localhost:8080/ pkg-mixed-sha1-bad 1.0 (tar) [3 B]
244 Get:2 http://localhost:8080/ pkg-mixed-sha1-bad 1.0 (dsc) [3 B]
245 Err http://localhost:8080/ pkg-mixed-sha1-bad 1.0 (dsc)
247 E: Failed to fetch http://localhost:8080/pkg-mixed-sha1-bad_1.0.dsc Hash Sum mismatch
249 E: Failed to fetch some archives.' aptget
source -d pkg
-mixed-sha1-bad
250 msgtest
'Only tar file is downloaded as the dsc has hashsum mismatch' 'pkg-mixed-sha1-bad'
251 testsuccess
--nomsg test ! -e pkg
-mixed-sha1-bad_1.0.dsc
-a -e pkg
-mixed-sha1-bad_1.0.
tar.gz
252 testfailureequal
'Reading package lists...
253 Building dependency tree...
254 Need to get 6 B of source archives.
255 Get:1 http://localhost:8080/ pkg-mixed-sha2-bad 1.0 (tar) [3 B]
256 Err http://localhost:8080/ pkg-mixed-sha2-bad 1.0 (tar)
258 Get:2 http://localhost:8080/ pkg-mixed-sha2-bad 1.0 (dsc) [3 B]
259 E: Failed to fetch http://localhost:8080/pkg-mixed-sha2-bad_1.0.tar.gz Hash Sum mismatch
261 E: Failed to fetch some archives.' aptget
source -d pkg
-mixed-sha2-bad
262 msgtest
'Only dsc file is downloaded as the tar has hashsum mismatch' 'pkg-mixed-sha2-bad'
263 testsuccess
--nomsg test -e pkg
-mixed-sha2-bad_1.0.dsc
-a ! -e pkg
-mixed-sha2-bad_1.0.
tar.gz
265 # it gets even more pathologic: multiple entries for one file, some even disagreeing!
267 testfailureequal
'Reading package lists...
268 Building dependency tree...
269 E: Error parsing checksum in Files of source package pkg-md5-disagree' aptget
source -d pkg
-md5-disagree
270 testfailureequal
'Reading package lists...
271 Building dependency tree...
272 E: Error parsing checksum in Checksums-SHA256 of source package pkg-sha256-disagree' aptget
source -d pkg
-sha256-disagree