mirror of
https://github.com/ostreedev/ostree.git
synced 2024-12-22 17:35:55 +03:00
Add tests for cases under random 500s
Signed-off-by: Ricardo Noriega <rnoriega@redhat.com>
This commit is contained in:
parent
722be7e3d7
commit
6ce2324e4a
@ -26,18 +26,32 @@ if has_gpgme; then
|
||||
COMMIT_SIGN="--gpg-homedir=${TEST_GPG_KEYHOME} --gpg-sign=${TEST_GPG_KEYID_1}"
|
||||
fi
|
||||
|
||||
echo "1..4"
|
||||
echo "1..6"
|
||||
|
||||
# Test pulling from a repo which gives error 500 (internal server error) a lot of the time.
|
||||
# Sanity check with no network retries and 500s given, pull should fail.
|
||||
rm ostree-srv httpd repo -rf
|
||||
setup_fake_remote_repo1 "archive" "${COMMIT_SIGN}" --random-500s=99
|
||||
|
||||
pushd ${test_tmpdir}
|
||||
ostree_repo_init repo --mode=archive
|
||||
${CMD_PREFIX} ostree --repo=repo remote add --set=gpg-verify=false origin $(cat httpd-address)/ostree/gnomerepo
|
||||
assert_fail ${CMD_PREFIX} ostree --repo=repo pull --mirror origin --network-retries=0 main 2>err.txt
|
||||
assert_file_has_content err.txt "\(500.*Internal Server Error\)\|\(HTTP 500\)"
|
||||
|
||||
popd
|
||||
echo "ok no retries after a 500"
|
||||
|
||||
# Test pulling a repo which gives error 500 (internal server error) a lot of the time.
|
||||
rm ostree-srv httpd repo -rf
|
||||
setup_fake_remote_repo1 "archive" "${COMMIT_SIGN}" --random-500s=50
|
||||
|
||||
pushd ${test_tmpdir}
|
||||
ostree_repo_init repo --mode=archive
|
||||
${CMD_PREFIX} ostree --repo=repo remote add --set=gpg-verify=false origin $(cat httpd-address)/ostree/gnomerepo
|
||||
for x in $(seq 200); do
|
||||
if ${CMD_PREFIX} ostree --repo=repo pull --mirror origin main 2>err.txt; then
|
||||
echo "Success on iteration ${x}"
|
||||
break;
|
||||
for x in $(seq 40); do
|
||||
if ${CMD_PREFIX} ostree --repo=repo pull --mirror origin --network-retries=2 main 2>err.txt; then
|
||||
echo "Success on iteration ${x}"
|
||||
break;
|
||||
fi
|
||||
assert_file_has_content err.txt "\(500.*Internal Server Error\)\|\(HTTP 500\)"
|
||||
done
|
||||
@ -48,6 +62,24 @@ ${CMD_PREFIX} ostree --repo=repo rev-parse main
|
||||
popd
|
||||
echo "ok repeated pull after 500s"
|
||||
|
||||
# Test pulling a repo that gives 408s a lot of the time, with many network retries.
|
||||
rm ostree-srv httpd repo -rf
|
||||
setup_fake_remote_repo1 "archive" "${COMMIT_SIGN}" --random-500s=50
|
||||
|
||||
pushd ${test_tmpdir}
|
||||
ostree_repo_init repo --mode=archive
|
||||
${CMD_PREFIX} ostree --repo=repo remote add --set=gpg-verify=false origin $(cat httpd-address)/ostree/gnomerepo
|
||||
|
||||
# We limit 500s above to 100, so 100 retries should be enough always.
|
||||
${CMD_PREFIX} ostree --repo=repo pull --mirror origin --network-retries=100 main
|
||||
echo "Success with big number of network retries"
|
||||
|
||||
${CMD_PREFIX} ostree --repo=repo fsck
|
||||
${CMD_PREFIX} ostree --repo=repo rev-parse main
|
||||
|
||||
popd
|
||||
echo "ok big number of retries with one 500s"
|
||||
|
||||
# Sanity check with no network retries and 408s given, pull should fail.
|
||||
rm ostree-srv httpd repo -rf
|
||||
setup_fake_remote_repo1 "archive" "${COMMIT_SIGN}" --random-408s=99
|
||||
|
Loading…
Reference in New Issue
Block a user