mirror of
				https://github.com/offen/docker-volume-backup.git
				synced 2025-10-30 00:45:59 +08:00 
			
		
		
		
	* Try running tests in Docker * Spawn new container for each test * Store test artifacts outside of mount * When requested, build up to date image in test script * sudo is unneccessary in containerized test env * Skip azure test * Backdate fixture file in JSON database * Pin versions for azure tools * Mount temp volume for /var/lib/docker to prevent dangling ones created by VOLUME instruction * Fail backdating tests with message * Add some documentation on test setup * Cache images * Run compose stacks with shortened default timeout
		
			
				
	
	
		
			67 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| set -e
 | |
| 
 | |
| cd "$(dirname "$0")"
 | |
| . ../util.sh
 | |
| current_test=$(basename $(pwd))
 | |
| 
 | |
| 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"
 | |
| 
 | |
| docker compose up -d --quiet-pull
 | |
| sleep 5
 | |
| 
 | |
| docker compose exec backup backup
 | |
| 
 | |
| sleep 5
 | |
| 
 | |
| expect_running_containers 3
 | |
| 
 | |
| docker run --rm \
 | |
|   -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)
 | |
| BACKUP_RETENTION_DAYS="0" docker compose up -d
 | |
| sleep 5
 | |
| 
 | |
| docker compose exec backup backup
 | |
| 
 | |
| docker run --rm \
 | |
|   -v ssh_backup_data:/ssh_data \
 | |
|   alpine \
 | |
|   ash -c '[ $(find /ssh_data/ -type f | wc -l) = "1" ]'
 | |
| 
 | |
| pass "Remote backups have not been deleted."
 | |
| 
 | |
| # 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."
 |