always run 'dpkg --configure -a' at the end of our dpkg callings
[ntk/apt.git] / test / integration / test-ubuntu-bug-1098738-apt-get-source-md5sum
CommitLineData
3a2b39ee
DK
1#!/bin/sh
2set -e
3
4TESTDIR=$(readlink -f $(dirname $0))
5. $TESTDIR/framework
6
7setupenvironment
8configarchitecture 'native'
9
10cat > aptarchive/Sources <<EOF
11Package: pkg-md5-ok
12Binary: pkg-md5-ok
13Version: 1.0
14Maintainer: Joe Sixpack <joe@example.org>
15Architecture: all
16Files:
17 d41d8cd98f00b204e9800998ecf8427e 0 pkg-md5-ok_1.0.dsc
18 d41d8cd98f00b204e9800998ecf8427e 0 pkg-md5-ok_1.0.tar.gz
19
20Package: pkg-sha256-ok
21Binary: pkg-sha256-ok
22Version: 1.0
23Maintainer: Joe Sixpack <joe@example.org>
24Architecture: all
25Files:
26 d41d8cd98f00b204e9800998ecf8427e 0 pkg-sha256-ok_1.0.dsc
27 d41d8cd98f00b204e9800998ecf8427e 0 pkg-sha256-ok_1.0.tar.gz
28Checksums-Sha1:
29 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-sha256-ok_1.0.dsc
30 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-sha256-ok_1.0.tar.gz
31Checksums-Sha256:
32 e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 0 pkg-sha256-ok_1.0.dsc
33 e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 0 pkg-sha256-ok_1.0.tar.gz
34
35Package: pkg-sha256-bad
36Binary: pkg-sha256-bad
37Version: 1.0
38Maintainer: Joe Sixpack <joe@example.org>
39Architecture: all
40Files:
41 d41d8cd98f00b204e9800998ecf8427e 0 pkg-sha256-bad_1.0.dsc
42 d41d8cd98f00b204e9800998ecf8427e 0 pkg-sha256-bad_1.0.tar.gz
43Checksums-Sha1:
44 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-sha256-bad_1.0.dsc
45 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-sha256-bad_1.0.tar.gz
46Checksums-Sha256:
47 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 0 pkg-sha256-bad_1.0.dsc
48 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb 0 pkg-sha256-bad_1.0.tar.gz
49
50Package: pkg-no-md5
51Binary: pkg-no-md5
52Version: 1.0
53Maintainer: Joe Sixpack <joe@example.org>
54Architecture: all
55Checksums-Sha1:
56 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-no-md5_1.0.dsc
57 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-no-md5_1.0.tar.gz
58Checksums-Sha256:
59 e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 0 pkg-no-md5_1.0.dsc
60 e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 0 pkg-no-md5_1.0.tar.gz
61
62Package: pkg-mixed-ok
63Binary: pkg-mixed-ok
64Version: 1.0
65Maintainer: Joe Sixpack <joe@example.org>
66Architecture: all
67Checksums-Sha1:
68 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-mixed-ok_1.0.tar.gz
69Checksums-Sha256:
70 e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 0 pkg-mixed-ok_1.0.dsc
71
72Package: pkg-mixed-sha1-bad
73Binary: pkg-mixed-sha1-bad
74Version: 1.0
75Maintainer: Joe Sixpack <joe@example.org>
76Architecture: all
77Checksums-Sha1:
78 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 0 pkg-mixed-sha1-bad_1.0.dsc
79Checksums-Sha256:
80 e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 0 pkg-mixed-sha1-bad_1.0.tar.gz
81
82Package: pkg-mixed-sha2-bad
83Binary: pkg-mixed-sha2-bad
84Version: 1.0
85Maintainer: Joe Sixpack <joe@example.org>
86Architecture: all
87Checksums-Sha1:
88 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-mixed-sha2-bad_1.0.dsc
89Checksums-Sha256:
90 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb 0 pkg-mixed-sha2-bad_1.0.tar.gz
91
92Package: pkg-md5-disagree
93Binary: pkg-md5-disagree
94Version: 1.0
95Maintainer: Joe Sixpack <joe@example.org>
96Architecture: all
97Files:
98 d41d8cd98f00b204e9800998ecf8427e 0 pkg-md5-disagree_1.0.dsc
99 d41d8cd98f00b204e9800998ecf8427e 0 pkg-md5-disagree_1.0.tar.gz
100 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 0 pkg-md5-disagree_1.0.dsc
101 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb 0 pkg-md5-disagree_1.0.tar.gz
102
103Package: pkg-md5-agree
104Binary: pkg-md5-agree
105Version: 1.0
106Maintainer: Joe Sixpack <joe@example.org>
107Architecture: all
108Files:
109 d41d8cd98f00b204e9800998ecf8427e 0 pkg-md5-agree_1.0.dsc
110 d41d8cd98f00b204e9800998ecf8427e 0 pkg-md5-agree_1.0.tar.gz
111 d41d8cd98f00b204e9800998ecf8427e 0 pkg-md5-agree_1.0.tar.gz
112 d41d8cd98f00b204e9800998ecf8427e 0 pkg-md5-agree_1.0.dsc
113
114Package: pkg-sha256-disagree
115Binary: pkg-sha256-disagree
116Version: 1.0
117Maintainer: Joe Sixpack <joe@example.org>
118Architecture: all
119Files:
120 d41d8cd98f00b204e9800998ecf8427e 0 pkg-sha256-disagree_1.0.dsc
121 d41d8cd98f00b204e9800998ecf8427e 0 pkg-sha256-disagree_1.0.tar.gz
122Checksums-Sha1:
123 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-sha256-disagree_1.0.dsc
124 da39a3ee5e6b4b0d3255bfef95601890afd80709 0 pkg-sha256-disagree_1.0.tar.gz
125Checksums-Sha256:
126 e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 0 pkg-sha256-disagree_1.0.dsc
127 e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 0 pkg-sha256-disagree_1.0.tar.gz
128 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 0 pkg-sha256-disagree_1.0.dsc
129 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb 0 pkg-sha256-disagree_1.0.tar.gz
130EOF
131
132# create fetchable files
133for 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 touch aptarchive/${x}_1.0.dsc aptarchive/${x}_1.0.tar.gz
137done
138
139setupaptarchive
140changetowebserver
141testsuccess aptget update
142
143testok() {
144 rm -f ${1}_1.0.dsc ${1}_1.0.tar.gz
145 testequal "Reading package lists...
146Building dependency tree...
147Need to get 0 B of source archives.
148Get:1 http://localhost:8080/ $1 1.0 (dsc)
149Get:2 http://localhost:8080/ $1 1.0 (tar)
150Download complete and in download only mode" aptget source -d "$@"
151 msgtest 'Files were successfully downloaded for' "$1"
152 testsuccess --nomsg test -e ${1}_1.0.dsc -a -e ${1}_1.0.tar.gz
153 rm -f ${1}_1.0.dsc ${1}_1.0.tar.gz
154}
155
156testkeep() {
157 touch ${1}_1.0.dsc ${1}_1.0.tar.gz
158 testequal "Reading package lists...
159Building dependency tree...
160Skipping already downloaded file '${1}_1.0.dsc'
161Skipping already downloaded file '${1}_1.0.tar.gz'
162Need to get 0 B of source archives.
163Download complete and in download only mode" aptget source -d "$@"
164 msgtest 'Files already downloaded are kept for' "$1"
165 testsuccess --nomsg test -e ${1}_1.0.dsc -a -e ${1}_1.0.tar.gz
166 rm -f ${1}_1.0.dsc ${1}_1.0.tar.gz
167}
168
169testmismatch() {
170 rm -f ${1}_1.0.dsc ${1}_1.0.tar.gz
171 testequal "Reading package lists...
172Building dependency tree...
173Need to get 0 B of source archives.
174Get:1 http://localhost:8080/ $1 1.0 (dsc)
175Get:2 http://localhost:8080/ $1 1.0 (tar)
176E: Failed to fetch http://localhost:8080/${1}_1.0.dsc Hash Sum mismatch
177
178E: Failed to fetch http://localhost:8080/${1}_1.0.tar.gz Hash Sum mismatch
179
180E: Failed to fetch some archives." aptget source -d "$@"
181 msgtest 'Files were not download as they have hashsum mismatches for' "$1"
182 testfailure --nomsg test -e ${1}_1.0.dsc -a -e ${1}_1.0.tar.gz
183
184 rm -f ${1}_1.0.dsc ${1}_1.0.tar.gz
185 testequal "Reading package lists...
186Building dependency tree...
187Skipping download of file 'pkg-sha256-bad_1.0.dsc' as requested hashsum is not available for authentication
188Skipping download of file 'pkg-sha256-bad_1.0.tar.gz' as requested hashsum is not available for authentication
189Need to get 0 B of source archives.
190Download complete and in download only mode" aptget source -d "$@" -o Acquire::ForceHash=ROT26
191 msgtest 'Files were not download as hash is unavailable for' "$1"
192 testfailure --nomsg test -e ${1}_1.0.dsc -a -e ${1}_1.0.tar.gz
193
194 rm -f ${1}_1.0.dsc ${1}_1.0.tar.gz
195 testequal "Reading package lists...
196Building dependency tree...
197Need to get 0 B of source archives.
198Get:1 http://localhost:8080/ $1 1.0 (dsc)
199Get:2 http://localhost:8080/ $1 1.0 (tar)
200Download complete and in download only mode" aptget source --allow-unauthenticated -d "$@" -o Acquire::ForceHash=ROT26
201 msgtest 'Files were downloaded unauthenticated as user allowed it' "$1"
202 testsuccess --nomsg test -e ${1}_1.0.dsc -a -e ${1}_1.0.tar.gz
203}
204
205testok pkg-md5-ok
206testkeep pkg-md5-ok
207testok pkg-sha256-ok
208testkeep pkg-sha256-ok
209
210# pkg-sha256-bad has a bad SHA sum, but good MD5 sum. If apt is
211# checking the best available hash (as it should), this will trigger
212# a hash mismatch.
213testmismatch pkg-sha256-bad
214testmismatch pkg-sha256-bad
215testok pkg-sha256-bad -o Acquire::ForceHash=MD5Sum
216
217# not having MD5 sum doesn't mean the file doesn't exist at all …
218testok pkg-no-md5
219testok pkg-no-md5 -o Acquire::ForceHash=SHA256
220testequal "Reading package lists...
221Building dependency tree...
222Skipping download of file 'pkg-no-md5_1.0.dsc' as requested hashsum is not available for authentication
223Skipping download of file 'pkg-no-md5_1.0.tar.gz' as requested hashsum is not available for authentication
224Need to get 0 B of source archives.
225Download complete and in download only mode" aptget source -d pkg-no-md5 -o Acquire::ForceHash=MD5Sum
226msgtest 'Files were not download as MD5 is not available for this package' 'pkg-no-md5'
227testfailure --nomsg test -e pkg-no-md5_1.0.dsc -a -e pkg-no-md5_1.0.tar.gz
228
229# deal with cases in which we haven't for all files the same checksum type
230# mostly pathologic as this shouldn't happen, but just to be sure
231testok pkg-mixed-ok
232testequal 'Reading package lists...
233Building dependency tree...
234Need to get 0 B of source archives.
235Get:1 http://localhost:8080/ pkg-mixed-sha1-bad 1.0 (tar)
236Get:2 http://localhost:8080/ pkg-mixed-sha1-bad 1.0 (dsc)
237E: Failed to fetch http://localhost:8080/pkg-mixed-sha1-bad_1.0.dsc Hash Sum mismatch
238
239E: Failed to fetch some archives.' aptget source -d pkg-mixed-sha1-bad
240msgtest 'Only tar file is downloaded as the dsc has hashsum mismatch' 'pkg-mixed-sha1-bad'
241testsuccess --nomsg test ! -e pkg-mixed-sha1-bad_1.0.dsc -a -e pkg-mixed-sha1-bad_1.0.tar.gz
242testequal 'Reading package lists...
243Building dependency tree...
244Need to get 0 B of source archives.
245Get:1 http://localhost:8080/ pkg-mixed-sha2-bad 1.0 (tar)
246Get:2 http://localhost:8080/ pkg-mixed-sha2-bad 1.0 (dsc)
247E: Failed to fetch http://localhost:8080/pkg-mixed-sha2-bad_1.0.tar.gz Hash Sum mismatch
248
249E: Failed to fetch some archives.' aptget source -d pkg-mixed-sha2-bad
250msgtest 'Only dsc file is downloaded as the tar has hashsum mismatch' 'pkg-mixed-sha2-bad'
251testsuccess --nomsg test -e pkg-mixed-sha2-bad_1.0.dsc -a ! -e pkg-mixed-sha2-bad_1.0.tar.gz
252
253# it gets even more pathologic: multiple entries for one file, some even disagreeing!
254testok pkg-md5-agree
255testequal 'Reading package lists...
256Building dependency tree...
257E: Error parsing checksum in Files of source package pkg-md5-disagree' aptget source -d pkg-md5-disagree
258testequal 'Reading package lists...
259Building dependency tree...
260E: Error parsing checksum in Checksums-SHA256 of source package pkg-sha256-disagree' aptget source -d pkg-sha256-disagree