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 LOCAL_DIR=$(mktemp -d)
|
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
|
|
|
|
|
|
|
|
# A symlink for a known file in the volume is created so the test can check
|
|
|
|
# whether symlinks are preserved on backup.
|
2023-01-07 18:50:27 +01:00
|
|
|
docker compose exec offen ln -s /var/opt/offen/offen.db /var/opt/offen/db.link
|
|
|
|
docker compose exec backup backup
|
2022-06-23 14:40:29 +02:00
|
|
|
|
|
|
|
sleep 5
|
|
|
|
|
|
|
|
expect_running_containers "2"
|
|
|
|
|
|
|
|
tmp_dir=$(mktemp -d)
|
2023-09-02 15:17:46 +02:00
|
|
|
tar -xvf "$LOCAL_DIR/test-hostnametoken.tar.gz" -C $tmp_dir
|
2022-06-23 14:40:29 +02:00
|
|
|
if [ ! -f "$tmp_dir/backup/app_data/offen.db" ]; then
|
|
|
|
fail "Could not find expected file in untared archive."
|
|
|
|
fi
|
2023-09-02 15:17:46 +02:00
|
|
|
rm -f "$LOCAL_DIR/test-hostnametoken.tar.gz"
|
2022-06-23 14:40:29 +02:00
|
|
|
|
|
|
|
if [ ! -L "$tmp_dir/backup/app_data/db.link" ]; then
|
|
|
|
fail "Could not find expected symlink in untared archive."
|
|
|
|
fi
|
|
|
|
|
|
|
|
pass "Found relevant files in decrypted and untared local backup."
|
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
if [ ! -L "$LOCAL_DIR/test-hostnametoken.latest.tar.gz.gpg" ]; then
|
2022-06-23 14:40:29 +02:00
|
|
|
fail "Could not find symlink to latest version."
|
|
|
|
fi
|
|
|
|
|
|
|
|
pass "Found symlink to latest version in local backup."
|
|
|
|
|
|
|
|
# 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-09-02 15:17:46 +02:00
|
|
|
if [ "$(find "$LOCAL_DIR" -type f | wc -l)" != "1" ]; then
|
|
|
|
fail "Backups should not have been deleted, instead seen: "$(find "$local_dir" -type f)""
|
2022-06-23 14:40:29 +02:00
|
|
|
fi
|
|
|
|
pass "Local 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
|
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
touch -r "$LOCAL_DIR/test-hostnametoken.tar.gz" -d "14 days ago" "$LOCAL_DIR/test-hostnametoken-old.tar.gz"
|
2023-08-27 19:19:11 +02:00
|
|
|
|
|
|
|
info "Create second backup and prune"
|
|
|
|
docker compose exec backup backup
|
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
if [ -f "$LOCAL_DIR/test-hostnametoken-old.tar.gz" ]; then
|
|
|
|
fail "Backdated file has not been deleted."
|
|
|
|
fi
|
2023-08-27 19:19:11 +02:00
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
if [ ! -f "$LOCAL_DIR/test-hostnametoken.tar.gz" ]; then
|
|
|
|
fail "Recent file has been deleted."
|
|
|
|
fi
|
2023-08-27 19:19:11 +02:00
|
|
|
|
2023-09-02 15:17:46 +02:00
|
|
|
pass "Old remote backup has been pruned, new one is still present."
|