157 lines
4.9 KiB
Bash
Executable file
157 lines
4.9 KiB
Bash
Executable file
#!/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 || true
|
|
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"
|