2016-07-25 03:38:28 +00:00
|
|
|
import os
|
|
|
|
|
2016-10-13 21:59:28 +00:00
|
|
|
import pytest
|
|
|
|
|
2017-06-10 09:42:42 +00:00
|
|
|
# IMPORTANT keep this above all other borg imports to avoid inconsistent values
|
|
|
|
# for `from borg.constants import PBKDF2_ITERATIONS` (or star import) usages before
|
|
|
|
# this is executed
|
|
|
|
from borg import constants
|
|
|
|
# no fixture-based monkey-patching since star-imports are used for the constants module
|
|
|
|
constants.PBKDF2_ITERATIONS = 1
|
|
|
|
|
2017-06-06 20:37:53 +00:00
|
|
|
|
2016-12-13 18:27:01 +00:00
|
|
|
# needed to get pretty assertion failures in unit tests:
|
2016-12-17 14:58:51 +00:00
|
|
|
if hasattr(pytest, 'register_assert_rewrite'):
|
|
|
|
pytest.register_assert_rewrite('borg.testsuite')
|
2016-10-13 22:46:43 +00:00
|
|
|
|
2017-06-06 20:37:53 +00:00
|
|
|
|
2021-03-15 13:52:39 +00:00
|
|
|
import borg.cache # noqa: E402
|
|
|
|
from borg.logger import setup_logging # noqa: E402
|
2016-05-17 22:22:49 +00:00
|
|
|
|
|
|
|
# Ensure that the loggers exist for all tests
|
|
|
|
setup_logging()
|
|
|
|
|
2021-03-15 13:52:39 +00:00
|
|
|
from borg.testsuite import has_lchflags, has_llfuse, has_pyfuse3 # noqa: E402
|
|
|
|
from borg.testsuite import are_symlinks_supported, are_hardlinks_supported, is_utime_fully_supported # noqa: E402
|
|
|
|
from borg.testsuite.platform import fakeroot_detected # noqa: E402
|
2016-05-17 22:22:49 +00:00
|
|
|
|
|
|
|
|
2016-10-13 21:59:28 +00:00
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def clean_env(tmpdir_factory, monkeypatch):
|
|
|
|
# avoid that we access / modify the user's normal .config / .cache directory:
|
2018-10-31 08:41:02 +00:00
|
|
|
monkeypatch.setenv('XDG_CONFIG_HOME', str(tmpdir_factory.mktemp('xdg-config-home')))
|
|
|
|
monkeypatch.setenv('XDG_CACHE_HOME', str(tmpdir_factory.mktemp('xdg-cache-home')))
|
2016-10-13 21:59:28 +00:00
|
|
|
# also avoid to use anything from the outside environment:
|
2020-10-10 21:12:47 +00:00
|
|
|
keys = [key for key in os.environ
|
|
|
|
if key.startswith('BORG_') and key not in ('BORG_FUSE_IMPL', )]
|
2016-10-13 21:59:28 +00:00
|
|
|
for key in keys:
|
|
|
|
monkeypatch.delenv(key, raising=False)
|
|
|
|
|
|
|
|
|
2016-05-17 22:22:49 +00:00
|
|
|
def pytest_report_header(config, startdir):
|
2016-07-25 03:38:28 +00:00
|
|
|
tests = {
|
|
|
|
"BSD flags": has_lchflags,
|
2020-10-10 21:12:47 +00:00
|
|
|
"fuse2": has_llfuse,
|
|
|
|
"fuse3": has_pyfuse3,
|
2016-07-25 03:38:28 +00:00
|
|
|
"root": not fakeroot_detected(),
|
|
|
|
"symlinks": are_symlinks_supported(),
|
|
|
|
"hardlinks": are_hardlinks_supported(),
|
|
|
|
"atime/mtime": is_utime_fully_supported(),
|
|
|
|
"modes": "BORG_TESTS_IGNORE_MODES" not in os.environ
|
|
|
|
}
|
|
|
|
enabled = []
|
|
|
|
disabled = []
|
|
|
|
for test in tests:
|
|
|
|
if tests[test]:
|
|
|
|
enabled.append(test)
|
|
|
|
else:
|
|
|
|
disabled.append(test)
|
|
|
|
output = "Tests enabled: " + ", ".join(enabled) + "\n"
|
|
|
|
output += "Tests disabled: " + ", ".join(disabled)
|
|
|
|
return output
|
2017-06-06 20:37:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
class DefaultPatches:
|
|
|
|
def __init__(self, request):
|
2017-06-10 15:59:41 +00:00
|
|
|
self.org_cache_wipe_cache = borg.cache.LocalCache.wipe_cache
|
2017-06-06 20:37:53 +00:00
|
|
|
|
|
|
|
def wipe_should_not_be_called(*a, **kw):
|
2021-03-15 13:52:39 +00:00
|
|
|
raise AssertionError("Cache wipe was triggered, if this is part of the test add "
|
|
|
|
"@pytest.mark.allow_cache_wipe")
|
2017-06-06 20:37:53 +00:00
|
|
|
if 'allow_cache_wipe' not in request.keywords:
|
2017-06-10 15:59:41 +00:00
|
|
|
borg.cache.LocalCache.wipe_cache = wipe_should_not_be_called
|
2017-06-06 20:37:53 +00:00
|
|
|
request.addfinalizer(self.undo)
|
|
|
|
|
|
|
|
def undo(self):
|
2017-06-10 15:59:41 +00:00
|
|
|
borg.cache.LocalCache.wipe_cache = self.org_cache_wipe_cache
|
2017-06-06 20:37:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def default_patches(request):
|
|
|
|
return DefaultPatches(request)
|