2023-01-11 21:40:48 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
cd "$(dirname "$0")"
|
|
|
|
. ../util.sh
|
|
|
|
current_test=$(basename $(pwd))
|
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
export LOCAL_DIR=$(mktemp -d)
|
|
|
|
export TMP_DIR=$(mktemp -d)
|
|
|
|
export DATA_DIR=$(mktemp -d)
|
|
|
|
|
2023-08-27 19:19:11 +02:00
|
|
|
download_az () {
|
|
|
|
docker compose run --rm az_cli \
|
|
|
|
az storage blob download -f /dump/$1.tar.gz -c test-container -n path/to/backup/$1.tar.gz
|
|
|
|
}
|
|
|
|
|
|
|
|
docker compose up -d --quiet-pull
|
2023-09-02 15:17:46 +02:00
|
|
|
|
2023-01-11 21:40:48 +01:00
|
|
|
sleep 5
|
|
|
|
|
2023-03-16 19:32:44 +01:00
|
|
|
docker compose exec backup backup
|
2023-01-11 21:40:48 +01:00
|
|
|
|
|
|
|
sleep 5
|
|
|
|
|
|
|
|
expect_running_containers "3"
|
|
|
|
|
2023-08-27 19:19:11 +02:00
|
|
|
download_az "test"
|
2023-09-02 15:17:46 +02:00
|
|
|
|
|
|
|
tar -xvf "$LOCAL_DIR/test.tar.gz" -C $TMP_DIR
|
|
|
|
|
|
|
|
if [ ! -f "$TMP_DIR/backup/app_data/offen.db" ]; then
|
|
|
|
fail "Could not find expeced file in untared backup"
|
|
|
|
fi
|
2023-01-11 21:40:48 +01:00
|
|
|
|
|
|
|
pass "Found relevant files in untared remote backups."
|
2023-09-02 15:17:46 +02:00
|
|
|
rm "$LOCAL_DIR/test.tar.gz"
|
2023-01-11 21:40:48 +01:00
|
|
|
|
|
|
|
# The second part of this test checks if backups get deleted when the retention
|
|
|
|
# is set to 0 days (which it should not as it would mean all backups get deleted)
|
2023-04-29 20:14:04 +02:00
|
|
|
BACKUP_RETENTION_DAYS="0" docker compose up -d
|
2023-01-11 21:40:48 +01:00
|
|
|
sleep 5
|
|
|
|
|
2023-03-16 19:32:44 +01:00
|
|
|
docker compose exec backup backup
|
2023-01-11 21:40:48 +01:00
|
|
|
|
2023-08-27 19:19:11 +02:00
|
|
|
download_az "test"
|
2023-09-02 15:17:46 +02:00
|
|
|
if [ ! -f "$LOCAL_DIR/test.tar.gz" ]; then
|
|
|
|
fail "Remote backup was deleted"
|
|
|
|
fi
|
2023-01-11 21:40:48 +01:00
|
|
|
pass "Remote backups have not been deleted."
|
|
|
|
|
2023-08-27 19:19:11 +02:00
|
|
|
# The third part of this test checks if old backups get deleted when the retention
|
|
|
|
# is set to 7 days (which it should)
|
|
|
|
|
|
|
|
BACKUP_RETENTION_DAYS="7" docker compose up -d
|
|
|
|
sleep 5
|
|
|
|
|
|
|
|
info "Create first backup with no prune"
|
|
|
|
docker compose exec backup backup
|
|
|
|
|
|
|
|
docker compose run --rm az_cli \
|
|
|
|
az storage blob upload -f /dump/test.tar.gz -c test-container -n path/to/backup/test-old.tar.gz
|
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
docker compose down
|
|
|
|
rm "$LOCAL_DIR/test.tar.gz"
|
|
|
|
|
|
|
|
back_date="$(date "+%Y-%m-%dT%H:%M:%S%z" -d "14 days ago" | rev | cut -c 3- | rev):00"
|
|
|
|
jq --arg back_date "$back_date" '(.collections[] | select(.name=="$BLOBS_COLLECTION$") | .data[] | select(.name=="path/to/backup/test-old.tar.gz") | .properties.creationTime = $back_date)' "$DATA_DIR/__azurite_db_blob__.json" | sponge "$DATA_DIR/__azurite_db_blob__.json"
|
|
|
|
|
|
|
|
docker compose up -d
|
|
|
|
sleep 5
|
2023-08-27 19:19:11 +02:00
|
|
|
|
|
|
|
info "Create second backup and prune"
|
|
|
|
docker compose exec backup backup
|
|
|
|
|
|
|
|
info "Download first backup which should be pruned"
|
|
|
|
download_az "test-old" || true
|
2023-09-02 15:17:46 +02:00
|
|
|
if [ -f "$LOCAL_DIR/test-old.tar.gz" ]; then
|
|
|
|
fail "Backdated file was not deleted"
|
|
|
|
fi
|
|
|
|
download_az "test" || true
|
|
|
|
if [ ! -f "$LOCAL_DIR/test.tar.gz" ]; then
|
|
|
|
fail "Recent file was not found"
|
|
|
|
fi
|
2023-08-27 19:19:11 +02:00
|
|
|
|
|
|
|
pass "Old remote backup has been pruned, new one is still present."
|