]> git.saurik.com Git - apt.git/blob - test/integration/test-ubuntu-bug-346386-apt-get-update-paywall
properly format multiline error messages
[apt.git] / test / integration / test-ubuntu-bug-346386-apt-get-update-paywall
1 #!/bin/sh
2 set -e
3
4 TESTDIR="$(readlink -f "$(dirname "$0")")"
5 . "$TESTDIR/framework"
6
7 setupenvironment
8 configarchitecture 'native'
9
10 insertpackage 'unstable' 'unrelated' 'all' '1.0' 'stable'
11 insertsource 'unstable' 'unrelated' 'all' '1.0' 'stable'
12
13 echo 'ni ni ni' > aptarchive/knights
14
15 setupaptarchive
16 changetowebserver -o 'aptwebserver::overwrite::.*::filename=/knights'
17
18 msgtest 'Acquire test file from the webserver to check' 'overwrite'
19 if downloadfile http://localhost:${APTHTTPPORT}/holygrail ./knights-talking >/dev/null; then
20 msgpass
21 else
22 msgfail
23 fi
24
25 testfileequal knights-talking 'ni ni ni'
26
27 ensure_n_canary_strings_in_dir() {
28 local DIR="$1"
29 local CANARY_STRING="$2"
30 local EXPECTED_N="$3"
31
32 msgtest "Testing in $DIR for $EXPECTED_N canary" "$CANARY_STRING"
33 local N=$(grep "$CANARY_STRING" $DIR/* 2>/dev/null |wc -l )
34 test "$N" = "$EXPECTED_N" && msgpass || msgfail "Expected $EXPECTED_N canaries, got $N"
35 }
36
37 LISTS='rootdir/var/lib/apt/lists'
38 rm -rf rootdir/var/lib/apt/lists
39 testfailure aptget update
40 testsuccess grep '^E:.*Clearsigned file .*NOSPLIT.*' rootdir/tmp/testfailure.output
41
42 ensure_n_canary_strings_in_dir "$LISTS" 'ni ni ni' 0
43 testequal 'lock
44 partial' ls "$LISTS"
45
46 # and again with pre-existing files with "valid data" which should remain
47 for f in Release Release.gpg main_binary-amd64_Packages main_source_Sources; do
48 echo 'peng neee-wom' > "$LISTS/localhost:${APTHTTPPORT}_dists_stable_${f}"
49 chmod 644 "$LISTS/localhost:${APTHTTPPORT}_dists_stable_${f}"
50 done
51
52 testfailure aptget update
53 testsuccess grep '^E:.*Clearsigned file .*NOSPLIT.*' rootdir/tmp/testfailure.output
54
55 ensure_n_canary_strings_in_dir "$LISTS" 'peng neee-wom' 4
56 ensure_n_canary_strings_in_dir "$LISTS" 'ni ni ni' 0
57
58 # and now with a pre-existing InRelease file
59 echo 'peng neee-wom' > "$LISTS/localhost:${APTHTTPPORT}_dists_stable_InRelease"
60 chmod 644 "$LISTS/localhost:${APTHTTPPORT}_dists_stable_InRelease"
61 rm -f "$LISTS/localhost:${APTHTTPPORT}_dists_stable_Release" "$LISTS/localhost:${APTHTTPPORT}_dists_stable_Release.gpg"
62 msgtest 'excpected failure of' 'apt-get update'
63 testfailure aptget update
64 testsuccess grep '^E:.*Clearsigned file .*NOSPLIT.*' rootdir/tmp/testfailure.output
65
66 ensure_n_canary_strings_in_dir "$LISTS" 'peng neee-wom' 3
67 ensure_n_canary_strings_in_dir "$LISTS" 'ni ni ni' 0