123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- #!/bin/sh
- set -e
- TESTDIR="$(readlink -f "$(dirname "$0")")"
- . "$TESTDIR/framework"
- setupenvironment
- configarchitecture 'amd64'
- changetowebserver
- copysource() {
- dd if="$1" bs=1 count="$2" of="$3" 2>/dev/null
- touch -d "$(stat --format '%y' "${TESTFILE}")" "$3"
- }
- DOWNLOADLOG='rootdir/tmp/testdownloadfile.log'
- testdownloadfile() {
- rm -f "$DOWNLOADLOG"
- msgtest "Testing download of file $2 with" "$1 $5"
- if ! downloadfile "$2" "$3" "$5" > "$DOWNLOADLOG"; then
- cat >&2 "$DOWNLOADLOG"
- msgfail
- else
- msgpass
- fi
- sed -e '/^ <- / s#%20# #g' -e '/^ <- / s#%0a#\n#g' "$DOWNLOADLOG" | grep '^.*-Hash: ' > receivedhashes.log
- testsuccess test -s receivedhashes.log
- local HASHES_OK=0
- local HASHES_BAD=0
- while read field hash; do
- local EXPECTED
- case "$field" in
- 'MD5Sum-Hash:') EXPECTED="$(md5sum "$TESTFILE" | cut -d' ' -f 1)";;
- 'SHA1-Hash:') EXPECTED="$(sha1sum "$TESTFILE" | cut -d' ' -f 1)";;
- 'SHA256-Hash:') EXPECTED="$(sha256sum "$TESTFILE" | cut -d' ' -f 1)";;
- 'SHA512-Hash:') EXPECTED="$(sha512sum "$TESTFILE" | cut -d' ' -f 1)";;
- 'Checksum-FileSize-Hash:')
- #filesize is too weak to check for !=
- if [ "$4" = '=' ]; then
- EXPECTED="$(stat -c '%s' "$TESTFILE")"
- else
- continue
- fi
- ;;
- *) continue;;
- esac
- if [ "$4" = '=' ]; then
- msgtest 'Test downloaded file for correct' "$field"
- else
- msgtest 'Test downloaded file does not match in' "$field"
- fi
- if [ "$EXPECTED" "$4" "$hash" ]; then
- msgpass
- HASHES_OK=$((HASHES_OK+1));
- else
- msgfail "expected: $EXPECTED ; got: $hash"
- HASHES_BAD=$((HASHES_BAD+1));
- fi
- done < receivedhashes.log
- msgtest 'At least one good hash and no bad ones'
- if [ $HASHES_OK -eq 0 ] || [ $HASHES_BAD -ne 0 ]; then
- cat >&2 "$DOWNLOADLOG"
- msgfail
- else
- msgpass
- fi
- }
- TESTFILE='aptarchive/testfile'
- cp -a "${TESTDIR}/framework" "$TESTFILE"
- cp -a "${TESTDIR}/framework" "${TESTFILE}2"
- followuprequest() {
- local DOWN='./downloaded/testfile'
- copysource $TESTFILE 1M $DOWN
- testdownloadfile 'completely downloaded file' "${1}/testfile" "$DOWN" '='
- testwebserverlaststatuscode '416' "$DOWNLOADLOG"
- webserverconfig 'aptwebserver::support::content-range' 'false'
- copysource $TESTFILE 1M $DOWN
- testdownloadfile 'completely downloaded file' "${1}/testfile" "$DOWN" '=' "SHA256:$(sha256sum "$TESTFILE" | cut -d' ' -f 1)"
- testwebserverlaststatuscode '416' "$DOWNLOADLOG"
- webserverconfig 'aptwebserver::support::content-range' 'true'
- copysource $TESTFILE 1M $DOWN
- copysource "${TESTFILE}2" 20 "${DOWN}2"
- msgtest 'Testing download of files with' 'completely downloaded file + partial file'
- testsuccess --nomsg apthelper -o Debug::Acquire::${1%%:*}=1 -o Debug::pkgAcquire::Worker=1 \
- download-file "$1/testfile" "$DOWN" '' "$1/testfile2" "${DOWN}2"
- testwebserverlaststatuscode '206' 'rootdir/tmp/testsuccess.output'
- testsuccess diff -u "$TESTFILE" "${DOWN}"
- testsuccess diff -u "${DOWN}" "${DOWN}2"
- }
- testrun() {
- webserverconfig 'aptwebserver::support::range' 'true'
- webserverconfig 'aptwebserver::response-header::Accept-Ranges' 'bytes'
- local DOWN='./downloaded/testfile'
- copysource $TESTFILE 0 $DOWN
- testdownloadfile 'no data' "${1}/testfile" "$DOWN" '='
- testwebserverlaststatuscode '200' "$DOWNLOADLOG"
- copysource $TESTFILE 20 $DOWN
- testdownloadfile 'valid partial data' "${1}/testfile" "$DOWN" '='
- testwebserverlaststatuscode '206' "$DOWNLOADLOG"
- copysource /dev/zero 20 $DOWN
- testdownloadfile 'invalid partial data' "${1}/testfile" "$DOWN" '!='
- testwebserverlaststatuscode '206' "$DOWNLOADLOG"
- webserverconfig 'aptwebserver::closeOnError' 'false'
- followuprequest "$1"
- webserverconfig 'aptwebserver::closeOnError' 'true'
- followuprequest "$1"
- webserverconfig 'aptwebserver::closeOnError' 'false'
- copysource /dev/zero 1M $DOWN
- testdownloadfile 'too-big partial file' "${1}/testfile" "$DOWN" '='
- testwebserverlaststatuscode '200' "$DOWNLOADLOG"
- copysource /dev/zero 20 $DOWN
- touch $DOWN
- testdownloadfile 'old data' "${1}/testfile" "$DOWN" '='
- testwebserverlaststatuscode '200' "$DOWNLOADLOG"
- if [ "${1%%:*}" = 'https' ] && expr match "$1" "^.*/redirectme$" >/dev/null; then
- webserverconfig 'aptwebserver::response-header::Accept-Ranges' 'none'
- else
- webserverconfig 'aptwebserver::support::range' 'false'
- fi
- copysource $TESTFILE 20 $DOWN
- testdownloadfile 'no server support' "${1}/testfile" "$DOWN" '='
- testwebserverlaststatuscode '200' "$DOWNLOADLOG"
- }
- serverconfigs() {
- msgmsg "${1%%:*}: Test with Content-Length"
- webserverconfig 'aptwebserver::chunked-transfer-encoding' 'false'
- testrun "$1"
- msgmsg "${1%%:*}: Test with Transfer-Encoding: chunked"
- webserverconfig 'aptwebserver::chunked-transfer-encoding' 'true'
- testrun "$1"
- }
- serverconfigs "http://localhost:${APTHTTPPORT}"
- changetohttpswebserver
- serverconfigs "https://localhost:${APTHTTPSPORT}"
- webserverconfig 'aptwebserver::redirect::replace::/redirectme/' "https://localhost:${APTHTTPSPORT}/"
- serverconfigs "https://localhost:${APTHTTPSPORT}/redirectme"
- serverconfigs "http://localhost:${APTHTTPPORT}/redirectme"
|