2023-08-24 19:33:47 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
cd "$(dirname "$0")"
|
|
|
|
. ../util.sh
|
|
|
|
current_test=$(basename $(pwd))
|
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
export SPEC_FILE=$(mktemp -d)/user_v2.yaml
|
|
|
|
cp user_v2.yaml $SPEC_FILE
|
|
|
|
sed -i 's/SERVER_MODIFIED_1/'"$(date "+%Y-%m-%dT%H:%M:%SZ")/g" $SPEC_FILE
|
|
|
|
sed -i 's/SERVER_MODIFIED_2/'"$(date "+%Y-%m-%dT%H:%M:%SZ" -d "14 days ago")/g" $SPEC_FILE
|
2023-08-27 19:19:11 +02:00
|
|
|
|
|
|
|
docker compose up -d --quiet-pull
|
2023-08-24 19:33:47 +02:00
|
|
|
sleep 5
|
|
|
|
|
|
|
|
logs=$(docker compose exec -T backup backup)
|
|
|
|
|
|
|
|
sleep 5
|
|
|
|
|
|
|
|
expect_running_containers "4"
|
|
|
|
|
|
|
|
echo "$logs"
|
|
|
|
if echo "$logs" | grep -q "ERROR"; then
|
2023-08-27 19:19:11 +02:00
|
|
|
fail "Backup failed, errors reported: $logs"
|
2023-08-24 19:33:47 +02:00
|
|
|
else
|
|
|
|
pass "Backup succeeded, no errors reported."
|
|
|
|
fi
|
|
|
|
|
|
|
|
# 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)
|
|
|
|
BACKUP_RETENTION_DAYS="0" docker compose up -d
|
|
|
|
sleep 5
|
|
|
|
|
|
|
|
logs=$(docker compose exec -T backup backup)
|
|
|
|
|
|
|
|
echo "$logs"
|
|
|
|
if echo "$logs" | grep -q "Refusing to do so, please check your configuration"; then
|
|
|
|
pass "Remote backups have not been deleted."
|
|
|
|
else
|
2023-08-27 19:19:11 +02:00
|
|
|
fail "Remote backups would have been deleted: $logs"
|
2023-08-24 19:33:47 +02:00
|
|
|
fi
|
|
|
|
|
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 second backup and prune"
|
|
|
|
logs=$(docker compose exec -T backup backup)
|
|
|
|
|
|
|
|
echo "$logs"
|
|
|
|
if echo "$logs" | grep -q "Pruned 1 out of 2 backups as their age exceeded the configured retention period"; then
|
|
|
|
pass "Old remote backup has been pruned, new one is still present."
|
|
|
|
elif echo "$logs" | grep -q "ERROR"; then
|
|
|
|
fail "Pruning failed, errors reported: $logs"
|
|
|
|
elif echo "$logs" | grep -q "None of 1 existing backups were pruned"; then
|
|
|
|
fail "Pruning failed, old backup has not been pruned: $logs"
|
|
|
|
else
|
|
|
|
fail "Pruning failed, unknown result: $logs"
|
|
|
|
fi
|