2018-10-01 02:30:04 +02:00
|
|
|
import json
|
|
|
|
import os
|
2018-10-04 07:36:25 +02:00
|
|
|
import shutil
|
2018-10-01 02:30:04 +02:00
|
|
|
import subprocess
|
|
|
|
import sys
|
2018-10-04 07:36:25 +02:00
|
|
|
import tempfile
|
2018-10-01 02:30:04 +02:00
|
|
|
|
|
|
|
|
2018-10-04 07:36:25 +02:00
|
|
|
def generate_configuration(config_path, repository_path):
|
|
|
|
'''
|
|
|
|
Generate borgmatic configuration into a file at the config path, and update the defaults so as
|
2018-12-11 07:20:57 +01:00
|
|
|
to work for testing (including injecting the given repository path and tacking on an encryption
|
|
|
|
passphrase).
|
2018-10-04 07:36:25 +02:00
|
|
|
'''
|
2018-10-15 18:37:26 +02:00
|
|
|
subprocess.check_call(
|
|
|
|
'generate-borgmatic-config --destination {}'.format(config_path).split(' ')
|
|
|
|
)
|
2018-10-01 02:30:04 +02:00
|
|
|
config = (
|
2018-10-04 07:36:25 +02:00
|
|
|
open(config_path)
|
2018-10-01 02:30:04 +02:00
|
|
|
.read()
|
2018-10-04 07:36:25 +02:00
|
|
|
.replace('user@backupserver:sourcehostname.borg', repository_path)
|
2018-10-15 18:30:04 +02:00
|
|
|
.replace('- /home', '- {}'.format(config_path))
|
2018-10-04 07:36:25 +02:00
|
|
|
.replace('- /etc', '')
|
2018-10-01 02:30:04 +02:00
|
|
|
.replace('- /var/log/syslog*', '')
|
2018-12-11 07:20:57 +01:00
|
|
|
+ 'storage:\n encryption_passphrase: "test"'
|
2018-10-01 02:30:04 +02:00
|
|
|
)
|
2018-10-04 07:36:25 +02:00
|
|
|
config_file = open(config_path, 'w')
|
2018-10-01 02:30:04 +02:00
|
|
|
config_file.write(config)
|
|
|
|
config_file.close()
|
|
|
|
|
|
|
|
|
2019-05-10 00:10:28 +02:00
|
|
|
def validate_valid_configuration(config_path):
|
|
|
|
'''
|
|
|
|
Validate borgmatic configuration which is valid.
|
|
|
|
'''
|
|
|
|
subprocess.check_call(
|
|
|
|
'validate-borgmatic-config --config {}'.format(config_path).split(' ')
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def validate_invalid_configuration(config_path):
|
|
|
|
'''
|
|
|
|
Validate borgmatic configuration which is invalid.
|
|
|
|
'''
|
|
|
|
|
|
|
|
config = (
|
|
|
|
open(config_path)
|
|
|
|
.read()
|
|
|
|
.replace('keep_daily: 7', 'keep_daily: "7"')
|
|
|
|
)
|
|
|
|
config_file = open(config_path, 'w')
|
|
|
|
config_file.write(config)
|
|
|
|
config_file.close()
|
|
|
|
|
|
|
|
exit_code = subprocess.call(
|
|
|
|
'validate-borgmatic-config --config {}'.format(config_path).split(' ')
|
|
|
|
)
|
|
|
|
|
|
|
|
assert exit_code == 1
|
|
|
|
|
|
|
|
|
2018-10-01 02:30:04 +02:00
|
|
|
def test_borgmatic_command():
|
|
|
|
# Create a Borg repository.
|
2018-10-04 07:36:25 +02:00
|
|
|
temporary_directory = tempfile.mkdtemp()
|
|
|
|
repository_path = os.path.join(temporary_directory, 'test.borg')
|
2019-02-18 22:47:18 +01:00
|
|
|
extract_path = os.path.join(temporary_directory, 'extract')
|
|
|
|
|
|
|
|
original_working_directory = os.getcwd()
|
|
|
|
os.mkdir(extract_path)
|
|
|
|
os.chdir(extract_path)
|
2018-10-01 02:30:04 +02:00
|
|
|
|
2018-10-04 07:36:25 +02:00
|
|
|
try:
|
|
|
|
config_path = os.path.join(temporary_directory, 'test.yaml')
|
2019-05-10 00:10:28 +02:00
|
|
|
invalid_config_path = os.path.join(temporary_directory, 'test_invalid.yaml')
|
2018-10-04 07:36:25 +02:00
|
|
|
generate_configuration(config_path, repository_path)
|
2019-05-10 00:10:28 +02:00
|
|
|
generate_configuration(invalid_config_path, repository_path)
|
|
|
|
validate_valid_configuration(config_path)
|
|
|
|
validate_invalid_configuration(invalid_config_path)
|
2018-10-04 07:36:25 +02:00
|
|
|
|
2018-12-11 07:20:57 +01:00
|
|
|
subprocess.check_call(
|
|
|
|
'borgmatic -v 2 --config {} --init --encryption repokey'.format(config_path).split(' ')
|
|
|
|
)
|
|
|
|
|
2018-10-04 07:36:25 +02:00
|
|
|
# Run borgmatic to generate a backup archive, and then list it to make sure it exists.
|
2018-10-15 18:30:04 +02:00
|
|
|
subprocess.check_call('borgmatic --config {}'.format(config_path).split(' '))
|
2018-10-04 07:36:25 +02:00
|
|
|
output = subprocess.check_output(
|
2018-10-15 18:37:26 +02:00
|
|
|
'borgmatic --config {} --list --json'.format(config_path).split(' ')
|
|
|
|
).decode(sys.stdout.encoding)
|
2018-10-04 07:36:25 +02:00
|
|
|
parsed_output = json.loads(output)
|
2018-10-01 02:30:04 +02:00
|
|
|
|
2018-10-04 07:36:25 +02:00
|
|
|
assert len(parsed_output) == 1
|
|
|
|
assert len(parsed_output[0]['archives']) == 1
|
2019-02-18 22:47:18 +01:00
|
|
|
archive_name = parsed_output[0]['archives'][0]['archive']
|
|
|
|
|
|
|
|
# Extract the created archive into the current (temporary) directory, and confirm that the
|
|
|
|
# extracted file looks right.
|
|
|
|
output = subprocess.check_output(
|
|
|
|
'borgmatic --config {} --extract --archive {}'.format(config_path, archive_name).split(
|
|
|
|
' '
|
|
|
|
)
|
|
|
|
).decode(sys.stdout.encoding)
|
|
|
|
extracted_config_path = os.path.join(extract_path, config_path)
|
|
|
|
assert open(extracted_config_path).read() == open(config_path).read()
|
2018-10-13 22:09:12 +02:00
|
|
|
|
2019-02-18 22:47:18 +01:00
|
|
|
# Exercise the info flag.
|
2018-10-13 22:09:12 +02:00
|
|
|
output = subprocess.check_output(
|
2018-10-15 18:37:26 +02:00
|
|
|
'borgmatic --config {} --info --json'.format(config_path).split(' ')
|
|
|
|
).decode(sys.stdout.encoding)
|
2018-10-13 22:09:12 +02:00
|
|
|
parsed_output = json.loads(output)
|
|
|
|
|
|
|
|
assert len(parsed_output) == 1
|
|
|
|
assert 'repository' in parsed_output[0]
|
2018-10-04 07:36:25 +02:00
|
|
|
finally:
|
2019-02-18 22:47:18 +01:00
|
|
|
os.chdir(original_working_directory)
|
2018-10-04 07:36:25 +02:00
|
|
|
shutil.rmtree(temporary_directory)
|