]> git.saurik.com Git - apt.git/blob - test/integration/test-http-pipeline-messup
tests: ensure sponge-files are cleaned up properly
[apt.git] / test / integration / test-http-pipeline-messup
1 #!/bin/sh
2 set -e
3
4 TESTDIR=$(readlink -f $(dirname $0))
5 . $TESTDIR/framework
6
7 setupenvironment
8 configarchitecture "i386"
9
10 # try a little harder to create a size mismatch
11 buildsimplenativepackage 'pkga' 'all' '1.0' 'stable' "Depends: foo" '' '' '' '' 'none'
12 buildsimplenativepackage 'pkgb' 'all' '1.0' 'stable' "Depends: foo" '' '' '' '' 'none'
13 buildsimplenativepackage 'pkgc' 'all' '1.0' 'stable' "Depends: f$(for i in $(seq 0 1000); do printf 'o'; done)" '' '' '' '' 'none'
14 buildsimplenativepackage 'pkgd' 'all' '1.0' 'stable' "Depends: f$(for i in $(seq 0 1000); do printf 'o'; done)" '' '' '' '' 'none'
15
16 setupaptarchive --no-update
17
18 # simulate (and be a predictable) pipeline mess-up by the server/proxy
19 changetowebserver \
20 -o 'aptwebserver::overwrite::.*pkga.*::filename=/pool/pkgd_1.0_all.deb' \
21 -o 'aptwebserver::overwrite::.*pkgc.*::filename=/pool/pkgb_1.0_all.deb' \
22 -o 'aptwebserver::overwrite::.*pkgb.*::filename=/pool/pkgc_1.0_all.deb' \
23 -o 'aptwebserver::overwrite::.*pkgd.*::filename=/pool/pkga_1.0_all.deb'
24
25 echo 'Debug::Acquire::http "true";
26 Debug::pkgAcquire::Worker "true";' > rootdir/etc/apt/apt.conf.d/99debug
27
28 testsuccess aptget update
29
30 cd downloaded
31 # messup is bigger than pipeline: checks if fixup isn't trying too hard
32 testfailure aptget download pkga pkgb pkgc pkgd -o Acquire::http::Pipeline-Depth=2
33 for pkg in 'pkga' 'pkgd'; do
34 testfailure test -f ${pkg}_1.0_all.deb
35 done
36 for pkg in 'pkgb' 'pkgc'; do
37 testsuccess test -f ${pkg}_1.0_all.deb
38 testsuccess cmp ../incoming/${pkg}_1.0_all.deb ${pkg}_1.0_all.deb
39 rm -f ${pkg}_1.0_all.deb
40 done
41
42 # ensure that pipeling is enabled for rest of this test
43 echo 'Acquire::http::Pipeline-Depth 10;' > ../rootdir/etc/apt/apt.conf.d/99enable-pipeline
44
45 # the output is a bit strange: it looks like it has downloaded pkga 4 times
46 testwarning aptget download pkga pkgb pkgc pkgd
47 for pkg in 'pkga' 'pkgb' 'pkgc' 'pkgd'; do
48 testsuccess test -f ${pkg}_1.0_all.deb
49 testsuccess cmp ../incoming/${pkg}_1.0_all.deb ${pkg}_1.0_all.deb
50 rm -f ${pkg}_1.0_all.deb
51 done
52
53 # while hashes will pass (as none are available), sizes will not match, so failure
54 # checks that no hashes means that pipeline depth is ignored as we can't fixup
55 testfailure aptget download pkga pkgb pkgc pkgd --allow-unauthenticated -o Acquire::ForceHash=ROT26