mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2024-11-24 13:01:28 +00:00
fix(backups): singleton metaclass was screwing with tests
This commit is contained in:
parent
090198c300
commit
8f019c99e3
|
@ -10,7 +10,8 @@ from selfprivacy_api.backup.providers import get_provider
|
||||||
from selfprivacy_api.graphql.queries.providers import BackupProvider
|
from selfprivacy_api.graphql.queries.providers import BackupProvider
|
||||||
|
|
||||||
|
|
||||||
class Backups(metaclass=SingletonMetaclass):
|
# class Backups(metaclass=SingletonMetaclass):
|
||||||
|
class Backups:
|
||||||
"""A singleton controller for backups"""
|
"""A singleton controller for backups"""
|
||||||
|
|
||||||
provider: AbstractBackupProvider
|
provider: AbstractBackupProvider
|
||||||
|
@ -18,7 +19,8 @@ class Backups(metaclass=SingletonMetaclass):
|
||||||
def __init__(self, test_repo_file: str = ""):
|
def __init__(self, test_repo_file: str = ""):
|
||||||
if test_repo_file != "":
|
if test_repo_file != "":
|
||||||
self.set_localfile_repo(test_repo_file)
|
self.set_localfile_repo(test_repo_file)
|
||||||
self.lookup_provider()
|
else:
|
||||||
|
self.lookup_provider()
|
||||||
|
|
||||||
def set_localfile_repo(self, file_path: str):
|
def set_localfile_repo(self, file_path: str):
|
||||||
ProviderClass = get_provider(BackupProvider.FILE)
|
ProviderClass = get_provider(BackupProvider.FILE)
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import pytest
|
import pytest
|
||||||
import os.path as path
|
import os.path as path
|
||||||
|
from os import makedirs
|
||||||
|
|
||||||
from selfprivacy_api.services.test_service import DummyService
|
from selfprivacy_api.services.test_service import DummyService
|
||||||
|
|
||||||
|
@ -15,17 +16,36 @@ TESTFILE_BODY = "testytest!"
|
||||||
REPO_NAME = "test_backup"
|
REPO_NAME = "test_backup"
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="function")
|
||||||
|
def backups(tmpdir):
|
||||||
|
test_repo_path = path.join(tmpdir, "totallyunrelated")
|
||||||
|
return Backups(test_repo_path)
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
@pytest.fixture()
|
||||||
def test_service(tmpdir, backups):
|
def raw_dummy_service(tmpdir, backups):
|
||||||
testile_path = path.join(tmpdir, "testfile.txt")
|
service_dir = path.join(tmpdir, "test_service")
|
||||||
with open(testile_path, "w") as file:
|
makedirs(service_dir)
|
||||||
|
|
||||||
|
testfile_path = path.join(service_dir, "testfile.txt")
|
||||||
|
with open(testfile_path, "w") as file:
|
||||||
file.write(TESTFILE_BODY)
|
file.write(TESTFILE_BODY)
|
||||||
|
|
||||||
# we need this to not change get_location() much
|
# we need this to not change get_location() much
|
||||||
class TestDummyService(DummyService, location=tmpdir):
|
class TestDummyService(DummyService, location=service_dir):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
service = TestDummyService()
|
service = TestDummyService()
|
||||||
|
return service
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def dummy_service(tmpdir, backups, raw_dummy_service):
|
||||||
|
service = raw_dummy_service
|
||||||
|
repo_path = path.join(tmpdir, "test_repo")
|
||||||
|
assert not path.exists(repo_path)
|
||||||
|
# assert not repo_path
|
||||||
|
|
||||||
backups.init_repo(service)
|
backups.init_repo(service)
|
||||||
return service
|
return service
|
||||||
|
|
||||||
|
@ -49,12 +69,6 @@ def file_backup(tmpdir) -> AbstractBackupProvider:
|
||||||
return provider
|
return provider
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture()
|
|
||||||
def backups(tmpdir):
|
|
||||||
test_repo_path = path.join(tmpdir, "test_repo")
|
|
||||||
return Backups(test_repo_path)
|
|
||||||
|
|
||||||
|
|
||||||
def test_select_backend():
|
def test_select_backend():
|
||||||
provider = providers.get_provider(BackupProvider.BACKBLAZE)
|
provider = providers.get_provider(BackupProvider.BACKBLAZE)
|
||||||
assert provider is not None
|
assert provider is not None
|
||||||
|
@ -65,15 +79,18 @@ def test_file_backend_init(file_backup):
|
||||||
file_backup.backuper.init("somerepo")
|
file_backup.backuper.init("somerepo")
|
||||||
|
|
||||||
|
|
||||||
def test_backup_simple(test_service, memory_backup):
|
def test_backup_simple_file(raw_dummy_service, file_backup):
|
||||||
# temporarily incomplete
|
# temporarily incomplete
|
||||||
assert test_service is not None
|
service = raw_dummy_service
|
||||||
assert memory_backup is not None
|
assert service is not None
|
||||||
memory_backup.backuper.start_backup(test_service.get_location(), REPO_NAME)
|
assert file_backup is not None
|
||||||
|
|
||||||
|
name = service.get_id()
|
||||||
|
file_backup.backuper.init(name)
|
||||||
|
|
||||||
|
|
||||||
def test_backup_service(test_service, backups):
|
def test_backup_service(dummy_service, backups):
|
||||||
backups.back_up(test_service)
|
backups.back_up(dummy_service)
|
||||||
|
|
||||||
|
|
||||||
def test_no_repo(memory_backup):
|
def test_no_repo(memory_backup):
|
||||||
|
@ -81,6 +98,6 @@ def test_no_repo(memory_backup):
|
||||||
assert memory_backup.backuper.get_snapshots("") == []
|
assert memory_backup.backuper.get_snapshots("") == []
|
||||||
|
|
||||||
|
|
||||||
# def test_one_snapshot(backups, test_service):
|
# def test_one_snapshot(backups, dummy_service):
|
||||||
# backups.back_up(test_service)
|
# backups.back_up(dummy_service)
|
||||||
# assert len(backups.get_snapshots(test_service)) == 1
|
# assert len(backups.get_snapshots(dummy_service)) == 1
|
||||||
|
|
Loading…
Reference in a new issue