Make getting old compose config reusable

The file will only be loaded once, it gets cached afterwards.

Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
This commit is contained in:
Lubomír Sedlář 2021-08-06 14:02:54 +02:00
parent d8d1cc520b
commit 20dc4beb6b
4 changed files with 45 additions and 75 deletions

View File

@ -252,6 +252,8 @@ class Compose(kobo.log.LoggingBase):
self.koji_event = koji_event or conf.get("koji_event") self.koji_event = koji_event or conf.get("koji_event")
self.notifier = notifier self.notifier = notifier
self._old_config = None
# path definitions # path definitions
self.paths = Paths(self) self.paths = Paths(self)
@ -635,6 +637,22 @@ class Compose(kobo.log.LoggingBase):
with open(tb_path, "wb") as f: with open(tb_path, "wb") as f:
f.write(kobo.tback.Traceback().get_traceback()) f.write(kobo.tback.Traceback().get_traceback())
def load_old_compose_config(self):
"""
Helper method to load Pungi config dump from old compose.
"""
if not self._old_config:
config_dump_full = self.paths.log.log_file("global", "config-dump")
config_dump_full = self.paths.old_compose_path(config_dump_full)
if not config_dump_full:
return None
self.log_info("Loading old config file: %s", config_dump_full)
with open(config_dump_full, "r") as f:
self._old_config = json.load(f)
return self._old_config
def get_ordered_variant_uids(compose): def get_ordered_variant_uids(compose):
if not hasattr(compose, "_ordered_variant_uids"): if not hasattr(compose, "_ordered_variant_uids"):

View File

@ -194,21 +194,6 @@ def load_old_gather_result(compose, arch, variant):
return old_result return old_result
def load_old_compose_config(compose):
"""
Helper method to load Pungi config dump from old compose.
"""
config_dump_full = compose.paths.log.log_file("global", "config-dump")
config_dump_full = compose.paths.old_compose_path(config_dump_full)
if not config_dump_full:
return None
compose.log_info("Loading old config file: %s", config_dump_full)
with open(config_dump_full, "r") as f:
old_config = json.load(f)
return old_config
def reuse_old_gather_packages(compose, arch, variant, package_sets, methods): def reuse_old_gather_packages(compose, arch, variant, package_sets, methods):
""" """
Tries to reuse `gather_packages` result from older compose. Tries to reuse `gather_packages` result from older compose.
@ -230,7 +215,7 @@ def reuse_old_gather_packages(compose, arch, variant, package_sets, methods):
compose.log_info(log_msg % "no old gather results.") compose.log_info(log_msg % "no old gather results.")
return return
old_config = load_old_compose_config(compose) old_config = compose.load_old_compose_config()
if old_config is None: if old_config is None:
compose.log_info(log_msg % "no old compose config dump.") compose.log_info(log_msg % "no old compose config dump.")
return return

View File

