mirror of https://github.com/borgbackup/borg.git
rcreate_cmd converted
This commit is contained in:
parent
a3bfc4d390
commit
673cd4718e
|
@ -21,7 +21,7 @@ def check_cmd_setUp(archiver):
|
|||
|
||||
|
||||
def pytest_generate_tests(metafunc):
|
||||
# Generates tests that run on both local and remote repos
|
||||
# Generate tests for different scenarios: local repository, remote repository, and using the borg binary.
|
||||
if "archivers" in metafunc.fixturenames:
|
||||
metafunc.parametrize("archivers", ["archiver", "remote_archiver", "binary_archiver"])
|
||||
|
||||
|
|
|
@ -43,7 +43,7 @@ def cmd_raises_unknown_feature(archiver, args):
|
|||
|
||||
|
||||
def pytest_generate_tests(metafunc):
|
||||
# Generates tests that run on both local and remote repos
|
||||
# Generate tests for different scenarios: local repository, remote repository, and using the borg binary.
|
||||
if "archivers" in metafunc.fixturenames:
|
||||
metafunc.parametrize("archivers", ["archiver", "remote_archiver"])
|
||||
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
import os
|
||||
import unittest
|
||||
from unittest.mock import patch
|
||||
|
||||
import pytest
|
||||
|
@ -9,79 +8,79 @@ from ...constants import * # NOQA
|
|||
from ...crypto.key import FlexiKey
|
||||
from ...repository import Repository
|
||||
from .. import environment_variable
|
||||
from . import (
|
||||
ArchiverTestCaseBase,
|
||||
ArchiverTestCaseBinaryBase,
|
||||
RemoteArchiverTestCaseBase,
|
||||
RK_ENCRYPTION,
|
||||
KF_ENCRYPTION,
|
||||
BORG_EXES,
|
||||
)
|
||||
from . import cmd, RK_ENCRYPTION, KF_ENCRYPTION
|
||||
|
||||
|
||||
class ArchiverTestCase(ArchiverTestCaseBase):
|
||||
def test_rcreate_parent_dirs(self):
|
||||
parent_path = os.path.join(self.tmpdir, "parent1", "parent2")
|
||||
repository_path = os.path.join(parent_path, "repository")
|
||||
repository_location = self.prefix + repository_path
|
||||
with pytest.raises(Repository.ParentPathDoesNotExist):
|
||||
# normal borg rcreate does NOT create missing parent dirs
|
||||
self.cmd(f"--repo={repository_location}", "rcreate", "--encryption=none")
|
||||
# but if told so, it does:
|
||||
self.cmd(f"--repo={repository_location}", "rcreate", "--encryption=none", "--make-parent-dirs")
|
||||
assert os.path.exists(parent_path)
|
||||
def pytest_generate_tests(metafunc):
|
||||
# Generate tests for different scenarios: local repository, remote repository, and using the borg binary.
|
||||
if "archivers" in metafunc.fixturenames:
|
||||
metafunc.parametrize("archivers", ["archiver", "remote_archiver", "binary_archiver"])
|
||||
|
||||
def test_rcreate_interrupt(self):
|
||||
def raise_eof(*args, **kwargs):
|
||||
raise EOFError
|
||||
|
||||
with patch.object(FlexiKey, "create", raise_eof):
|
||||
self.cmd(f"--repo={self.repository_location}", "rcreate", RK_ENCRYPTION, exit_code=1)
|
||||
assert not os.path.exists(self.repository_location)
|
||||
def test_rcreate_parent_dirs(archivers, request):
|
||||
archiver = request.getfixturevalue(archivers)
|
||||
if archiver.EXE:
|
||||
pytest.skip("does not raise Exception, but sets rc==2")
|
||||
|
||||
def test_rcreate_requires_encryption_option(self):
|
||||
self.cmd(f"--repo={self.repository_location}", "rcreate", exit_code=2)
|
||||
parent_path = os.path.join(archiver.tmpdir, "parent1", "parent2")
|
||||
repository_path = os.path.join(parent_path, "repository")
|
||||
repository_location = archiver.prefix + repository_path
|
||||
with pytest.raises(Repository.ParentPathDoesNotExist):
|
||||
# normal borg rcreate does NOT create missing parent dirs
|
||||
cmd(archiver, f"--repo={repository_location}", "rcreate", "--encryption=none")
|
||||
# but if told so, it does:
|
||||
cmd(archiver, f"--repo={repository_location}", "rcreate", "--encryption=none", "--make-parent-dirs")
|
||||
assert os.path.exists(parent_path)
|
||||
|
||||
def test_rcreate_nested_repositories(self):
|
||||
self.cmd(f"--repo={self.repository_location}", "rcreate", RK_ENCRYPTION)
|
||||
if self.FORK_DEFAULT:
|
||||
self.cmd(f"--repo={self.repository_location}/nested", "rcreate", RK_ENCRYPTION, exit_code=2)
|
||||
|
||||
def test_rcreate_interrupt(archivers, request):
|
||||
archiver = request.getfixturevalue(archivers)
|
||||
repo_location = archiver.repository_location
|
||||
if archiver.EXE:
|
||||
pytest.skip("patches object")
|
||||
|
||||
def raise_eof(*args, **kwargs):
|
||||
raise EOFError
|
||||
|
||||
with patch.object(FlexiKey, "create", raise_eof):
|
||||
cmd(archiver, f"--repo={repo_location}", "rcreate", RK_ENCRYPTION, exit_code=1)
|
||||
assert not os.path.exists(repo_location)
|
||||
|
||||
|
||||
def test_rcreate_requires_encryption_option(archivers, request):
|
||||
archiver = request.getfixturevalue(archivers)
|
||||
cmd(archiver, f"--repo={archiver.repository_location}", "rcreate", exit_code=2)
|
||||
|
||||
|
||||
def test_rcreate_nested_repositories(archivers, request):
|
||||
archiver = request.getfixturevalue(archivers)
|
||||
repo_location = archiver.repository_location
|
||||
|
||||
cmd(archiver, f"--repo={repo_location}", "rcreate", RK_ENCRYPTION)
|
||||
if archiver.FORK_DEFAULT:
|
||||
cmd(archiver, f"--repo={repo_location}/nested", "rcreate", RK_ENCRYPTION, exit_code=2)
|
||||
else:
|
||||
with pytest.raises(Repository.AlreadyExists):
|
||||
cmd(archiver, f"--repo={repo_location}/nested", "rcreate", RK_ENCRYPTION)
|
||||
|
||||
|
||||
def test_rcreate_refuse_to_overwrite_keyfile(archivers, request):
|
||||
# BORG_KEY_FILE=something borg rcreate should quit if "something" already exists.
|
||||
# See: https://github.com/borgbackup/borg/pull/6046
|
||||
archiver = request.getfixturevalue(archivers)
|
||||
repo_location = archiver.repository_location
|
||||
|
||||
keyfile = os.path.join(archiver.tmpdir, "keyfile")
|
||||
with environment_variable(BORG_KEY_FILE=keyfile):
|
||||
cmd(archiver, f"--repo={repo_location}0", "rcreate", KF_ENCRYPTION)
|
||||
with open(keyfile) as file:
|
||||
before = file.read()
|
||||
arg = (f"--repo={repo_location}1", "rcreate", KF_ENCRYPTION)
|
||||
if archiver.FORK_DEFAULT:
|
||||
cmd(archiver, *arg, exit_code=2)
|
||||
else:
|
||||
with pytest.raises(Repository.AlreadyExists):
|
||||
self.cmd(f"--repo={self.repository_location}/nested", "rcreate", RK_ENCRYPTION)
|
||||
|
||||
def test_rcreate_refuse_to_overwrite_keyfile(self):
|
||||
"""BORG_KEY_FILE=something borg rcreate should quit if "something" already exists.
|
||||
|
||||
See https://github.com/borgbackup/borg/pull/6046"""
|
||||
keyfile = os.path.join(self.tmpdir, "keyfile")
|
||||
with environment_variable(BORG_KEY_FILE=keyfile):
|
||||
self.cmd(f"--repo={self.repository_location}0", "rcreate", KF_ENCRYPTION)
|
||||
with open(keyfile) as file:
|
||||
before = file.read()
|
||||
arg = (f"--repo={self.repository_location}1", "rcreate", KF_ENCRYPTION)
|
||||
if self.FORK_DEFAULT:
|
||||
self.cmd(*arg, exit_code=2)
|
||||
else:
|
||||
with pytest.raises(Error):
|
||||
self.cmd(*arg)
|
||||
with open(keyfile) as file:
|
||||
after = file.read()
|
||||
assert before == after
|
||||
|
||||
|
||||
class RemoteArchiverTestCase(RemoteArchiverTestCaseBase, ArchiverTestCase):
|
||||
"""run the same tests, but with a remote repository"""
|
||||
|
||||
|
||||
@unittest.skipUnless("binary" in BORG_EXES, "no borg.exe available")
|
||||
class ArchiverTestCaseBinary(ArchiverTestCaseBinaryBase, ArchiverTestCase):
|
||||
"""runs the same tests, but via the borg binary"""
|
||||
|
||||
@unittest.skip("does not raise Exception, but sets rc==2")
|
||||
def test_rcreate_parent_dirs(self):
|
||||
pass
|
||||
|
||||
@unittest.skip("patches objects")
|
||||
def test_rcreate_interrupt(self):
|
||||
pass
|
||||
with pytest.raises(Error):
|
||||
cmd(archiver, *arg)
|
||||
with open(keyfile) as file:
|
||||
after = file.read()
|
||||
assert before == after
|
||||
|
|
Loading…
Reference in New Issue