123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193 |
- #!/bin/sh
- set -e
- TESTDIR="$(readlink -f "$(dirname "$0")")"
- . "$TESTDIR/framework"
- setupenvironment
- configarchitecture 'amd64'
- insertpackage 'unstable' 'unrelated' 'all' '0.5~squeeze1'
- insertpackage 'unstable' 'unrelated2' 'amd64' '0.5~squeeze1'
- insertsource 'unstable' 'unrelated' 'all' '0.5~squeeze1'
- export APT_DONT_SIGN=""
- setupaptarchive --no-update
- logcurrentarchivedirectory
- changetowebserver
- runtest() {
- local APTOPT=""
- if [ -n "$1" ]; then
- APTOPT='--allow-insecure-repositories'
- else
- APTOPT='--no-allow-insecure-repositories'
- fi
- rm -rf rootdir/var/lib/apt/lists/
- local TEST="test${1:-success}"
- $TEST aptget update $APTOPT -o Debug::pkgAcquire::Worker=1
- if [ "$1" = 'failure' ]; then
- # accept the outdated Release file so we can check Hit behaviour
- "test${2:-success}" aptget update -o Acquire::Min-ValidTime=9999999 $APTOPT
- fi
- listcurrentlistsdirectory > listsdir.lst
- testsuccess grep '_Packages\(\.[0-9a-z]\+\)\?$' listsdir.lst
- testsuccess grep '_Sources\(\.[0-9a-z]\+\)\?$' listsdir.lst
- testsuccess grep '_Translation-en\(\.[0-9a-z]\+\)\?$' listsdir.lst
- # ensure no leftovers in partial
- testfailure ls 'rootdir/var/lib/apt/lists/partial/*'
- # check that I-M-S header is kept in redirections
- echo "$EXPECT" | sed -e 's#(invalid since [^)]\+)#(invalid since)#' > expected.output
- $TEST aptget update -o Debug::pkgAcquire::Worker=0 -o Debug::Acquire::http=0 $APTOPT
- sed -i -e 's#(invalid since [^)]\+)#(invalid since)#' rootdir/tmp/${TEST}.output
- testequal "$(cat expected.output)" cat rootdir/tmp/${TEST}.output
- testfileequal 'listsdir.lst' "$(listcurrentlistsdirectory)"
- # ensure that we still do a hash check for other files on ims hit of Release
- if grep -q '^Hit:[0-9]\+ .* InRelease$' expected.output || ! grep -q '^Ign:[0-9]\+ .* Release\(\.gpg\)\?$' expected.output; then
- $TEST aptget update -o Debug::Acquire::gpgv=1 $APTOPT
- cp rootdir/tmp/${TEST}.output goodsign.output
- testfileequal 'listsdir.lst' "$(listcurrentlistsdirectory)"
- testsuccess grep '^Got GOODSIG ' goodsign.output
- fi
- # ensure no leftovers in partial
- testfailure ls 'rootdir/var/lib/apt/lists/partial/*'
- }
- msgmsg 'InRelease'
- EXPECT="Hit:1 http://localhost:${APTHTTPPORT} unstable InRelease
- Reading package lists..."
- echo 'Acquire::GzipIndexes "0";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest
- echo 'Acquire::GzipIndexes "1";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest
- msgmsg 'Release/Release.gpg'
- EXPECT="Ign:1 http://localhost:${APTHTTPPORT} unstable InRelease
- 404 Not Found
- Hit:2 http://localhost:${APTHTTPPORT} unstable Release
- Reading package lists..."
- find aptarchive -name 'InRelease' -delete
- logcurrentarchivedirectory
- echo 'Acquire::GzipIndexes "0";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest
- echo 'Acquire::GzipIndexes "1";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest
- msgmsg 'Release only'
- EXPECT="Ign:1 http://localhost:${APTHTTPPORT} unstable InRelease
- 404 Not Found
- Hit:2 http://localhost:${APTHTTPPORT} unstable Release
- Ign:3 http://localhost:${APTHTTPPORT} unstable Release.gpg
- 404 Not Found
- Reading package lists...
- W: The repository 'http://localhost:${APTHTTPPORT} unstable Release' is not signed.
- N: Data from such a repository can't be authenticated and is therefore potentially dangerous to use.
- N: See apt-secure(8) manpage for repository creation and user configuration details."
- find aptarchive -name 'Release.gpg' -delete
- logcurrentarchivedirectory
- echo 'Acquire::GzipIndexes "0";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'warning'
- echo 'Acquire::GzipIndexes "1";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'warning'
- # make the release file old
- find aptarchive -name '*Release' -exec sed -i \
- -e "s#^Date: .*\$#Date: $(date -ud '-2 weeks' '+%a, %d %b %Y %H:%M:%S %Z')#" \
- -e '/^Valid-Until: / d' -e "/^Date: / a\
- Valid-Until: $(date -ud '-1 weeks' '+%a, %d %b %Y %H:%M:%S %Z')" '{}' \;
- signreleasefiles
- logcurrentarchivedirectory
- msgmsg 'expired InRelease'
- EXPECT="Hit:1 http://localhost:${APTHTTPPORT} unstable InRelease
- Reading package lists...
- E: Release file for http://localhost:${APTHTTPPORT}/dists/unstable/InRelease is expired (invalid since). Updates for this repository will not be applied."
- echo 'Acquire::GzipIndexes "0";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'failure'
- echo 'Acquire::GzipIndexes "1";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'failure'
- msgmsg 'expired Release/Release.gpg'
- EXPECT="Ign:1 http://localhost:${APTHTTPPORT} unstable InRelease
- 404 Not Found
- Hit:2 http://localhost:${APTHTTPPORT} unstable Release
- Reading package lists...
- E: Release file for http://localhost:${APTHTTPPORT}/dists/unstable/Release is expired (invalid since). Updates for this repository will not be applied."
- find aptarchive -name 'InRelease' -delete
- logcurrentarchivedirectory
- echo 'Acquire::GzipIndexes "0";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'failure'
- echo 'Acquire::GzipIndexes "1";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'failure'
- msgmsg 'expired Release only'
- EXPECT="Ign:1 http://localhost:${APTHTTPPORT} unstable InRelease
- 404 Not Found
- Hit:2 http://localhost:${APTHTTPPORT} unstable Release
- Ign:3 http://localhost:${APTHTTPPORT} unstable Release.gpg
- 404 Not Found
- Reading package lists...
- W: The repository 'http://localhost:${APTHTTPPORT} unstable Release' is not signed.
- N: Data from such a repository can't be authenticated and is therefore potentially dangerous to use.
- N: See apt-secure(8) manpage for repository creation and user configuration details.
- E: Release file for http://localhost:${APTHTTPPORT}/dists/unstable/Release is expired (invalid since). Updates for this repository will not be applied."
- find aptarchive -name 'Release.gpg' -delete
- logcurrentarchivedirectory
- echo 'Acquire::GzipIndexes "0";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'failure' 'warning'
- echo 'Acquire::GzipIndexes "1";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'failure' 'warning'
- msgmsg 'no Release at all'
- EXPECT="Ign:1 http://localhost:${APTHTTPPORT} unstable InRelease
- 404 Not Found
- Ign:2 http://localhost:${APTHTTPPORT} unstable Release
- 404 Not Found
- Ign:3 http://localhost:${APTHTTPPORT} unstable/main Sources
- 404 Not Found
- Ign:4 http://localhost:${APTHTTPPORT} unstable/main amd64 Packages
- 404 Not Found
- Ign:5 http://localhost:${APTHTTPPORT} unstable/main all Packages
- 404 Not Found
- Ign:6 http://localhost:${APTHTTPPORT} unstable/main Translation-en
- 404 Not Found
- Ign:3 http://localhost:${APTHTTPPORT} unstable/main Sources
- 404 Not Found
- Ign:4 http://localhost:${APTHTTPPORT} unstable/main amd64 Packages
- 404 Not Found
- Ign:5 http://localhost:${APTHTTPPORT} unstable/main all Packages
- 404 Not Found
- Ign:6 http://localhost:${APTHTTPPORT} unstable/main Translation-en
- 404 Not Found
- Ign:3 http://localhost:${APTHTTPPORT} unstable/main Sources
- 404 Not Found
- Ign:4 http://localhost:${APTHTTPPORT} unstable/main amd64 Packages
- 404 Not Found
- Ign:5 http://localhost:${APTHTTPPORT} unstable/main all Packages
- 404 Not Found
- Ign:6 http://localhost:${APTHTTPPORT} unstable/main Translation-en
- 404 Not Found
- Hit:3 http://localhost:${APTHTTPPORT} unstable/main Sources
- Hit:4 http://localhost:${APTHTTPPORT} unstable/main amd64 Packages
- Hit:5 http://localhost:${APTHTTPPORT} unstable/main all Packages
- Hit:6 http://localhost:${APTHTTPPORT} unstable/main Translation-en
- Reading package lists...
- W: The repository 'http://localhost:${APTHTTPPORT} unstable Release' does not have a Release file.
- N: Data from such a repository can't be authenticated and is therefore potentially dangerous to use.
- N: See apt-secure(8) manpage for repository creation and user configuration details."
- find aptarchive -name '*Release*' -delete
- logcurrentarchivedirectory
- echo 'Acquire::GzipIndexes "0";
- Acquire::PDiffs "0";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'warning'
- echo 'Acquire::GzipIndexes "1";
- Acquire::PDiffs "0";' > rootdir/etc/apt/apt.conf.d/02compressindex
- runtest 'warning'
|