@ -230,6 +230,7 @@ class DummyCompose(object):
self.should_create_yum_database = True self.should_create_yum_database = True
self.cache_region = None self.cache_region = None
self.containers_metadata = {} self.containers_metadata = {}
self.load_old_compose_config = mock.Mock(return_value=None)
def setup_optional(self): def setup_optional(self):
self.all_variants["Server-optional"] = MockVariant( self.all_variants["Server-optional"] = MockVariant(

View File

@ -1099,10 +1099,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_no_old_compose_config(self, load_old_gather_result):
def test_reuse_no_old_compose_config(
self, load_old_compose_config, load_old_gather_result
):
load_old_gather_result.return_value = { load_old_gather_result.return_value = {
"rpm": [{"path": "/build/bash-1.0.0-1.x86_64.rpm"}], "rpm": [{"path": "/build/bash-1.0.0-1.x86_64.rpm"}],
"srpm": [], "srpm": [],
@ -1111,7 +1108,6 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = None
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], [], "deps" compose, "x86_64", compose.variants["Server"], [], "deps"
@ -1119,10 +1115,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_compose_config_different(self, load_old_gather_result):
def test_reuse_compose_config_different(
self, load_old_compose_config, load_old_gather_result
):
load_old_gather_result.return_value = { load_old_gather_result.return_value = {
"rpm": [{"path": "/build/bash-1.0.0-1.x86_64.rpm"}], "rpm": [{"path": "/build/bash-1.0.0-1.x86_64.rpm"}],
"srpm": [], "srpm": [],
@ -1133,7 +1126,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self._save_config_dump(compose) self._save_config_dump(compose)
compose_conf_copy = dict(compose.conf) compose_conf_copy = dict(compose.conf)
compose_conf_copy["gather_method"] = "nodeps" compose_conf_copy["gather_method"] = "nodeps"
load_old_compose_config.return_value = compose_conf_copy compose.load_old_compose_config.return_value = compose_conf_copy
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], [], "nodeps" compose, "x86_64", compose.variants["Server"], [], "nodeps"
@ -1141,10 +1134,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_compose_config_different_whitelist(self, load_old_gather_result):
def test_reuse_compose_config_different_whitelist(
self, load_old_compose_config, load_old_gather_result
):
for whitelist_opt in ["product_id", "pkgset_koji_builds"]: for whitelist_opt in ["product_id", "pkgset_koji_builds"]:
load_old_gather_result.return_value = { load_old_gather_result.return_value = {
"rpm": [{"path": "/build/bash-1.0.0-1.x86_64.rpm"}], "rpm": [{"path": "/build/bash-1.0.0-1.x86_64.rpm"}],
@ -1156,7 +1146,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self._save_config_dump(compose) self._save_config_dump(compose)
compose_conf_copy = dict(compose.conf) compose_conf_copy = dict(compose.conf)
compose_conf_copy[whitelist_opt] = "different" compose_conf_copy[whitelist_opt] = "different"
load_old_compose_config.return_value = compose_conf_copy compose.load_old_compose_config.return_value = compose_conf_copy
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], [], "deps" compose, "x86_64", compose.variants["Server"], [], "deps"
@ -1184,14 +1174,13 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
return package_sets return package_sets
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse(self, load_old_gather_result):
def test_reuse(self, load_old_compose_config, load_old_gather_result):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=[] load_old_gather_result, requires=[], provides=[]
) )
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = compose.conf compose.load_old_compose_config.return_value = compose.conf
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], package_sets, "deps" compose, "x86_64", compose.variants["Server"], package_sets, "deps"
@ -1206,16 +1195,13 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
) )
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_update_gather_lookaside_repos(self, load_old_gather_result):
def test_reuse_update_gather_lookaside_repos(
self, load_old_compose_config, load_old_gather_result
):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=[] load_old_gather_result, requires=[], provides=[]
) )
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = copy.deepcopy(compose.conf) compose.load_old_compose_config.return_value = copy.deepcopy(compose.conf)
gather._update_config(compose, "Server", "x86_64", compose.topdir) gather._update_config(compose, "Server", "x86_64", compose.topdir)
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
@ -1231,9 +1217,8 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
) )
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config")
def test_reuse_update_gather_lookaside_repos_different_initial_repos( def test_reuse_update_gather_lookaside_repos_different_initial_repos(
self, load_old_compose_config, load_old_gather_result self, load_old_gather_result
): ):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=[] load_old_gather_result, requires=[], provides=[]
@ -1242,7 +1227,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self._save_config_dump(compose) self._save_config_dump(compose)
lookasides = compose.conf["gather_lookaside_repos"] lookasides = compose.conf["gather_lookaside_repos"]
lookasides.append(("^Server$", {"x86_64": "http://localhost/real.repo"})) lookasides.append(("^Server$", {"x86_64": "http://localhost/real.repo"}))
load_old_compose_config.return_value = copy.deepcopy(compose.conf) compose.load_old_compose_config.return_value = copy.deepcopy(compose.conf)
gather._update_config(compose, "Server", "x86_64", compose.topdir) gather._update_config(compose, "Server", "x86_64", compose.topdir)
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
@ -1251,9 +1236,8 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config")
def test_reuse_update_gather_lookaside_repos_different_initial_repos_list( def test_reuse_update_gather_lookaside_repos_different_initial_repos_list(
self, load_old_compose_config, load_old_gather_result self, load_old_gather_result
): ):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=[] load_old_gather_result, requires=[], provides=[]
@ -1263,7 +1247,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
lookasides = compose.conf["gather_lookaside_repos"] lookasides = compose.conf["gather_lookaside_repos"]
repos = ["http://localhost/real1.repo", "http://localhost/real2.repo"] repos = ["http://localhost/real1.repo", "http://localhost/real2.repo"]
lookasides.append(("^Server$", {"x86_64": repos})) lookasides.append(("^Server$", {"x86_64": repos}))
load_old_compose_config.return_value = copy.deepcopy(compose.conf) compose.load_old_compose_config.return_value = copy.deepcopy(compose.conf)
gather._update_config(compose, "Server", "x86_64", compose.topdir) gather._update_config(compose, "Server", "x86_64", compose.topdir)
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
@ -1272,10 +1256,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_no_old_file_cache(self, load_old_gather_result):
def test_reuse_no_old_file_cache(
self, load_old_compose_config, load_old_gather_result
):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=[] load_old_gather_result, requires=[], provides=[]
) )
@ -1284,7 +1265,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
} }
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = compose.conf compose.load_old_compose_config.return_value = compose.conf
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], package_sets, "deps" compose, "x86_64", compose.variants["Server"], package_sets, "deps"
@ -1292,10 +1273,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_two_rpms_from_same_source(self, load_old_gather_result):
def test_reuse_two_rpms_from_same_source(
self, load_old_compose_config, load_old_gather_result
):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=[] load_old_gather_result, requires=[], provides=[]
) )
@ -1307,7 +1285,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
pkg_set.file_cache["/build/bash-1-2.x86_64.rpm"] = bash_pkg pkg_set.file_cache["/build/bash-1-2.x86_64.rpm"] = bash_pkg
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = compose.conf compose.load_old_compose_config.return_value = compose.conf
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], package_sets, "deps" compose, "x86_64", compose.variants["Server"], package_sets, "deps"
@ -1315,10 +1293,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_rpm_added_removed(self, load_old_gather_result):
def test_reuse_rpm_added_removed(
self, load_old_compose_config, load_old_gather_result
):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=[] load_old_gather_result, requires=[], provides=[]
) )
@ -1333,7 +1308,7 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
pkg_set.file_cache["/build/foo-1-1.x86_64.rpm"] = foo_pkg pkg_set.file_cache["/build/foo-1-1.x86_64.rpm"] = foo_pkg
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = compose.conf compose.load_old_compose_config.return_value = compose.conf
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], package_sets, "deps" compose, "x86_64", compose.variants["Server"], package_sets, "deps"
@ -1341,17 +1316,14 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_different_packages(self, load_old_gather_result):
def test_reuse_different_packages(
self, load_old_compose_config, load_old_gather_result
):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=["foo"] load_old_gather_result, requires=[], provides=["foo"]
) )
package_sets[0]["global"].old_file_cache = None package_sets[0]["global"].old_file_cache = None
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = compose.conf compose.load_old_compose_config.return_value = compose.conf
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], package_sets, "deps" compose, "x86_64", compose.variants["Server"], package_sets, "deps"
@ -1359,16 +1331,13 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_requires_changed(self, load_old_gather_result):
def test_reuse_requires_changed(
self, load_old_compose_config, load_old_gather_result
):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=["foo"], provides=[] load_old_gather_result, requires=["foo"], provides=[]
) )
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = compose.conf compose.load_old_compose_config.return_value = compose.conf
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], package_sets, "deps" compose, "x86_64", compose.variants["Server"], package_sets, "deps"
@ -1376,16 +1345,13 @@ class TestReuseOldGatherPackages(helpers.PungiTestCase):
self.assertEqual(result, None) self.assertEqual(result, None)
@mock.patch("pungi.phases.gather.load_old_gather_result") @mock.patch("pungi.phases.gather.load_old_gather_result")
@mock.patch("pungi.phases.gather.load_old_compose_config") def test_reuse_provides_changed(self, load_old_gather_result):
def test_reuse_provides_changed(
self, load_old_compose_config, load_old_gather_result
):
package_sets = self._prepare_package_sets( package_sets = self._prepare_package_sets(
load_old_gather_result, requires=[], provides=["foo"] load_old_gather_result, requires=[], provides=["foo"]
) )
compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True}) compose = helpers.DummyCompose(self.topdir, {"gather_allow_reuse": True})
self._save_config_dump(compose) self._save_config_dump(compose)
load_old_compose_config.return_value = compose.conf compose.load_old_compose_config.return_value = compose.conf
result = gather.reuse_old_gather_packages( result = gather.reuse_old_gather_packages(
compose, "x86_64", compose.variants["Server"], package_sets, "deps" compose, "x86_64", compose.variants["Server"], package_sets, "deps"