Release 4.1.26
This commit is contained in:
parent
ad7a42e1cf
commit
900266f1e1
@ -1,21 +1,24 @@
|
|||||||
From 622ba38a84d3e748ee1fa8b278f22af74c8aa393 Mon Sep 17 00:00:00 2001
|
From a6c0cf38c05e67e616a424dad16194d5de36134a Mon Sep 17 00:00:00 2001
|
||||||
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
||||||
Date: Wed, 4 Jul 2018 09:16:51 +0200
|
Date: Wed, 4 Jul 2018 09:16:51 +0200
|
||||||
Subject: [PATCH] Skip tests involving lookaside with new DNF
|
Subject: [PATCH] Fix tests for DNF 3
|
||||||
MIME-Version: 1.0
|
MIME-Version: 1.0
|
||||||
Content-Type: text/plain; charset=UTF-8
|
Content-Type: text/plain; charset=UTF-8
|
||||||
Content-Transfer-Encoding: 8bit
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
DNF 3 seems to work differently than previous versions in terms of
|
The configuration for modules has changed.
|
||||||
handling lookaside. Disable the the tests for now.
|
|
||||||
|
Lookaside handling has changed, and there are now test failures. This
|
||||||
|
could be a bug in DNF, or maybe Pungi is not setting things up
|
||||||
|
correctly. As a temporary workaround we can skip the tests.
|
||||||
|
|
||||||
Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
|
Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
|
||||||
---
|
---
|
||||||
tests/test_gather.py | 7 ++++++-
|
tests/test_gather.py | 11 ++++++++++-
|
||||||
1 file changed, 6 insertions(+), 1 deletion(-)
|
1 file changed, 10 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/tests/test_gather.py b/tests/test_gather.py
|
diff --git a/tests/test_gather.py b/tests/test_gather.py
|
||||||
index 25dfc399..2ea3e324 100644
|
index 25dfc399..8ccbf2f8 100644
|
||||||
--- a/tests/test_gather.py
|
--- a/tests/test_gather.py
|
||||||
+++ b/tests/test_gather.py
|
+++ b/tests/test_gather.py
|
||||||
@@ -22,6 +22,7 @@ os.environ['PATH'] = '%s:%s' % (BINDIR, os.environ['PATH'])
|
@@ -22,6 +22,7 @@ os.environ['PATH'] = '%s:%s' % (BINDIR, os.environ['PATH'])
|
||||||
@ -26,15 +29,19 @@ index 25dfc399..2ea3e324 100644
|
|||||||
from pungi.dnf_wrapper import DnfWrapper, Conf
|
from pungi.dnf_wrapper import DnfWrapper, Conf
|
||||||
from pungi.gather_dnf import Gather, GatherOptions, PkgFlag
|
from pungi.gather_dnf import Gather, GatherOptions, PkgFlag
|
||||||
HAS_DNF = True
|
HAS_DNF = True
|
||||||
@@ -1810,7 +1811,6 @@ class DNFDepsolvingTestCase(DepsolvingBase, unittest.TestCase):
|
@@ -1810,7 +1811,10 @@ class DNFDepsolvingTestCase(DepsolvingBase, unittest.TestCase):
|
||||||
conf = Conf(base_arch)
|
conf = Conf(base_arch)
|
||||||
conf.persistdir = persistdir
|
conf.persistdir = persistdir
|
||||||
conf.cachedir = self.cachedir
|
conf.cachedir = self.cachedir
|
||||||
- conf.modulesdir = os.path.join(persistdir, 'modules.d')
|
- conf.modulesdir = os.path.join(persistdir, 'modules.d')
|
||||||
|
+ if int(dnf_version.split('.')[0]) < 3:
|
||||||
|
+ conf.modulesdir = os.path.join(persistdir, 'modules.d')
|
||||||
|
+ else:
|
||||||
|
+ conf.modulesdir._set(os.path.join(persistdir, 'modules.d'))
|
||||||
if exclude:
|
if exclude:
|
||||||
conf.exclude = exclude
|
conf.exclude = exclude
|
||||||
dnf = DnfWrapper(conf)
|
dnf = DnfWrapper(conf)
|
||||||
@@ -1888,6 +1888,7 @@ class DNFDepsolvingTestCase(DepsolvingBase, unittest.TestCase):
|
@@ -1888,6 +1892,7 @@ class DNFDepsolvingTestCase(DepsolvingBase, unittest.TestCase):
|
||||||
"dummy-glibc-debuginfo-common-2.14-5.x86_64.rpm",
|
"dummy-glibc-debuginfo-common-2.14-5.x86_64.rpm",
|
||||||
])
|
])
|
||||||
|
|
||||||
@ -42,7 +49,7 @@ index 25dfc399..2ea3e324 100644
|
|||||||
def test_firefox_selfhosting_with_krb5_lookaside(self):
|
def test_firefox_selfhosting_with_krb5_lookaside(self):
|
||||||
super(DNFDepsolvingTestCase, self).test_firefox_selfhosting_with_krb5_lookaside()
|
super(DNFDepsolvingTestCase, self).test_firefox_selfhosting_with_krb5_lookaside()
|
||||||
self.assertFlags("dummy-krb5-devel-1.10-5.x86_64", [PkgFlag.lookaside])
|
self.assertFlags("dummy-krb5-devel-1.10-5.x86_64", [PkgFlag.lookaside])
|
||||||
@@ -1910,3 +1911,7 @@ class DNFDepsolvingTestCase(DepsolvingBase, unittest.TestCase):
|
@@ -1910,3 +1915,7 @@ class DNFDepsolvingTestCase(DepsolvingBase, unittest.TestCase):
|
||||||
])
|
])
|
||||||
self.assertItemsEqual(pkg_map["debuginfo"], [
|
self.assertItemsEqual(pkg_map["debuginfo"], [
|
||||||
])
|
])
|
@ -1,7 +1,7 @@
|
|||||||
From c6bb04041867c242629c9becd83d47f2722b2432 Mon Sep 17 00:00:00 2001
|
From 9dc20c455df71f95a7f131ac10b7013042c5f71d Mon Sep 17 00:00:00 2001
|
||||||
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
||||||
Date: Wed, 11 Apr 2018 09:18:59 +0200
|
Date: Wed, 11 Apr 2018 09:18:59 +0200
|
||||||
Subject: [PATCH 1/6] Revert "Move ostree phase and pipelines for running
|
Subject: [PATCH 1/3] Revert "Move ostree phase and pipelines for running
|
||||||
phases"
|
phases"
|
||||||
|
|
||||||
This reverts commit 660c04368ba1abed310f121d01f0fa029eea5f11.
|
This reverts commit 660c04368ba1abed310f121d01f0fa029eea5f11.
|
||||||
@ -15,10 +15,10 @@ This reverts commit 660c04368ba1abed310f121d01f0fa029eea5f11.
|
|||||||
delete mode 100644 pungi/phases/weaver.py
|
delete mode 100644 pungi/phases/weaver.py
|
||||||
|
|
||||||
diff --git a/bin/pungi-koji b/bin/pungi-koji
|
diff --git a/bin/pungi-koji b/bin/pungi-koji
|
||||||
index b3b49de5..e797ce86 100755
|
index 42dcb424..f6971591 100755
|
||||||
--- a/bin/pungi-koji
|
--- a/bin/pungi-koji
|
||||||
+++ b/bin/pungi-koji
|
+++ b/bin/pungi-koji
|
||||||
@@ -365,27 +365,41 @@ def run_compose(compose, create_latest_link=True, latest_link_status=None):
|
@@ -367,27 +367,41 @@ def run_compose(compose, create_latest_link=True, latest_link_status=None):
|
||||||
# Store the password
|
# Store the password
|
||||||
compose.conf["signing_key_password"] = signing_key_password
|
compose.conf["signing_key_password"] = signing_key_password
|
||||||
|
|
||||||
@ -71,7 +71,7 @@ index b3b49de5..e797ce86 100755
|
|||||||
|
|
||||||
# write treeinfo before ISOs are created
|
# write treeinfo before ISOs are created
|
||||||
for variant in compose.get_variants():
|
for variant in compose.get_variants():
|
||||||
@@ -401,17 +415,12 @@ def run_compose(compose, create_latest_link=True, latest_link_status=None):
|
@@ -403,17 +417,12 @@ def run_compose(compose, create_latest_link=True, latest_link_status=None):
|
||||||
pungi.metadata.write_media_repo(compose, arch, variant, timestamp)
|
pungi.metadata.write_media_repo(compose, arch, variant, timestamp)
|
||||||
|
|
||||||
# Start all phases for image artifacts
|
# Start all phases for image artifacts
|
||||||
@ -95,7 +95,7 @@ index b3b49de5..e797ce86 100755
|
|||||||
|
|
||||||
image_checksum_phase.start()
|
image_checksum_phase.start()
|
||||||
image_checksum_phase.stop()
|
image_checksum_phase.stop()
|
||||||
@@ -420,6 +429,7 @@ def run_compose(compose, create_latest_link=True, latest_link_status=None):
|
@@ -422,6 +431,7 @@ def run_compose(compose, create_latest_link=True, latest_link_status=None):
|
||||||
compose.im.dump(compose.paths.compose.metadata("images.json"))
|
compose.im.dump(compose.paths.compose.metadata("images.json"))
|
||||||
osbs_phase.dump_metadata()
|
osbs_phase.dump_metadata()
|
||||||
|
|
||||||
@ -615,5 +615,5 @@ index ba80afe3..a8b9469a 100644
|
|||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
--
|
--
|
||||||
2.14.3
|
2.14.4
|
||||||
|
|
||||||
|
@ -1,21 +1,21 @@
|
|||||||
From 376f52f1c18e5c8500fa8afd9c91ba9a6e4c4ae0 Mon Sep 17 00:00:00 2001
|
From 883a69645b92b243787312af232aeb804cf53292 Mon Sep 17 00:00:00 2001
|
||||||
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
||||||
Date: Wed, 11 Apr 2018 09:19:53 +0200
|
Date: Wed, 11 Apr 2018 09:19:53 +0200
|
||||||
Subject: [PATCH 2/6] Revert "Other repo for OstreeInstaller"
|
Subject: [PATCH 2/3] Revert "Other repo for OstreeInstaller"
|
||||||
|
|
||||||
This reverts commit 5c081cb545715c2a912ff50fa57554e89d905868.
|
This reverts commit 5c081cb545715c2a912ff50fa57554e89d905868.
|
||||||
---
|
---
|
||||||
pungi/checks.py | 3 ++-
|
pungi/checks.py | 3 +-
|
||||||
pungi/phases/ostree_installer.py | 11 ++------
|
pungi/phases/ostree_installer.py | 18 ++----------
|
||||||
pungi/util.py | 21 +++++----------
|
pungi/util.py | 21 ++++----------
|
||||||
tests/test_ostree_installer_phase.py | 50 +++++++++++++-----------------------
|
tests/test_ostree_installer_phase.py | 54 +++++++++++++-----------------------
|
||||||
4 files changed, 28 insertions(+), 57 deletions(-)
|
4 files changed, 29 insertions(+), 67 deletions(-)
|
||||||
|
|
||||||
diff --git a/pungi/checks.py b/pungi/checks.py
|
diff --git a/pungi/checks.py b/pungi/checks.py
|
||||||
index 2ddd7164..03cab460 100644
|
index 017fab23..61d42b89 100644
|
||||||
--- a/pungi/checks.py
|
--- a/pungi/checks.py
|
||||||
+++ b/pungi/checks.py
|
+++ b/pungi/checks.py
|
||||||
@@ -998,7 +998,7 @@ def make_schema():
|
@@ -1009,7 +1009,7 @@ def make_schema():
|
||||||
"tag_ref": {"type": "boolean"},
|
"tag_ref": {"type": "boolean"},
|
||||||
"ostree_ref": {"type": "string"},
|
"ostree_ref": {"type": "string"},
|
||||||
},
|
},
|
||||||
@ -24,7 +24,7 @@ index 2ddd7164..03cab460 100644
|
|||||||
"additionalProperties": False,
|
"additionalProperties": False,
|
||||||
}),
|
}),
|
||||||
]
|
]
|
||||||
@@ -1019,6 +1019,7 @@ def make_schema():
|
@@ -1030,6 +1030,7 @@ def make_schema():
|
||||||
"template_repo": {"type": "string"},
|
"template_repo": {"type": "string"},
|
||||||
"template_branch": {"type": "string"},
|
"template_branch": {"type": "string"},
|
||||||
},
|
},
|
||||||
@ -33,7 +33,7 @@ index 2ddd7164..03cab460 100644
|
|||||||
}),
|
}),
|
||||||
|
|
||||||
diff --git a/pungi/phases/ostree_installer.py b/pungi/phases/ostree_installer.py
|
diff --git a/pungi/phases/ostree_installer.py b/pungi/phases/ostree_installer.py
|
||||||
index 2eac49f7..abcb1572 100644
|
index 587ff2c5..861d9db1 100644
|
||||||
--- a/pungi/phases/ostree_installer.py
|
--- a/pungi/phases/ostree_installer.py
|
||||||
+++ b/pungi/phases/ostree_installer.py
|
+++ b/pungi/phases/ostree_installer.py
|
||||||
@@ -9,7 +9,7 @@ from kobo import shortcuts
|
@@ -9,7 +9,7 @@ from kobo import shortcuts
|
||||||
@ -45,27 +45,34 @@ index 2eac49f7..abcb1572 100644
|
|||||||
from ..wrappers import kojiwrapper, iso, lorax, scm
|
from ..wrappers import kojiwrapper, iso, lorax, scm
|
||||||
|
|
||||||
|
|
||||||
@@ -62,14 +62,7 @@ class OstreeInstallerThread(WorkerThread):
|
@@ -62,21 +62,7 @@ class OstreeInstallerThread(WorkerThread):
|
||||||
self.pool.log_info('[BEGIN] %s' % msg)
|
self.pool.log_info('[BEGIN] %s' % msg)
|
||||||
self.logdir = compose.paths.log.topdir('%s/%s/ostree_installer-%s' % (arch, variant, self.num))
|
self.logdir = compose.paths.log.topdir('%s/%s/ostree_installer-%s' % (arch, variant, self.num))
|
||||||
|
|
||||||
- repo_baseurl = compose.paths.work.arch_repo('$basearch', create_dir=False)
|
- repo_baseurl = compose.paths.work.arch_repo('$basearch', create_dir=False)
|
||||||
- comps_baseurl = compose.paths.work.comps_repo('$basearch', variant=variant, create_dir=False)
|
|
||||||
- repos = get_repo_urls(None, # compose==None. Special value says that method should ignore deprecated variant-type repo
|
- repos = get_repo_urls(None, # compose==None. Special value says that method should ignore deprecated variant-type repo
|
||||||
- shortcuts.force_list(config['repo'])
|
- shortcuts.force_list(config['repo'])
|
||||||
- + shortcuts.force_list(translate_path(compose, repo_baseurl))
|
- + shortcuts.force_list(translate_path(compose, repo_baseurl)),
|
||||||
- + shortcuts.force_list(translate_path(compose, comps_baseurl)),
|
|
||||||
- arch=arch,
|
- arch=arch,
|
||||||
- logger=self.pool)
|
- logger=self.pool)
|
||||||
|
- if compose.has_comps:
|
||||||
|
- repos.append(
|
||||||
|
- translate_path(
|
||||||
|
- compose,
|
||||||
|
- compose.paths.work.comps_repo(
|
||||||
|
- '$basearch', variant=variant, create_dir=False
|
||||||
|
- ),
|
||||||
|
- )
|
||||||
|
- )
|
||||||
+ repos = get_repo_urls(compose, shortcuts.force_list(config['repo']), arch=arch)
|
+ repos = get_repo_urls(compose, shortcuts.force_list(config['repo']), arch=arch)
|
||||||
repos = [url.replace('$arch', arch) for url in repos]
|
repos = [url.replace('$arch', arch) for url in repos]
|
||||||
output_dir = os.path.join(compose.paths.work.topdir(arch), variant.uid, 'ostree_installer')
|
output_dir = os.path.join(compose.paths.work.topdir(arch), variant.uid, 'ostree_installer')
|
||||||
util.makedirs(os.path.dirname(output_dir))
|
util.makedirs(os.path.dirname(output_dir))
|
||||||
diff --git a/pungi/util.py b/pungi/util.py
|
diff --git a/pungi/util.py b/pungi/util.py
|
||||||
index ea0f6e48..3150e26c 100644
|
index 78a9c9be..31e763b5 100644
|
||||||
--- a/pungi/util.py
|
--- a/pungi/util.py
|
||||||
+++ b/pungi/util.py
|
+++ b/pungi/util.py
|
||||||
@@ -686,8 +686,6 @@ def get_repo_url(compose, repo, arch='$basearch'):
|
@@ -688,8 +688,6 @@ def get_repo_url(compose, repo, arch='$basearch'):
|
||||||
Convert repo to repo URL.
|
Convert repo to repo URL.
|
||||||
|
|
||||||
@param compose - required for access to variants
|
@param compose - required for access to variants
|
||||||
@ -74,7 +81,7 @@ index ea0f6e48..3150e26c 100644
|
|||||||
@param repo - string or a dict which at least contains 'baseurl' key
|
@param repo - string or a dict which at least contains 'baseurl' key
|
||||||
@param arch - string to be used as arch in repo url
|
@param arch - string to be used as arch in repo url
|
||||||
"""
|
"""
|
||||||
@@ -698,17 +696,14 @@ def get_repo_url(compose, repo, arch='$basearch'):
|
@@ -700,17 +698,14 @@ def get_repo_url(compose, repo, arch='$basearch'):
|
||||||
raise RuntimeError('Baseurl is required in repo dict %s' % str(repo))
|
raise RuntimeError('Baseurl is required in repo dict %s' % str(repo))
|
||||||
if '://' not in repo:
|
if '://' not in repo:
|
||||||
# this is a variant name
|
# this is a variant name
|
||||||
@ -96,7 +103,7 @@ index ea0f6e48..3150e26c 100644
|
|||||||
"""
|
"""
|
||||||
Convert repos to a list of repo URLs.
|
Convert repos to a list of repo URLs.
|
||||||
|
|
||||||
@@ -719,11 +714,7 @@ def get_repo_urls(compose, repos, arch='$basearch', logger=None):
|
@@ -721,11 +716,7 @@ def get_repo_urls(compose, repos, arch='$basearch', logger=None):
|
||||||
urls = []
|
urls = []
|
||||||
for repo in repos:
|
for repo in repos:
|
||||||
repo = get_repo_url(compose, repo, arch=arch)
|
repo = get_repo_url(compose, repo, arch=arch)
|
||||||
@ -109,7 +116,7 @@ index ea0f6e48..3150e26c 100644
|
|||||||
return urls
|
return urls
|
||||||
|
|
||||||
|
|
||||||
@@ -781,7 +772,7 @@ def get_repo_dicts(repos, logger=None):
|
@@ -783,7 +774,7 @@ def get_repo_dicts(repos, logger=None):
|
||||||
repo_dict = get_repo_dict(repo)
|
repo_dict = get_repo_dict(repo)
|
||||||
if repo_dict == {}:
|
if repo_dict == {}:
|
||||||
if logger:
|
if logger:
|
||||||
@ -119,7 +126,7 @@ index ea0f6e48..3150e26c 100644
|
|||||||
repo_dicts.append(repo_dict)
|
repo_dicts.append(repo_dict)
|
||||||
return repo_dicts
|
return repo_dicts
|
||||||
diff --git a/tests/test_ostree_installer_phase.py b/tests/test_ostree_installer_phase.py
|
diff --git a/tests/test_ostree_installer_phase.py b/tests/test_ostree_installer_phase.py
|
||||||
index ee3294e5..f44ca4ef 100644
|
index 7569e348..25227689 100644
|
||||||
--- a/tests/test_ostree_installer_phase.py
|
--- a/tests/test_ostree_installer_phase.py
|
||||||
+++ b/tests/test_ostree_installer_phase.py
|
+++ b/tests/test_ostree_installer_phase.py
|
||||||
@@ -14,7 +14,6 @@ sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
@@ -14,7 +14,6 @@ sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
||||||
@ -130,7 +137,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
|
|
||||||
|
|
||||||
LOG_PATH = 'logs/x86_64/Everything/ostree_installer-1'
|
LOG_PATH = 'logs/x86_64/Everything/ostree_installer-1'
|
||||||
@@ -96,9 +95,6 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -98,9 +97,6 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
'koji_profile': 'koji',
|
'koji_profile': 'koji',
|
||||||
'runroot_tag': 'rrt',
|
'runroot_tag': 'rrt',
|
||||||
'image_volid_formats': ['{release_short}-{variant}-{arch}'],
|
'image_volid_formats': ['{release_short}-{variant}-{arch}'],
|
||||||
@ -140,7 +147,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
})
|
})
|
||||||
|
|
||||||
def assertImageAdded(self, compose, ImageCls, iso):
|
def assertImageAdded(self, compose, ImageCls, iso):
|
||||||
@@ -125,7 +121,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -127,7 +123,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
]
|
]
|
||||||
|
|
||||||
for s in force_list(sources):
|
for s in force_list(sources):
|
||||||
@ -149,7 +156,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
|
|
||||||
lorax_cmd.append('--variant=Everything')
|
lorax_cmd.append('--variant=Everything')
|
||||||
lorax_cmd.append('--nomacboot')
|
lorax_cmd.append('--nomacboot')
|
||||||
@@ -179,7 +175,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -182,7 +178,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
self.compose.supported = False
|
self.compose.supported = False
|
||||||
pool = mock.Mock()
|
pool = mock.Mock()
|
||||||
cfg = {
|
cfg = {
|
||||||
@ -158,7 +165,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
'release': '20160321.n.0',
|
'release': '20160321.n.0',
|
||||||
}
|
}
|
||||||
koji = KojiWrapper.return_value
|
koji = KojiWrapper.return_value
|
||||||
@@ -197,8 +193,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -200,8 +196,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
||||||
|
|
||||||
self.assertRunrootCall(koji,
|
self.assertRunrootCall(koji,
|
||||||
@ -168,7 +175,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
cfg['release'],
|
cfg['release'],
|
||||||
extra=['--logfile=%s/%s/lorax.log' % (self.topdir, LOG_PATH)])
|
extra=['--logfile=%s/%s/lorax.log' % (self.topdir, LOG_PATH)])
|
||||||
self.assertIsoLinked(link, get_file_size, get_mtime, final_iso_path)
|
self.assertIsoLinked(link, get_file_size, get_mtime, final_iso_path)
|
||||||
@@ -233,12 +228,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -236,12 +231,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
|
|
||||||
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
||||||
|
|
||||||
@ -182,7 +189,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
extra=['--logfile=%s/%s/lorax.log' % (self.topdir, LOG_PATH)])
|
extra=['--logfile=%s/%s/lorax.log' % (self.topdir, LOG_PATH)])
|
||||||
self.assertIsoLinked(link, get_file_size, get_mtime, final_iso_path)
|
self.assertIsoLinked(link, get_file_size, get_mtime, final_iso_path)
|
||||||
self.assertImageAdded(self.compose, ImageCls, iso)
|
self.assertImageAdded(self.compose, ImageCls, iso)
|
||||||
@@ -257,7 +247,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -260,7 +250,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
cfg = {
|
cfg = {
|
||||||
'release': '20160321.n.0',
|
'release': '20160321.n.0',
|
||||||
'repo': [
|
'repo': [
|
||||||
@ -191,7 +198,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
'https://example.com/extra-repo1.repo',
|
'https://example.com/extra-repo1.repo',
|
||||||
'https://example.com/extra-repo2.repo',
|
'https://example.com/extra-repo2.repo',
|
||||||
],
|
],
|
||||||
@@ -274,10 +264,9 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -277,10 +267,9 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
||||||
|
|
||||||
sources = [
|
sources = [
|
||||||
@ -204,7 +211,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
]
|
]
|
||||||
|
|
||||||
self.assertRunrootCall(koji, sources, cfg['release'], isfinal=True,
|
self.assertRunrootCall(koji, sources, cfg['release'], isfinal=True,
|
||||||
@@ -296,8 +285,8 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -299,8 +288,8 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
cfg = {
|
cfg = {
|
||||||
'release': '20160321.n.0',
|
'release': '20160321.n.0',
|
||||||
'repo': [
|
'repo': [
|
||||||
@ -215,7 +222,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
'https://example.com/extra-repo1.repo',
|
'https://example.com/extra-repo1.repo',
|
||||||
'https://example.com/extra-repo2.repo',
|
'https://example.com/extra-repo2.repo',
|
||||||
],
|
],
|
||||||
@@ -314,10 +303,10 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -317,10 +306,10 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
||||||
|
|
||||||
sources = [
|
sources = [
|
||||||
@ -229,7 +236,18 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
]
|
]
|
||||||
|
|
||||||
self.assertRunrootCall(koji, sources, cfg['release'], isfinal=True,
|
self.assertRunrootCall(koji, sources, cfg['release'], isfinal=True,
|
||||||
@@ -368,7 +357,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -353,9 +342,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
|
|
||||||
|
t.process((self.compose, self.compose.variants['Everything'], 'x86_64', cfg), 1)
|
||||||
|
|
||||||
|
- sources = [
|
||||||
|
- 'http://example.com/work/$basearch/repo',
|
||||||
|
- ]
|
||||||
|
+ sources = []
|
||||||
|
|
||||||
|
self.assertRunrootCall(koji, sources, cfg['release'], isfinal=True,
|
||||||
|
extra=['--logfile=%s/%s/lorax.log' % (self.topdir, LOG_PATH)])
|
||||||
|
@@ -405,7 +392,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
get_dir_from_scm):
|
get_dir_from_scm):
|
||||||
pool = mock.Mock()
|
pool = mock.Mock()
|
||||||
cfg = {
|
cfg = {
|
||||||
@ -238,7 +256,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
'release': '20160321.n.0',
|
'release': '20160321.n.0',
|
||||||
'add_template': ['some_file.txt'],
|
'add_template': ['some_file.txt'],
|
||||||
'add_arch_template': ['other_file.txt'],
|
'add_arch_template': ['other_file.txt'],
|
||||||
@@ -395,8 +384,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -432,8 +419,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
'branch': 'f24', 'dir': '.'},
|
'branch': 'f24', 'dir': '.'},
|
||||||
templ_dir, logger=pool._logger)])
|
templ_dir, logger=pool._logger)])
|
||||||
self.assertRunrootCall(koji,
|
self.assertRunrootCall(koji,
|
||||||
@ -248,7 +266,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
cfg['release'],
|
cfg['release'],
|
||||||
isfinal=True,
|
isfinal=True,
|
||||||
extra=['--add-template=%s/some_file.txt' % templ_dir,
|
extra=['--add-template=%s/some_file.txt' % templ_dir,
|
||||||
@@ -417,7 +405,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -454,7 +440,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
get_file_size, get_mtime, ImageCls, copy_all):
|
get_file_size, get_mtime, ImageCls, copy_all):
|
||||||
pool = mock.Mock()
|
pool = mock.Mock()
|
||||||
cfg = {
|
cfg = {
|
||||||
@ -257,7 +275,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
'release': '!RELEASE_FROM_LABEL_DATE_TYPE_RESPIN',
|
'release': '!RELEASE_FROM_LABEL_DATE_TYPE_RESPIN',
|
||||||
"installpkgs": ["fedora-productimg-atomic"],
|
"installpkgs": ["fedora-productimg-atomic"],
|
||||||
"add_template": ["/spin-kickstarts/atomic-installer/lorax-configure-repo.tmpl"],
|
"add_template": ["/spin-kickstarts/atomic-installer/lorax-configure-repo.tmpl"],
|
||||||
@@ -449,8 +437,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -486,8 +472,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
|
|
||||||
self.assertRunrootCall(
|
self.assertRunrootCall(
|
||||||
koji,
|
koji,
|
||||||
@ -267,7 +285,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
'20151203.t.0',
|
'20151203.t.0',
|
||||||
isfinal=True,
|
isfinal=True,
|
||||||
extra=['--installpkgs=fedora-productimg-atomic',
|
extra=['--installpkgs=fedora-productimg-atomic',
|
||||||
@@ -479,7 +466,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -516,7 +501,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
get_file_size, get_mtime, ImageCls, copy_all):
|
get_file_size, get_mtime, ImageCls, copy_all):
|
||||||
pool = mock.Mock()
|
pool = mock.Mock()
|
||||||
cfg = {
|
cfg = {
|
||||||
@ -276,7 +294,7 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
'release': None,
|
'release': None,
|
||||||
"installpkgs": ["fedora-productimg-atomic"],
|
"installpkgs": ["fedora-productimg-atomic"],
|
||||||
"add_template": ["/spin-kickstarts/atomic-installer/lorax-configure-repo.tmpl"],
|
"add_template": ["/spin-kickstarts/atomic-installer/lorax-configure-repo.tmpl"],
|
||||||
@@ -511,8 +498,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
@@ -548,8 +533,7 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
||||||
|
|
||||||
self.assertRunrootCall(
|
self.assertRunrootCall(
|
||||||
koji,
|
koji,
|
||||||
@ -287,5 +305,5 @@ index ee3294e5..f44ca4ef 100644
|
|||||||
isfinal=True,
|
isfinal=True,
|
||||||
extra=['--installpkgs=fedora-productimg-atomic',
|
extra=['--installpkgs=fedora-productimg-atomic',
|
||||||
--
|
--
|
||||||
2.14.3
|
2.14.4
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
From 836750b9c53aa4c6330b986e7fb28f92d940df55 Mon Sep 17 00:00:00 2001
|
From 079177c5bf498fe21c1f0b03d127bfa25fa09fe0 Mon Sep 17 00:00:00 2001
|
||||||
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
||||||
Date: Wed, 11 Apr 2018 09:20:51 +0200
|
Date: Wed, 11 Apr 2018 09:20:51 +0200
|
||||||
Subject: [PATCH 3/6] Revert "Ostree can use pkgset repos"
|
Subject: [PATCH 3/3] Revert "Ostree can use pkgset repos"
|
||||||
|
|
||||||
This reverts commit c7cc200246300c6a3946b2e3a9f5f7693896a7d6.
|
This reverts commit c7cc200246300c6a3946b2e3a9f5f7693896a7d6.
|
||||||
---
|
---
|
||||||
@ -31,10 +31,10 @@ index 2918fff8..0550b18c 100644
|
|||||||
# copy the original config and update before save to a json file
|
# copy the original config and update before save to a json file
|
||||||
new_config = copy.copy(config)
|
new_config = copy.copy(config)
|
||||||
diff --git a/pungi/util.py b/pungi/util.py
|
diff --git a/pungi/util.py b/pungi/util.py
|
||||||
index 3150e26c..7cfbb4e6 100644
|
index 31e763b5..9f0aab69 100644
|
||||||
--- a/pungi/util.py
|
--- a/pungi/util.py
|
||||||
+++ b/pungi/util.py
|
+++ b/pungi/util.py
|
||||||
@@ -726,16 +726,19 @@ def _translate_url_to_repo_id(url):
|
@@ -728,16 +728,19 @@ def _translate_url_to_repo_id(url):
|
||||||
return ''.join([s if s in list(_REPOID_CHARS) else '_' for s in url])
|
return ''.join([s if s in list(_REPOID_CHARS) else '_' for s in url])
|
||||||
|
|
||||||
|
|
||||||
@ -59,7 +59,7 @@ index 3150e26c..7cfbb4e6 100644
|
|||||||
"""
|
"""
|
||||||
repo_dict = {}
|
repo_dict = {}
|
||||||
if isinstance(repo, dict):
|
if isinstance(repo, dict):
|
||||||
@@ -745,8 +748,10 @@ def get_repo_dict(repo):
|
@@ -747,8 +750,10 @@ def get_repo_dict(repo):
|
||||||
if name is None:
|
if name is None:
|
||||||
name = _translate_url_to_repo_id(url)
|
name = _translate_url_to_repo_id(url)
|
||||||
else:
|
else:
|
||||||
@ -72,7 +72,7 @@ index 3150e26c..7cfbb4e6 100644
|
|||||||
repo['name'] = name
|
repo['name'] = name
|
||||||
repo['baseurl'] = url
|
repo['baseurl'] = url
|
||||||
return repo
|
return repo
|
||||||
@@ -757,24 +762,24 @@ def get_repo_dict(repo):
|
@@ -759,24 +764,24 @@ def get_repo_dict(repo):
|
||||||
repo_dict['name'] = _translate_url_to_repo_id(repo)
|
repo_dict['name'] = _translate_url_to_repo_id(repo)
|
||||||
repo_dict['baseurl'] = repo
|
repo_dict['baseurl'] = repo
|
||||||
else:
|
else:
|
||||||
@ -226,10 +226,10 @@ index ad14eca4..3a9ebf32 100644
|
|||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
diff --git a/tests/test_util.py b/tests/test_util.py
|
diff --git a/tests/test_util.py b/tests/test_util.py
|
||||||
index 1f22b63e..322301ff 100644
|
index 739ea9e1..ab4f3459 100644
|
||||||
--- a/tests/test_util.py
|
--- a/tests/test_util.py
|
||||||
+++ b/tests/test_util.py
|
+++ b/tests/test_util.py
|
||||||
@@ -588,35 +588,43 @@ class GetRepoFuncsTestCase(unittest.TestCase):
|
@@ -587,35 +587,43 @@ class GetRepoFuncsTestCase(unittest.TestCase):
|
||||||
self.assertEqual(util.get_repo_urls(self.compose, repos), expect)
|
self.assertEqual(util.get_repo_urls(self.compose, repos), expect)
|
||||||
|
|
||||||
def test_get_repo_dict_from_normal_url(self):
|
def test_get_repo_dict_from_normal_url(self):
|
||||||
@ -283,5 +283,5 @@ index 1f22b63e..322301ff 100644
|
|||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
2.14.3
|
2.14.4
|
||||||
|
|
||||||
|
@ -1,107 +0,0 @@
|
|||||||
From c8e03cfba196719e80c953c3d197653ef84716ed Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
|
||||||
Date: Tue, 29 May 2018 08:38:09 +0200
|
|
||||||
Subject: [PATCH 4/6] kojiwrapper: Make result of runroot world readable
|
|
||||||
MIME-Version: 1.0
|
|
||||||
Content-Type: text/plain; charset=UTF-8
|
|
||||||
Content-Transfer-Encoding: 8bit
|
|
||||||
|
|
||||||
The commands in runroot run as root every time. If they create files
|
|
||||||
that are not readable to other users, the reset of compose could have
|
|
||||||
problems with it if it does not run as root too. Particularly updates
|
|
||||||
composes in Bodhi run under apache user.
|
|
||||||
|
|
||||||
Relates: https://pagure.io/pungi/issue/932
|
|
||||||
Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
|
|
||||||
---
|
|
||||||
pungi/phases/ostree_installer.py | 3 ++-
|
|
||||||
pungi/wrappers/kojiwrapper.py | 7 ++++++-
|
|
||||||
tests/test_koji_wrapper.py | 18 ++++++++++++++++++
|
|
||||||
tests/test_ostree_installer_phase.py | 3 ++-
|
|
||||||
4 files changed, 28 insertions(+), 3 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/pungi/phases/ostree_installer.py b/pungi/phases/ostree_installer.py
|
|
||||||
index abcb1572..572edbbb 100644
|
|
||||||
--- a/pungi/phases/ostree_installer.py
|
|
||||||
+++ b/pungi/phases/ostree_installer.py
|
|
||||||
@@ -174,7 +174,8 @@ class OstreeInstallerThread(WorkerThread):
|
|
||||||
channel=runroot_channel,
|
|
||||||
use_shell=True, task_id=True,
|
|
||||||
packages=packages, mounts=[compose.topdir],
|
|
||||||
- weight=compose.conf['runroot_weights'].get('ostree_installer'))
|
|
||||||
+ weight=compose.conf['runroot_weights'].get('ostree_installer'),
|
|
||||||
+ destdir=output_dir)
|
|
||||||
output = koji.run_runroot_cmd(koji_cmd, log_file=log_file)
|
|
||||||
if output["retcode"] != 0:
|
|
||||||
raise RuntimeError("Runroot task failed: %s. See %s for more details."
|
|
||||||
diff --git a/pungi/wrappers/kojiwrapper.py b/pungi/wrappers/kojiwrapper.py
|
|
||||||
index f89640ca..b8d56791 100644
|
|
||||||
--- a/pungi/wrappers/kojiwrapper.py
|
|
||||||
+++ b/pungi/wrappers/kojiwrapper.py
|
|
||||||
@@ -66,7 +66,9 @@ class KojiWrapper(object):
|
|
||||||
def _get_cmd(self, *args):
|
|
||||||
return ["koji", "--profile=%s" % self.profile] + list(args)
|
|
||||||
|
|
||||||
- def get_runroot_cmd(self, target, arch, command, quiet=False, use_shell=True, channel=None, packages=None, mounts=None, weight=None, task_id=True, new_chroot=False):
|
|
||||||
+ def get_runroot_cmd(self, target, arch, command, quiet=False, use_shell=True,
|
|
||||||
+ channel=None, packages=None, mounts=None, weight=None,
|
|
||||||
+ task_id=True, new_chroot=False, destdir=None):
|
|
||||||
cmd = self._get_cmd("runroot")
|
|
||||||
|
|
||||||
if quiet:
|
|
||||||
@@ -109,6 +111,9 @@ class KojiWrapper(object):
|
|
||||||
|
|
||||||
# HACK: remove rpmdb and yum cache
|
|
||||||
command = "rm -f /var/lib/rpm/__db*; rm -rf /var/cache/yum/*; set -x; " + command
|
|
||||||
+
|
|
||||||
+ if destdir:
|
|
||||||
+ command += "; chmod a+r %s" % shlex_quote(destdir)
|
|
||||||
cmd.append(command)
|
|
||||||
|
|
||||||
return cmd
|
|
||||||
diff --git a/tests/test_koji_wrapper.py b/tests/test_koji_wrapper.py
|
|
||||||
index 7bf13773..4a14aed6 100644
|
|
||||||
--- a/tests/test_koji_wrapper.py
|
|
||||||
+++ b/tests/test_koji_wrapper.py
|
|
||||||
@@ -416,6 +416,24 @@ class RunrootKojiWrapperTest(KojiWrapperBaseTestCase):
|
|
||||||
'--task-id', '--weight=1000', '--package=some_other_package',
|
|
||||||
'--package=lorax', '--mount=/tmp'])
|
|
||||||
|
|
||||||
+ def test_with_destdir(self):
|
|
||||||
+ cmd = self.koji.get_runroot_cmd('tgt', 's390x', ['/bin/echo', '&'],
|
|
||||||
+ quiet=True, channel='chan',
|
|
||||||
+ packages=['lorax', 'some_other_package'],
|
|
||||||
+ mounts=['/tmp'], weight=1000, destdir="/output dir")
|
|
||||||
+ self.assertEqual(len(cmd), 14)
|
|
||||||
+ self.assertEqual(cmd[:3], ['koji', '--profile=custom-koji', 'runroot'])
|
|
||||||
+ self.assertEqual(cmd[-3], 'tgt')
|
|
||||||
+ self.assertEqual(cmd[-2], 's390x')
|
|
||||||
+ self.assertEqual(
|
|
||||||
+ cmd[-1],
|
|
||||||
+ "rm -f /var/lib/rpm/__db*; rm -rf /var/cache/yum/*; set -x; /bin/echo '&'; chmod a+r '/output dir'"
|
|
||||||
+ )
|
|
||||||
+ self.assertItemsEqual(cmd[3:-3],
|
|
||||||
+ ['--channel-override=chan', '--quiet', '--use-shell',
|
|
||||||
+ '--task-id', '--weight=1000', '--package=some_other_package',
|
|
||||||
+ '--package=lorax', '--mount=/tmp'])
|
|
||||||
+
|
|
||||||
@mock.patch('pungi.wrappers.kojiwrapper.run')
|
|
||||||
def test_run_runroot_cmd_no_task_id(self, run):
|
|
||||||
cmd = ['koji', 'runroot']
|
|
||||||
diff --git a/tests/test_ostree_installer_phase.py b/tests/test_ostree_installer_phase.py
|
|
||||||
index f44ca4ef..859b18da 100644
|
|
||||||
--- a/tests/test_ostree_installer_phase.py
|
|
||||||
+++ b/tests/test_ostree_installer_phase.py
|
|
||||||
@@ -142,7 +142,8 @@ class OstreeThreadTest(helpers.PungiTestCase):
|
|
||||||
'rm -rf %s && %s' % (outdir, ' '.join(lorax_cmd)),
|
|
||||||
channel=None, mounts=[self.topdir],
|
|
||||||
packages=['pungi', 'lorax', 'ostree'],
|
|
||||||
- task_id=True, use_shell=True, weight=weight)])
|
|
||||||
+ task_id=True, use_shell=True, weight=weight,
|
|
||||||
+ destdir=outdir)])
|
|
||||||
self.assertEqual(koji.run_runroot_cmd.call_args_list,
|
|
||||||
[mock.call(koji.get_runroot_cmd.return_value,
|
|
||||||
log_file='%s/%s/runroot.log' % (self.topdir, LOG_PATH))])
|
|
||||||
--
|
|
||||||
2.14.3
|
|
||||||
|
|
@ -1,43 +0,0 @@
|
|||||||
From 80cb233b2225abd8fcb687aa61a522e6e8280617 Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
|
||||||
Date: Thu, 31 May 2018 14:50:03 +0200
|
|
||||||
Subject: [PATCH 5/6] kojiwrapper: Don't mark runroot as successful by chmod
|
|
||||||
MIME-Version: 1.0
|
|
||||||
Content-Type: text/plain; charset=UTF-8
|
|
||||||
Content-Transfer-Encoding: 8bit
|
|
||||||
|
|
||||||
Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
|
|
||||||
---
|
|
||||||
pungi/wrappers/kojiwrapper.py | 2 +-
|
|
||||||
tests/test_koji_wrapper.py | 2 +-
|
|
||||||
2 files changed, 2 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/pungi/wrappers/kojiwrapper.py b/pungi/wrappers/kojiwrapper.py
|
|
||||||
index b8d56791..bcfb5303 100644
|
|
||||||
--- a/pungi/wrappers/kojiwrapper.py
|
|
||||||
+++ b/pungi/wrappers/kojiwrapper.py
|
|
||||||
@@ -113,7 +113,7 @@ class KojiWrapper(object):
|
|
||||||
command = "rm -f /var/lib/rpm/__db*; rm -rf /var/cache/yum/*; set -x; " + command
|
|
||||||
|
|
||||||
if destdir:
|
|
||||||
- command += "; chmod a+r %s" % shlex_quote(destdir)
|
|
||||||
+ command += " && chmod a+r %s" % shlex_quote(destdir)
|
|
||||||
cmd.append(command)
|
|
||||||
|
|
||||||
return cmd
|
|
||||||
diff --git a/tests/test_koji_wrapper.py b/tests/test_koji_wrapper.py
|
|
||||||
index 4a14aed6..30037b27 100644
|
|
||||||
--- a/tests/test_koji_wrapper.py
|
|
||||||
+++ b/tests/test_koji_wrapper.py
|
|
||||||
@@ -427,7 +427,7 @@ class RunrootKojiWrapperTest(KojiWrapperBaseTestCase):
|
|
||||||
self.assertEqual(cmd[-2], 's390x')
|
|
||||||
self.assertEqual(
|
|
||||||
cmd[-1],
|
|
||||||
- "rm -f /var/lib/rpm/__db*; rm -rf /var/cache/yum/*; set -x; /bin/echo '&'; chmod a+r '/output dir'"
|
|
||||||
+ "rm -f /var/lib/rpm/__db*; rm -rf /var/cache/yum/*; set -x; /bin/echo '&' && chmod a+r '/output dir'"
|
|
||||||
)
|
|
||||||
self.assertItemsEqual(cmd[3:-3],
|
|
||||||
['--channel-override=chan', '--quiet', '--use-shell',
|
|
||||||
--
|
|
||||||
2.14.3
|
|
||||||
|
|
@ -1,44 +0,0 @@
|
|||||||
From 210037ad48aa7f91d0391dc7c9330d4fd5c7172e Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com>
|
|
||||||
Date: Mon, 4 Jun 2018 08:31:08 +0200
|
|
||||||
Subject: [PATCH 6/6] kojiwrapper: Call chmod recursively
|
|
||||||
MIME-Version: 1.0
|
|
||||||
Content-Type: text/plain; charset=UTF-8
|
|
||||||
Content-Transfer-Encoding: 8bit
|
|
||||||
|
|
||||||
Related: https://pagure.io/pungi/issue/932
|
|
||||||
Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
|
|
||||||
---
|
|
||||||
pungi/wrappers/kojiwrapper.py | 2 +-
|
|
||||||
tests/test_koji_wrapper.py | 2 +-
|
|
||||||
2 files changed, 2 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/pungi/wrappers/kojiwrapper.py b/pungi/wrappers/kojiwrapper.py
|
|
||||||
index bcfb5303..abcdecb9 100644
|
|
||||||
--- a/pungi/wrappers/kojiwrapper.py
|
|
||||||
+++ b/pungi/wrappers/kojiwrapper.py
|
|
||||||
@@ -113,7 +113,7 @@ class KojiWrapper(object):
|
|
||||||
command = "rm -f /var/lib/rpm/__db*; rm -rf /var/cache/yum/*; set -x; " + command
|
|
||||||
|
|
||||||
if destdir:
|
|
||||||
- command += " && chmod a+r %s" % shlex_quote(destdir)
|
|
||||||
+ command += " && chmod -R a+r %s" % shlex_quote(destdir)
|
|
||||||
cmd.append(command)
|
|
||||||
|
|
||||||
return cmd
|
|
||||||
diff --git a/tests/test_koji_wrapper.py b/tests/test_koji_wrapper.py
|
|
||||||
index 30037b27..0f20562a 100644
|
|
||||||
--- a/tests/test_koji_wrapper.py
|
|
||||||
+++ b/tests/test_koji_wrapper.py
|
|
||||||
@@ -427,7 +427,7 @@ class RunrootKojiWrapperTest(KojiWrapperBaseTestCase):
|
|
||||||
self.assertEqual(cmd[-2], 's390x')
|
|
||||||
self.assertEqual(
|
|
||||||
cmd[-1],
|
|
||||||
- "rm -f /var/lib/rpm/__db*; rm -rf /var/cache/yum/*; set -x; /bin/echo '&' && chmod a+r '/output dir'"
|
|
||||||
+ "rm -f /var/lib/rpm/__db*; rm -rf /var/cache/yum/*; set -x; /bin/echo '&' && chmod -R a+r '/output dir'"
|
|
||||||
)
|
|
||||||
self.assertItemsEqual(cmd[3:-3],
|
|
||||||
['--channel-override=chan', '--quiet', '--use-shell',
|
|
||||||
--
|
|
||||||
2.14.3
|
|
||||||
|
|
42
pungi.spec
42
pungi.spec
@ -1,6 +1,6 @@
|
|||||||
Name: pungi
|
Name: pungi
|
||||||
Version: 4.1.25
|
Version: 4.1.26
|
||||||
Release: 7%{?dist}
|
Release: 1%{?dist}
|
||||||
Summary: Distribution compose tool
|
Summary: Distribution compose tool
|
||||||
|
|
||||||
Group: Development/Tools
|
Group: Development/Tools
|
||||||
@ -10,10 +10,7 @@ Source0: https://pagure.io/releases/%{name}/%{name}-%{version}.tar.bz2
|
|||||||
Patch0: 0001-Revert-Move-ostree-phase-and-pipelines-for-running-p.patch
|
Patch0: 0001-Revert-Move-ostree-phase-and-pipelines-for-running-p.patch
|
||||||
Patch1: 0002-Revert-Other-repo-for-OstreeInstaller.patch
|
Patch1: 0002-Revert-Other-repo-for-OstreeInstaller.patch
|
||||||
Patch2: 0003-Revert-Ostree-can-use-pkgset-repos.patch
|
Patch2: 0003-Revert-Ostree-can-use-pkgset-repos.patch
|
||||||
Patch3: 0004-kojiwrapper-Make-result-of-runroot-world-readable.patch
|
Patch3: 0001-Fix-tests-for-DNF-3.patch
|
||||||
Patch4: 0005-kojiwrapper-Don-t-mark-runroot-as-successful-by-chmo.patch
|
|
||||||
Patch5: 0006-kojiwrapper-Call-chmod-recursively.patch
|
|
||||||
Patch6: 0001-Skip-tests-involving-lookaside-with-new-DNF.patch
|
|
||||||
|
|
||||||
BuildRequires: python3-nose
|
BuildRequires: python3-nose
|
||||||
BuildRequires: python3-mock
|
BuildRequires: python3-mock
|
||||||
@ -41,6 +38,7 @@ BuildRequires: python3-PyYAML
|
|||||||
BuildRequires: libmodulemd >= 1.3.0
|
BuildRequires: libmodulemd >= 1.3.0
|
||||||
BuildRequires: python3-gobject
|
BuildRequires: python3-gobject
|
||||||
BuildRequires: python3-pdc-client
|
BuildRequires: python3-pdc-client
|
||||||
|
BuildRequires: python3-createrepo_c
|
||||||
|
|
||||||
#deps for doc building
|
#deps for doc building
|
||||||
BuildRequires: python3-sphinx, texlive-collection-fontsrecommended
|
BuildRequires: python3-sphinx, texlive-collection-fontsrecommended
|
||||||
@ -75,6 +73,7 @@ Requires: python3-koji
|
|||||||
Requires: libmodulemd >= 1.3.0
|
Requires: libmodulemd >= 1.3.0
|
||||||
Requires: python3-gobject
|
Requires: python3-gobject
|
||||||
Requires: python3-pdc-client
|
Requires: python3-pdc-client
|
||||||
|
Requires: python3-createrepo_c
|
||||||
|
|
||||||
Requires: python3-%{name} = %{version}-%{release}
|
Requires: python3-%{name} = %{version}-%{release}
|
||||||
|
|
||||||
@ -181,6 +180,37 @@ nosetests-3 --exe
|
|||||||
%{_bindir}/%{name}-wait-for-signed-ostree-handler
|
%{_bindir}/%{name}-wait-for-signed-ostree-handler
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Jul 16 2018 Lubomír Sedlář <lsedlar@redhat.com> - 4.1.26-1
|
||||||
|
- gather: Add a hybrid depsolver backend (lsedlar)
|
||||||
|
- Always use lookasides for repoclosure (lsedlar)
|
||||||
|
- doc: closing parentheses for require_all_comps_packages (kdreyer)
|
||||||
|
- osbs: Generate unique repo names (lsedlar)
|
||||||
|
- Expand version field during image_build using version_generator (sinny)
|
||||||
|
- createrepo: Stop including modulemd in debug repos (lsedlar)
|
||||||
|
- Simplify iterating over module defaults (lsedlar)
|
||||||
|
- pkgset: Apply module filters on pkgset level (lsedlar)
|
||||||
|
- init: Validate whitespace in comps groups (lsedlar)
|
||||||
|
- createrepo: Include empty modules (lsedlar)
|
||||||
|
- createiso: Break hardlinks by copying files (lsedlar)
|
||||||
|
- pkgset: Query Koji instead of PDC (mcurlej)
|
||||||
|
- config: Report variants validity issues (lsedlar)
|
||||||
|
- variants: Reject values with whitespace (lsedlar)
|
||||||
|
- osbs: Fresh koji session for getting metadata (lsedlar)
|
||||||
|
- gather: Ignore comps in lookaside repo (lsedlar)
|
||||||
|
- init: Test that init phase correctly clones defaults (lsedlar)
|
||||||
|
- init: Add tests for cloning module defaults (lsedlar)
|
||||||
|
- init: Add validation for module defaults (lsedlar)
|
||||||
|
- ostree-installer: Skip comps repo if there are no comps (lsedlar)
|
||||||
|
- Add test for getting licenses from a repo (lsedlar)
|
||||||
|
- Add content_licenses to module metadata (sgallagh)
|
||||||
|
- Update virtualenv instructions (lsedlar)
|
||||||
|
- Allow extracting koji event from another compose (lsedlar)
|
||||||
|
- Copy modules instead of reparsing them (sgallagh)
|
||||||
|
- Silence config warnings in quiet mode (lsedlar)
|
||||||
|
- osbs: Add nvr to metadata (lsedlar)
|
||||||
|
- Always get old compose with release type suffix (patrick)
|
||||||
|
- Make ostree_installer check if buildinstall is skipped correctly (puiterwijk)
|
||||||
|
|
||||||
* Fri Jul 13 2018 Fedora Release Engineering <releng@fedoraproject.org> - 4.1.25-7
|
* Fri Jul 13 2018 Fedora Release Engineering <releng@fedoraproject.org> - 4.1.25-7
|
||||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
|
||||||
|
|
||||||
|
2
sources
2
sources
@ -1 +1 @@
|
|||||||
SHA512 (pungi-4.1.25.tar.bz2) = 6f58f6693619345fd517cab9ad833f961a544772d9f16ed75cf37d3c9b3905ea9c7c372c1906c1900bd18311a0ed0c182100e2017716db65f80595b51914ba96
|
SHA512 (pungi-4.1.26.tar.bz2) = 8b6aef74ea27b6e64f8d64297f0f6014dd7280f74754cf955f3e9680122e987ca0dedde5c96eeccb105958ced40133d62d9e52aa19097f33067ada9275d8dcd4
|
||||||
|
Loading…
Reference in New Issue
Block a user