From 12c43803400763f6207b1346ca81f95662c67178 Mon Sep 17 00:00:00 2001 From: Jiri Kyjovsky Date: Mon, 11 Nov 2024 16:38:16 +0100 Subject: [PATCH] misc: copr_new_packages, drop requests to koji api, use repoquery Asking koji for each package was slow, also we were spamming koji API. This gets every package just once. --- misc/copr_new_packages.py | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/misc/copr_new_packages.py b/misc/copr_new_packages.py index 7b4e945ce..b2412582b 100644 --- a/misc/copr_new_packages.py +++ b/misc/copr_new_packages.py @@ -33,6 +33,12 @@ def pick_project_candidates(client, projects, since): Magazine article). By such projects we consider those with at least one succeeded build and at least some project information filled. """ + rawhide_pks_resp = subprocess.run( + ["dnf", "repoquery", "rawhide", "--queryformat", "%{name}", "*"], + stdout=subprocess.PIPE, + ) + fedora_rawhide_pkgs = {x for x in rawhide_pks_resp.stdout.decode().split("\n")} + picked = [] for project in projects: if project.unlisted_on_hp: @@ -55,7 +61,9 @@ def pick_project_candidates(client, projects, since): continue builds = filter_unique_package_builds(builds) - builds = [b for b in builds if not is_in_fedora(b.source_package["name"])] + builds = [ + b for b in builds if b.source_package["name"] not in fedora_rawhide_pkgs + ] if not builds: print("Skipping {}, all packages already in Fedora".format(project.full_name)) continue @@ -81,14 +89,6 @@ def filter_unique_package_builds(builds): return unique.values() -def is_in_fedora(packagename): - """ - Check if a given package is already provided by Fedora official repositories - """ - cmd = ["koji", "search", "package", packagename] - return bool(subprocess.check_output(cmd)) - - def get_parser(): description = ("This tool lists new packages in Copr, that are not yet " "available in Fedora. It's main purpose is to help us pick "