Page MenuHomeSoftware Heritage

D4135.id14580.diff
No OneTemporary

D4135.id14580.diff

diff --git a/swh/vault/tests/test_cookers.py b/swh/vault/tests/test_cookers.py
--- a/swh/vault/tests/test_cookers.py
+++ b/swh/vault/tests/test_cookers.py
@@ -129,20 +129,25 @@
return swh_loader_config
+@pytest.fixture
def git_loader(
- storage,
- repo_path,
- visit_date=datetime.datetime.now(datetime.timezone.utc),
- config=None,
+ swh_storage, swh_loader_config,
):
"""Instantiate a Git Loader using the storage instance as storage.
"""
- loader = GitLoaderFromDisk(
- "fake_origin", directory=repo_path, visit_date=visit_date, config=config
- )
- loader.storage = storage
- return loader
+
+ def _create_loader(directory):
+ loader = GitLoaderFromDisk(
+ "fake_origin",
+ directory=directory,
+ visit_date=datetime.datetime.now(datetime.timezone.utc),
+ config=swh_loader_config,
+ )
+ loader.storage = swh_storage
+ return loader
+
+ return _create_loader
@contextlib.contextmanager
@@ -196,7 +201,7 @@
class TestDirectoryCooker:
- def test_directory_simple(self, swh_storage, swh_loader_config):
+ def test_directory_simple(self, git_loader):
repo = TestRepo()
with repo as rp:
(rp / "file").write_text(TEST_CONTENT)
@@ -206,13 +211,13 @@
(rp / "dir1/dir2").mkdir(parents=True)
(rp / "dir1/dir2/file").write_text(TEST_CONTENT)
c = repo.commit()
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
obj_id_hex = repo.repo[c].tree.decode()
obj_id = hashutil.hash_to_bytes(obj_id_hex)
- with cook_extract_directory(swh_storage, obj_id) as p:
+ with cook_extract_directory(loader.storage, obj_id) as p:
assert (p / "file").stat().st_mode == 0o100644
assert (p / "file").read_text() == TEST_CONTENT
assert (p / "executable").stat().st_mode == 0o100755
@@ -225,7 +230,7 @@
directory = from_disk.Directory.from_disk(path=bytes(p))
assert obj_id_hex == hashutil.hash_to_hex(directory.hash)
- def test_directory_filtered_objects(self, swh_storage, swh_loader_config):
+ def test_directory_filtered_objects(self, git_loader):
repo = TestRepo()
with repo as rp:
file_1, id_1 = hash_content(b"test1")
@@ -237,7 +242,7 @@
(rp / "absent_file").write_bytes(file_3)
c = repo.commit()
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
obj_id_hex = repo.repo[c].tree.decode()
@@ -245,7 +250,7 @@
# FIXME: storage.content_update() should be changed to allow things
# like that
- with swh_storage.get_db().transaction() as cur:
+ with loader.storage.get_db().transaction() as cur:
cur.execute(
"""update content set status = 'visible'
where sha1 = %s""",
@@ -262,12 +267,12 @@
(id_3,),
)
- with cook_extract_directory(swh_storage, obj_id) as p:
+ with cook_extract_directory(loader.storage, obj_id) as p:
assert (p / "file").read_bytes() == b"test1"
assert (p / "hidden_file").read_bytes() == HIDDEN_MESSAGE
assert (p / "absent_file").read_bytes() == SKIPPED_MESSAGE
- def test_directory_bogus_perms(self, swh_storage, swh_loader_config):
+ def test_directory_bogus_perms(self, git_loader):
# Some early git repositories have 664/775 permissions... let's check
# if all the weird modes are properly normalized in the directory
# cooker.
@@ -280,13 +285,13 @@
(rp / "wat").write_text(TEST_CONTENT)
(rp / "wat").chmod(0o604)
c = repo.commit()
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
obj_id_hex = repo.repo[c].tree.decode()
obj_id = hashutil.hash_to_bytes(obj_id_hex)
- with cook_extract_directory(swh_storage, obj_id) as p:
+ with cook_extract_directory(loader.storage, obj_id) as p:
assert (p / "file").stat().st_mode == 0o100644
assert (p / "executable").stat().st_mode == 0o100755
assert (p / "wat").stat().st_mode == 0o100644
@@ -312,7 +317,7 @@
class TestRevisionGitfastCooker:
- def test_revision_simple(self, swh_storage, swh_loader_config):
+ def test_revision_simple(self, git_loader):
#
# 1--2--3--4--5--6--7
#
@@ -334,12 +339,12 @@
repo.commit("remove file2")
(rp / "bin1").rename(rp / "bin")
repo.commit("rename bin1 to bin")
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
obj_id_hex = repo.repo.refs[b"HEAD"].decode()
obj_id = hashutil.hash_to_bytes(obj_id_hex)
- with cook_extract_revision_gitfast(swh_storage, obj_id) as (ert, p):
+ with cook_extract_revision_gitfast(loader.storage, obj_id) as (ert, p):
ert.checkout(b"HEAD")
assert (p / "file1").stat().st_mode == 0o100644
assert (p / "file1").read_text() == TEST_CONTENT
@@ -351,7 +356,7 @@
assert (p / "dir1/dir2/file").stat().st_mode == 0o100644
assert ert.repo.refs[b"HEAD"].decode() == obj_id_hex
- def test_revision_two_roots(self, swh_storage, swh_loader_config):
+ def test_revision_two_roots(self, git_loader):
#
# 1----3---4
# /
@@ -369,13 +374,13 @@
repo.commit("add file3")
obj_id_hex = repo.repo.refs[b"HEAD"].decode()
obj_id = hashutil.hash_to_bytes(obj_id_hex)
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
- with cook_extract_revision_gitfast(swh_storage, obj_id) as (ert, p):
+ with cook_extract_revision_gitfast(loader.storage, obj_id) as (ert, p):
assert ert.repo.refs[b"HEAD"].decode() == obj_id_hex
- def test_revision_two_double_fork_merge(self, swh_storage, swh_loader_config):
+ def test_revision_two_double_fork_merge(self, git_loader):
#
# 2---4---6
# / / /
@@ -403,13 +408,13 @@
obj_id_hex = repo.repo.refs[b"HEAD"].decode()
obj_id = hashutil.hash_to_bytes(obj_id_hex)
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
- with cook_extract_revision_gitfast(swh_storage, obj_id) as (ert, p):
+ with cook_extract_revision_gitfast(loader.storage, obj_id) as (ert, p):
assert ert.repo.refs[b"HEAD"].decode() == obj_id_hex
- def test_revision_triple_merge(self, swh_storage, swh_loader_config):
+ def test_revision_triple_merge(self, git_loader):
#
# .---.---5
# / / /
@@ -431,13 +436,13 @@
obj_id_hex = repo.repo.refs[b"HEAD"].decode()
obj_id = hashutil.hash_to_bytes(obj_id_hex)
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
- with cook_extract_revision_gitfast(swh_storage, obj_id) as (ert, p):
+ with cook_extract_revision_gitfast(loader.storage, obj_id) as (ert, p):
assert ert.repo.refs[b"HEAD"].decode() == obj_id_hex
- def test_revision_filtered_objects(self, swh_storage, swh_loader_config):
+ def test_revision_filtered_objects(self, git_loader):
repo = TestRepo()
with repo as rp:
file_1, id_1 = hash_content(b"test1")
@@ -451,12 +456,12 @@
repo.commit()
obj_id_hex = repo.repo.refs[b"HEAD"].decode()
obj_id = hashutil.hash_to_bytes(obj_id_hex)
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
# FIXME: storage.content_update() should be changed to allow things
# like that
- with swh_storage.get_db().transaction() as cur:
+ with loader.storage.get_db().transaction() as cur:
cur.execute(
"""update content set status = 'visible'
where sha1 = %s""",
@@ -473,13 +478,13 @@
(id_3,),
)
- with cook_extract_revision_gitfast(swh_storage, obj_id) as (ert, p):
+ with cook_extract_revision_gitfast(loader.storage, obj_id) as (ert, p):
ert.checkout(b"HEAD")
assert (p / "file").read_bytes() == b"test1"
assert (p / "hidden_file").read_bytes() == HIDDEN_MESSAGE
assert (p / "absent_file").read_bytes() == SKIPPED_MESSAGE
- def test_revision_bogus_perms(self, swh_storage, swh_loader_config):
+ def test_revision_bogus_perms(self, git_loader):
# Some early git repositories have 664/775 permissions... let's check
# if all the weird modes are properly normalized in the revision
# cooker.
@@ -492,25 +497,25 @@
(rp / "wat").write_text(TEST_CONTENT)
(rp / "wat").chmod(0o604)
repo.commit("initial commit")
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
obj_id_hex = repo.repo.refs[b"HEAD"].decode()
obj_id = hashutil.hash_to_bytes(obj_id_hex)
- with cook_extract_revision_gitfast(swh_storage, obj_id) as (ert, p):
+ with cook_extract_revision_gitfast(loader.storage, obj_id) as (ert, p):
ert.checkout(b"HEAD")
assert (p / "file").stat().st_mode == 0o100644
assert (p / "executable").stat().st_mode == 0o100755
assert (p / "wat").stat().st_mode == 0o100644
- def test_revision_null_fields(self, swh_storage, swh_loader_config):
+ def test_revision_null_fields(self, git_loader):
# Our schema doesn't enforce a lot of non-null revision fields. We need
# to check these cases don't break the cooker.
repo = TestRepo()
with repo as rp:
(rp / "file").write_text(TEST_CONTENT)
c = repo.commit("initial commit")
- loader = git_loader(swh_storage, str(rp), config=swh_loader_config)
+ loader = git_loader(str(rp))
loader.load()
repo.repo.refs[b"HEAD"].decode()
dir_id_hex = repo.repo[c].tree.decode()
@@ -529,9 +534,10 @@
synthetic=True,
)
- swh_storage.revision_add([test_revision])
+ storage = loader.storage
+ storage.revision_add([test_revision])
- with cook_extract_revision_gitfast(swh_storage, test_revision.id) as (ert, p):
+ with cook_extract_revision_gitfast(storage, test_revision.id) as (ert, p):
ert.checkout(b"HEAD")
assert (p / "file").stat().st_mode == 0o100644

File Metadata

Mime Type
text/plain
Expires
Tue, Dec 17, 3:57 PM (2 d, 20 h ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
3226695

Event Timeline