2022-06-23 14:40:29 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
cd "$(dirname "$0")"
|
|
|
|
. ../util.sh
|
|
|
|
current_test=$(basename $(pwd))
|
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
export KEY_DIR=$(mktemp -d)
|
|
|
|
|
|
|
|
ssh-keygen -t rsa -m pem -b 4096 -N "test1234" -f "$KEY_DIR/id_rsa" -C "docker-volume-backup@local"
|
2022-06-23 14:40:29 +02:00
|
|
|
|
2023-08-27 19:19:11 +02:00
|
|
|
docker compose up -d --quiet-pull
|
2022-06-23 14:40:29 +02:00
|
|
|
sleep 5
|
|
|
|
|
2023-01-07 18:50:27 +01:00
|
|
|
docker compose exec backup backup
|
2022-06-23 14:40:29 +02:00
|
|
|
|
|
|
|
sleep 5
|
|
|
|
|
|
|
|
expect_running_containers 3
|
|
|
|
|
2023-03-16 19:32:44 +01:00
|
|
|
docker run --rm \
|
2022-06-23 14:40:29 +02:00
|
|
|
-v ssh_backup_data:/ssh_data \
|
|
|
|
alpine \
|
|
|
|
ash -c 'tar -xvf /ssh_data/test-hostnametoken.tar.gz -C /tmp && test -f /tmp/backup/app_data/offen.db'
|
|
|
|
|
|
|
|
pass "Found relevant files in decrypted and untared remote backups."
|
|
|
|
|
|
|
|
# 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-01-07 18:50:27 +01:00
|
|
|
BACKUP_RETENTION_DAYS="0" docker compose up -d
|
2022-06-23 14:40:29 +02:00
|
|
|
sleep 5
|
|
|
|
|
2023-01-07 18:50:27 +01:00
|
|
|
docker compose exec backup backup
|
2022-06-23 14:40:29 +02:00
|
|
|
|
2023-03-16 19:32:44 +01:00
|
|
|
docker run --rm \
|
2022-06-23 14:40:29 +02:00
|
|
|
-v ssh_backup_data:/ssh_data \
|
|
|
|
alpine \
|
|
|
|
ash -c '[ $(find /ssh_data/ -type f | wc -l) = "1" ]'
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
# Set the modification date of the old backup to 14 days ago
|
|
|
|
docker run --rm \
|
|
|
|
-v ssh_backup_data:/ssh_data \
|
|
|
|
--user 1000 \
|
|
|
|
alpine \
|
|
|
|
ash -c 'touch -d@$(( $(date +%s) - 1209600 )) /ssh_data/test-hostnametoken-old.tar.gz'
|
|
|
|
|
|
|
|
info "Create second backup and prune"
|
|
|
|
docker compose exec backup backup
|
|
|
|
|
|
|
|
docker run --rm \
|
|
|
|
-v ssh_backup_data:/ssh_data \
|
|
|
|
alpine \
|
|
|
|
ash -c 'test ! -f /ssh_data/test-hostnametoken-old.tar.gz && test -f /ssh_data/test-hostnametoken.tar.gz'
|
|
|
|
|
|
|
|
pass "Old remote backup has been pruned, new one is still present."
|