Skip to content

Commit

Permalink
Define the reposync URL in line and fetch modulemd remotely
Browse files Browse the repository at this point in the history
  • Loading branch information
ehelms committed Sep 5, 2023
1 parent 0993b40 commit a72af33
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 18 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,4 @@ releases/**/rpms.processed
releases/**/tarballs
*.retry
settings.local
tmp/
41 changes: 23 additions & 18 deletions build_stage_repository
Original file line number Diff line number Diff line change
@@ -1,16 +1,18 @@
#!/usr/bin/env python3

from subprocess import check_output, STDOUT, CalledProcessError
from urllib.request import urlretrieve
import os
import yaml
import glob
import shutil
import time
import hashlib
import sys
import tempfile


def move_rpms_from_copr_to_stage(collection, version, src_folder, dest_folder, source=False):
def move_rpms_from_copr_to_stage(collection, version, src_folder, dest_folder, dist, arch, source=False):
if source:
print(f"Moving {collection} Source RPMs from Copr directory to stage repository")
else:
Expand All @@ -19,7 +21,7 @@ def move_rpms_from_copr_to_stage(collection, version, src_folder, dest_folder, s
if not os.path.exists(dest_folder):
os.mkdir(dest_folder)

repo_folder = f"{src_folder}/el8-{collection}-{version}"
repo_folder = f"{src_folder}/{dist}-{collection}-{version}-{arch}"

if source:
files = glob.glob(repo_folder + f"/**/*.src.rpm")
Expand All @@ -33,8 +35,10 @@ def move_rpms_from_copr_to_stage(collection, version, src_folder, dest_folder, s
shutil.rmtree(src_folder)


def modulemd_yaml(collection):
return f"modulemd/modulemd-{collection}-el8.yaml"
def modulemd_yaml(collection, version):
branch = 'develop' if version == 'nightly' else version
path, headers = urlretrieve(f"https://raw.githubusercontent.com/theforeman/foreman-packaging/rpm/{branch}/modulemd/modulemd-{collection}-el8.yaml")
return path


def generate_modulemd_version(version):
Expand Down Expand Up @@ -65,9 +69,9 @@ def create_modulemd(collection, version, stage_dir):
f"{stage_dir}/*.rpm",
"--queryformat=%{name}-%{epochnum}:%{version}-%{release}.%{arch}\n"
]
output = check_output(cmd)
output = check_output(cmd, universal_newlines=True)

with open(modulemd_yaml(collection), 'r') as file:
with open(modulemd_yaml(collection, version), 'r') as file:
modules = yaml.safe_load(file)

modules['data']['artifacts'] = {'rpms': output.splitlines()}
Expand All @@ -85,7 +89,7 @@ def create_repository(repo_dir):
check_output(['createrepo', repo_dir])


def sync_copr_repository(collection, version, target_dir, source=False):
def sync_copr_repository(collection, version, target_dir, dist, arch, source=False):
if source:
print(f"Syncing {collection} {version} Source RPM repository from Copr")
else:
Expand All @@ -96,9 +100,9 @@ def sync_copr_repository(collection, version, target_dir, source=False):
'reposync',
'--newest-only',
'--repo',
f"el8-{collection}-{version}",
'--config',
'reposync_config.conf',
f"{dist}-{collection}-{version}-{arch}",
'--repofrompath',
f"{dist}-{collection}-{version}-{arch},https://download.copr.fedorainfracloud.org/results/@theforeman/{collection}-{version}-staging/rhel-{dist.replace('el', '')}-{arch}/",
'--download-path',
target_dir
]
Expand All @@ -120,16 +124,17 @@ def main():
try:
collection = sys.argv[1]
version = sys.argv[2]
operating_system = sys.argv[3]
dist = sys.argv[3]
arch = 'x86_64'
except IndexError:
raise SystemExit(f"Usage: {sys.argv[0]} collection version os")

base_dir = 'tmp'
rpm_sync_dir = f"{base_dir}/rpms"
srpm_sync_dir = f"{base_dir}/srpms"

stage_dir = f"{base_dir}/{collection}/{version}/{operating_system}/"
rpm_dir = f"{stage_dir}/x86_64"
stage_dir = f"{base_dir}/{collection}/{version}/{dist}/"
rpm_dir = f"{stage_dir}/{arch}"
srpm_dir = f"{stage_dir}/source"

if not os.path.exists(rpm_sync_dir):
Expand All @@ -144,16 +149,16 @@ def main():
if not os.path.exists(srpm_dir):
os.makedirs(srpm_dir)

sync_copr_repository(collection, version, rpm_sync_dir)
sync_copr_repository(collection, version, srpm_sync_dir, source=True)
sync_copr_repository(collection, version, rpm_sync_dir, dist, arch)
sync_copr_repository(collection, version, srpm_sync_dir, dist, arch, source=True)

move_rpms_from_copr_to_stage(collection, version, srpm_sync_dir, srpm_dir, source=True)
move_rpms_from_copr_to_stage(collection, version, rpm_sync_dir, rpm_dir)
move_rpms_from_copr_to_stage(collection, version, srpm_sync_dir, srpm_dir, dist, arch, source=True)
move_rpms_from_copr_to_stage(collection, version, rpm_sync_dir, rpm_dir, dist, arch)

create_repository(rpm_dir)
create_repository(srpm_dir)

if collection in ['foreman', 'katello'] and operating_system == 'el8':
if collection in ['foreman', 'katello'] and dist == 'el8':
create_modulemd(collection, version, rpm_dir)


Expand Down

0 comments on commit a72af33

Please sign in to comment.