mirror of
https://github.com/offen/docker-volume-backup.git
synced 2024-11-10 00:30:29 +01:00
Frederik Ring
c2a8cc92fc
* Isolate S3 test case * Isolate webdav test case * Isolate SSH test case * Isolate local storage test case * Isolate gpg test case * Add missing volume mount * Fix file locations for local test case * Remove compose test case, use utils * Use test utils throughout * Use dedicated tmp dir * Fix link location that is being tested * Use dedicated tmp_dirs when working on host fs * Force delete artifact * Fix expected filename * Provide helpful messages on failing tests * Fix filename * Use proper volume names * Fix syntax error, use large resource class * Use named Docker volumes when referencing them in test scripts * Add name of test case to logging output
44 lines
1.1 KiB
Bash
Executable File
44 lines
1.1 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
set -e
|
|
|
|
cd "$(dirname "$0")"
|
|
. ../util.sh
|
|
current_test=$(basename $(pwd))
|
|
|
|
ssh-keygen -t rsa -m pem -b 4096 -N "test1234" -f id_rsa -C "docker-volume-backup@local"
|
|
|
|
docker-compose up -d
|
|
sleep 5
|
|
|
|
docker-compose exec backup backup
|
|
|
|
sleep 5
|
|
|
|
expect_running_containers 3
|
|
|
|
docker run --rm -it \
|
|
-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)
|
|
# TODO: find out if we can test actual deletion without having to wait for a day
|
|
BACKUP_RETENTION_DAYS="0" docker-compose up -d
|
|
sleep 5
|
|
|
|
docker-compose exec backup backup
|
|
|
|
docker run --rm -it \
|
|
-v ssh_backup_data:/ssh_data \
|
|
alpine \
|
|
ash -c '[ $(find /ssh_data/ -type f | wc -l) = "1" ]'
|
|
|
|
pass "Remote backups have not been deleted."
|
|
|
|
docker-compose down --volumes
|
|
rm -f id_rsa id_rsa.pub
|