Merge branch 'master' into epel7
This commit is contained in:
		
						commit
						0aacdc8822
					
				
							
								
								
									
										28
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										28
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -1,27 +1 @@ | |||||||
| pungi-2.1.2.tar.bz2 | /pungi-*.tar.bz2 | ||||||
| /pungi-2.1.3.tar.bz2 |  | ||||||
| /pungi-2.1.4.tar.bz2 |  | ||||||
| /pungi-2.3.tar.bz2 |  | ||||||
| /pungi-2.4.tar.bz2 |  | ||||||
| /pungi-2.5.tar.bz2 |  | ||||||
| /pungi-2.6.tar.bz2 |  | ||||||
| /pungi-2.8.tar.bz2 |  | ||||||
| /pungi-2.9.tar.bz2 |  | ||||||
| /pungi-2.10.tar.bz2 |  | ||||||
| /pungi-2.11.tar.bz2 |  | ||||||
| /pungi-2.12.tar.bz2 |  | ||||||
| /pungi-2.13.tar.bz2 |  | ||||||
| /pungi-3.00.tar.bz2 |  | ||||||
| /pungi-3.01.tar.bz2 |  | ||||||
| /pungi-3.02.tar.bz2 |  | ||||||
| /pungi-3.03.tar.bz2 |  | ||||||
| /pungi-3.04.tar.bz2 |  | ||||||
| /pungi-3.05.tar.bz2 |  | ||||||
| /pungi-3.06.tar.bz2 |  | ||||||
| /pungi-3.07.tar.bz2 |  | ||||||
| /pungi-3.08.tar.bz2 |  | ||||||
| /pungi-3.09.tar.bz2 |  | ||||||
| /pungi-3.10.tar.bz2 |  | ||||||
| /pungi-3.11.tar.bz2 |  | ||||||
| /pungi-3.12.tar.bz2 |  | ||||||
| /pungi-3.13.tar.bz2 |  | ||||||
|  | |||||||
							
								
								
									
										104
									
								
								0001-image-build-Expand-arches-for-can_fail.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								0001-image-build-Expand-arches-for-can_fail.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,104 @@ | |||||||
|  | From 6c708549c8f6632884bc55abed2f88afa1abe100 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com> | ||||||
|  | Date: Mon, 23 Jan 2017 16:52:57 +0100 | ||||||
|  | Subject: [PATCH 1/2] image-build: Expand arches for can_fail | ||||||
|  | MIME-Version: 1.0 | ||||||
|  | Content-Type: text/plain; charset=UTF-8 | ||||||
|  | Content-Transfer-Encoding: 8bit | ||||||
|  | 
 | ||||||
|  | We need to work with a list of strings, not a comma-delimited single | ||||||
|  | string. | ||||||
|  | 
 | ||||||
|  | Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com> | ||||||
|  | ---
 | ||||||
|  |  pungi/phases/image_build.py   |  2 +- | ||||||
|  |  tests/test_imagebuildphase.py | 60 +++++++++++++++++++++++++++++++++++++++++++ | ||||||
|  |  2 files changed, 61 insertions(+), 1 deletion(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/pungi/phases/image_build.py b/pungi/phases/image_build.py
 | ||||||
|  | index 5cfdbb0..b795125 100644
 | ||||||
|  | --- a/pungi/phases/image_build.py
 | ||||||
|  | +++ b/pungi/phases/image_build.py
 | ||||||
|  | @@ -122,7 +122,7 @@ class ImageBuildPhase(base.PhaseLoggerMixin, base.ImageConfigMixin, base.ConfigG
 | ||||||
|  |   | ||||||
|  |                  can_fail = image_conf['image-build'].pop('failable', []) | ||||||
|  |                  if can_fail == ['*']: | ||||||
|  | -                    can_fail = image_conf['image-build']['arches']
 | ||||||
|  | +                    can_fail = image_conf['image-build']['arches'].split(',')
 | ||||||
|  |                  if can_fail: | ||||||
|  |                      image_conf['image-build']['can_fail'] = ','.join(sorted(can_fail)) | ||||||
|  |   | ||||||
|  | diff --git a/tests/test_imagebuildphase.py b/tests/test_imagebuildphase.py
 | ||||||
|  | index 86012ac..328b2b3 100644
 | ||||||
|  | --- a/tests/test_imagebuildphase.py
 | ||||||
|  | +++ b/tests/test_imagebuildphase.py
 | ||||||
|  | @@ -619,6 +619,66 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |          self.assertItemsEqual(phase.pool.queue_put.mock_calls, | ||||||
|  |                                [mock.call((compose, server_args))]) | ||||||
|  |   | ||||||
|  | +    @mock.patch('pungi.phases.image_build.ThreadPool')
 | ||||||
|  | +    def test_failable_star(self, ThreadPool):
 | ||||||
|  | +        compose = DummyCompose(self.topdir, {
 | ||||||
|  | +            'image_build': {
 | ||||||
|  | +                '^Server$': [
 | ||||||
|  | +                    {
 | ||||||
|  | +                        'image-build': {
 | ||||||
|  | +                            'format': [('docker', 'tar.xz')],
 | ||||||
|  | +                            'name': 'Fedora-Docker-Base',
 | ||||||
|  | +                            'target': 'f24',
 | ||||||
|  | +                            'version': 'Rawhide',
 | ||||||
|  | +                            'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git',
 | ||||||
|  | +                            'kickstart': "fedora-docker-base.ks",
 | ||||||
|  | +                            'distro': 'Fedora-20',
 | ||||||
|  | +                            'disk_size': 3,
 | ||||||
|  | +                            'failable': ['*'],
 | ||||||
|  | +                        }
 | ||||||
|  | +                    }
 | ||||||
|  | +                ]
 | ||||||
|  | +            },
 | ||||||
|  | +            'koji_profile': 'koji',
 | ||||||
|  | +        })
 | ||||||
|  | +        compose.setup_optional()
 | ||||||
|  | +
 | ||||||
|  | +        self.assertValidConfig(compose.conf)
 | ||||||
|  | +
 | ||||||
|  | +        phase = ImageBuildPhase(compose)
 | ||||||
|  | +
 | ||||||
|  | +        phase.run()
 | ||||||
|  | +
 | ||||||
|  | +        # assert at least one thread was started
 | ||||||
|  | +        self.assertTrue(phase.pool.add.called)
 | ||||||
|  | +        server_args = {
 | ||||||
|  | +            "format": [('docker', 'tar.xz')],
 | ||||||
|  | +            "image_conf": {
 | ||||||
|  | +                'image-build': {
 | ||||||
|  | +                    'install_tree': self.topdir + '/compose/Server/$arch/os',
 | ||||||
|  | +                    'kickstart': 'fedora-docker-base.ks',
 | ||||||
|  | +                    'format': 'docker',
 | ||||||
|  | +                    'repo': self.topdir + '/compose/Server/$arch/os',
 | ||||||
|  | +                    'variant': compose.all_variants['Server'],
 | ||||||
|  | +                    'target': 'f24',
 | ||||||
|  | +                    'disk_size': 3,
 | ||||||
|  | +                    'name': 'Fedora-Docker-Base',
 | ||||||
|  | +                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'version': 'Rawhide',
 | ||||||
|  | +                    'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git',
 | ||||||
|  | +                    'distro': 'Fedora-20',
 | ||||||
|  | +                    'can_fail': 'amd64,x86_64',
 | ||||||
|  | +                }
 | ||||||
|  | +            },
 | ||||||
|  | +            "conf_file": self.topdir + '/work/image-build/Server/docker_Fedora-Docker-Base.cfg',
 | ||||||
|  | +            "image_dir": self.topdir + '/compose/Server/%(arch)s/images',
 | ||||||
|  | +            "relative_image_dir": 'Server/%(arch)s/images',
 | ||||||
|  | +            "link_type": 'hardlink-or-copy',
 | ||||||
|  | +            "scratch": False,
 | ||||||
|  | +        }
 | ||||||
|  | +        self.assertItemsEqual(phase.pool.queue_put.mock_calls,
 | ||||||
|  | +                              [mock.call((compose, server_args))])
 | ||||||
|  | +
 | ||||||
|  |   | ||||||
|  |  class TestCreateImageBuildThread(PungiTestCase): | ||||||
|  |   | ||||||
|  | -- 
 | ||||||
|  | 2.11.0 | ||||||
|  | 
 | ||||||
							
								
								
									
										66
									
								
								0001-replace-basearch-when-updating-the-ref.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								0001-replace-basearch-when-updating-the-ref.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,66 @@ | |||||||
|  | From 59dd4dbcd84ce30faa6558ad0d052370077d3fe5 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Dennis Gilmore <dennis@ausil.us> | ||||||
|  | Date: Jan 19 2017 03:21:26 +0000 | ||||||
|  | Subject: replace ${basearch} when updating the ref | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | pungi-make-ostree has to run on the target arch so that rpm | ||||||
|  | scriptlets can be ran. as a reult we can ask rpm what the | ||||||
|  | basearch is for the running environment. For notifications | ||||||
|  | we have to pass in the arch we are running for. | ||||||
|  | 
 | ||||||
|  | Signed-off-by: Dennis Gilmore <dennis@ausil.us> | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  | 
 | ||||||
|  | diff --git a/pungi/ostree/utils.py b/pungi/ostree/utils.py
 | ||||||
|  | index 02540c9..d80fb9f 100644
 | ||||||
|  | --- a/pungi/ostree/utils.py
 | ||||||
|  | +++ b/pungi/ostree/utils.py
 | ||||||
|  | @@ -17,6 +17,7 @@
 | ||||||
|  |  import datetime | ||||||
|  |  import json | ||||||
|  |  import os | ||||||
|  | +import rpmUtils.arch
 | ||||||
|  |   | ||||||
|  |  from pungi.util import makedirs | ||||||
|  |   | ||||||
|  | @@ -29,14 +30,21 @@ def make_log_file(log_dir, filename):
 | ||||||
|  |      return os.path.join(log_dir, '%s.log' % filename) | ||||||
|  |   | ||||||
|  |   | ||||||
|  | -def get_ref_from_treefile(treefile):
 | ||||||
|  | -    """Return ref name by parsing the tree config file"""
 | ||||||
|  | +def get_ref_from_treefile(treefile, arch=None):
 | ||||||
|  | +    """
 | ||||||
|  | +    Return ref name by parsing the tree config file. Replacing ${basearch} with
 | ||||||
|  | +    the basearch of the architecture we are running on or of the passed in arch.
 | ||||||
|  | +    """
 | ||||||
|  |      ref = None | ||||||
|  |      if os.path.isfile(treefile): | ||||||
|  |          with open(treefile, 'r') as f: | ||||||
|  |              try: | ||||||
|  |                  parsed = json.loads(f.read()) | ||||||
|  | -                ref = parsed['ref']
 | ||||||
|  | +                if arch is None:
 | ||||||
|  | +                    basearch = rpmUtils.arch.getBaseArch()
 | ||||||
|  | +                else:
 | ||||||
|  | +                    basearch = rpmUtils.arch.getBaseArch(arch)
 | ||||||
|  | +                ref = parsed['ref'].replace('${basearch}', basearch)
 | ||||||
|  |              except Exception as e: | ||||||
|  |                  print('Unable to get ref from treefile: %s' % e) | ||||||
|  |      else: | ||||||
|  | diff --git a/pungi/phases/ostree.py b/pungi/phases/ostree.py
 | ||||||
|  | index ebe03d0..e61e969 100644
 | ||||||
|  | --- a/pungi/phases/ostree.py
 | ||||||
|  | +++ b/pungi/phases/ostree.py
 | ||||||
|  | @@ -104,7 +104,7 @@ class OSTreeThread(WorkerThread):
 | ||||||
|  |                               extra_config_file=extra_config_file) | ||||||
|  |   | ||||||
|  |          if compose.notifier: | ||||||
|  | -            ref = get_ref_from_treefile(os.path.join(repodir, config['treefile']))
 | ||||||
|  | +            ref = get_ref_from_treefile(os.path.join(repodir, config['treefile']), arch)
 | ||||||
|  |              # 'pungi-make-ostree tree' writes commitid to commitid.log in logdir | ||||||
|  |              commitid = get_commitid_from_commitid_file(os.path.join(self.logdir, 'commitid.log')) | ||||||
|  |              compose.notifier.send('ostree', | ||||||
|  | 
 | ||||||
							
								
								
									
										241
									
								
								0002-image-build-Pass-arches-around-as-a-list.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										241
									
								
								0002-image-build-Pass-arches-around-as-a-list.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,241 @@ | |||||||
|  | From 8418b68fb0e1253f688b97c91df9ace6a38ebd02 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: =?UTF-8?q?Lubom=C3=ADr=20Sedl=C3=A1=C5=99?= <lsedlar@redhat.com> | ||||||
|  | Date: Tue, 24 Jan 2017 08:36:33 +0100 | ||||||
|  | Subject: [PATCH 2/2] image-build: Pass arches around as a list | ||||||
|  | MIME-Version: 1.0 | ||||||
|  | Content-Type: text/plain; charset=UTF-8 | ||||||
|  | Content-Transfer-Encoding: 8bit | ||||||
|  | 
 | ||||||
|  | Instead of joining the arches as a comma separated string and splitting | ||||||
|  | it again later. Ultimately we do need the original format to pass to | ||||||
|  | koji wrapper, but we can produce that value later. | ||||||
|  | 
 | ||||||
|  | Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com> | ||||||
|  | ---
 | ||||||
|  |  pungi/phases/image_build.py   | 16 ++++++++++------ | ||||||
|  |  tests/test_imagebuildphase.py | 41 +++++++++++++++++++++-------------------- | ||||||
|  |  2 files changed, 31 insertions(+), 26 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/pungi/phases/image_build.py b/pungi/phases/image_build.py
 | ||||||
|  | index b795125..bd18d3a 100644
 | ||||||
|  | --- a/pungi/phases/image_build.py
 | ||||||
|  | +++ b/pungi/phases/image_build.py
 | ||||||
|  | @@ -75,7 +75,7 @@ class ImageBuildPhase(base.PhaseLoggerMixin, base.ImageConfigMixin, base.ConfigG
 | ||||||
|  |      def _get_arches(self, image_conf, arches): | ||||||
|  |          if 'arches' in image_conf['image-build']: | ||||||
|  |              arches = set(image_conf['image-build'].get('arches', [])) & arches | ||||||
|  | -        return ','.join(sorted(arches))
 | ||||||
|  | +        return sorted(arches)
 | ||||||
|  |   | ||||||
|  |      def _set_release(self, image_conf): | ||||||
|  |          """If release is set explicitly to None, replace it with date and respin.""" | ||||||
|  | @@ -122,9 +122,9 @@ class ImageBuildPhase(base.PhaseLoggerMixin, base.ImageConfigMixin, base.ConfigG
 | ||||||
|  |   | ||||||
|  |                  can_fail = image_conf['image-build'].pop('failable', []) | ||||||
|  |                  if can_fail == ['*']: | ||||||
|  | -                    can_fail = image_conf['image-build']['arches'].split(',')
 | ||||||
|  | +                    can_fail = image_conf['image-build']['arches']
 | ||||||
|  |                  if can_fail: | ||||||
|  | -                    image_conf['image-build']['can_fail'] = ','.join(sorted(can_fail))
 | ||||||
|  | +                    image_conf['image-build']['can_fail'] = sorted(can_fail)
 | ||||||
|  |   | ||||||
|  |                  cmd = { | ||||||
|  |                      "format": format, | ||||||
|  | @@ -162,8 +162,7 @@ class CreateImageBuildThread(WorkerThread):
 | ||||||
|  |              self.worker(num, compose, variant, subvariant, cmd) | ||||||
|  |   | ||||||
|  |      def worker(self, num, compose, variant, subvariant, cmd): | ||||||
|  | -        arches = cmd["image_conf"]["image-build"]['arches'].split(',')
 | ||||||
|  | -        failable_arches = self.failable_arches.split(',')
 | ||||||
|  | +        arches = cmd["image_conf"]["image-build"]['arches']
 | ||||||
|  |          dash_arches = '-'.join(arches) | ||||||
|  |          log_file = compose.paths.log.log_file( | ||||||
|  |              dash_arches, | ||||||
|  | @@ -180,6 +179,11 @@ class CreateImageBuildThread(WorkerThread):
 | ||||||
|  |          # writes conf file for koji image-build | ||||||
|  |          self.pool.log_info("Writing image-build config for %s.%s into %s" % ( | ||||||
|  |              variant, dash_arches, cmd["conf_file"])) | ||||||
|  | +
 | ||||||
|  | +        # Join the arches into a single string. This is the value expected by
 | ||||||
|  | +        # koji config file.
 | ||||||
|  | +        cmd["image_conf"]["image-build"]['arches'] = ','.join(cmd["image_conf"]["image-build"]['arches'])
 | ||||||
|  | +
 | ||||||
|  |          koji_cmd = koji_wrapper.get_image_build_cmd(cmd["image_conf"], | ||||||
|  |                                                      conf_file_dest=cmd["conf_file"], | ||||||
|  |                                                      scratch=cmd['scratch']) | ||||||
|  | @@ -207,7 +211,7 @@ class CreateImageBuildThread(WorkerThread):
 | ||||||
|  |                          image_infos.append({'path': path, 'suffix': suffix, 'type': format, 'arch': arch}) | ||||||
|  |                          break | ||||||
|  |   | ||||||
|  | -        if len(image_infos) != len(cmd['format']) * (len(arches) - len(failable_arches)):
 | ||||||
|  | +        if len(image_infos) != len(cmd['format']) * (len(arches) - len(self.failable_arches)):
 | ||||||
|  |              self.pool.log_error( | ||||||
|  |                  "Error in koji task %s. Expected to find same amount of images " | ||||||
|  |                  "as in suffixes attr in image-build (%s) for each arch (%s). Got '%s'." % | ||||||
|  | diff --git a/tests/test_imagebuildphase.py b/tests/test_imagebuildphase.py
 | ||||||
|  | index 328b2b3..d3185e2 100644
 | ||||||
|  | --- a/tests/test_imagebuildphase.py
 | ||||||
|  | +++ b/tests/test_imagebuildphase.py
 | ||||||
|  | @@ -66,11 +66,11 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64',
 | ||||||
|  | +                    'arches': ['amd64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | -                    'can_fail': 'x86_64',
 | ||||||
|  | +                    'can_fail': ['x86_64'],
 | ||||||
|  |                  } | ||||||
|  |              }, | ||||||
|  |              "conf_file": self.topdir + '/work/image-build/Client/docker_Fedora-Docker-Base.cfg', | ||||||
|  | @@ -91,11 +91,11 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'arches': ['amd64', 'x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | -                    'can_fail': 'x86_64',
 | ||||||
|  | +                    'can_fail': ['x86_64'],
 | ||||||
|  |                  } | ||||||
|  |              }, | ||||||
|  |              "conf_file": self.topdir + '/work/image-build/Server/docker_Fedora-Docker-Base.cfg', | ||||||
|  | @@ -151,7 +151,7 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'arches': ['amd64', 'x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | @@ -207,7 +207,7 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'arches': ['amd64', 'x86_64'],
 | ||||||
|  |                      'version': '25', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | @@ -305,7 +305,7 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'x86_64',
 | ||||||
|  | +                    'arches': ['x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | @@ -369,7 +369,7 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'x86_64',
 | ||||||
|  | +                    'arches': ['x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | @@ -430,7 +430,7 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'x86_64',
 | ||||||
|  | +                    'arches': ['x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | @@ -603,11 +603,11 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'x86_64',
 | ||||||
|  | +                    'arches': ['x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | -                    'can_fail': 'x86_64',
 | ||||||
|  | +                    'can_fail': ['x86_64'],
 | ||||||
|  |                  } | ||||||
|  |              }, | ||||||
|  |              "conf_file": self.topdir + '/work/image-build/Server-optional/docker_Fedora-Docker-Base.cfg', | ||||||
|  | @@ -663,11 +663,11 @@ class TestImageBuildPhase(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'arches': ['amd64', 'x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | -                    'can_fail': 'amd64,x86_64',
 | ||||||
|  | +                    'can_fail': ['amd64', 'x86_64'],
 | ||||||
|  |                  } | ||||||
|  |              }, | ||||||
|  |              "conf_file": self.topdir + '/work/image-build/Server/docker_Fedora-Docker-Base.cfg', | ||||||
|  | @@ -703,7 +703,7 @@ class TestCreateImageBuildThread(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'arches': ['amd64', 'x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | @@ -743,6 +743,7 @@ class TestCreateImageBuildThread(PungiTestCase):
 | ||||||
|  |          with mock.patch('time.sleep'): | ||||||
|  |              t.process((compose, cmd), 1) | ||||||
|  |   | ||||||
|  | +        self.assertEqual(cmd['image_conf']['image-build']['arches'], 'amd64,x86_64')
 | ||||||
|  |          self.assertItemsEqual( | ||||||
|  |              koji_wrapper.get_image_build_cmd.call_args_list, | ||||||
|  |              [mock.call(cmd['image_conf'], | ||||||
|  | @@ -832,11 +833,11 @@ class TestCreateImageBuildThread(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'arches': ['amd64', 'x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | -                    "can_fail": 'amd64,x86_64',
 | ||||||
|  | +                    "can_fail": ['amd64', 'x86_64'],
 | ||||||
|  |                  } | ||||||
|  |              }, | ||||||
|  |              "conf_file": 'amd64,x86_64-Client-Fedora-Docker-Base-docker', | ||||||
|  | @@ -880,11 +881,11 @@ class TestCreateImageBuildThread(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'arches': ['amd64', 'x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | -                    'can_fail': 'amd64,x86_64',
 | ||||||
|  | +                    'can_fail': ['amd64', 'x86_64'],
 | ||||||
|  |                  } | ||||||
|  |              }, | ||||||
|  |              "conf_file": 'amd64,x86_64-Client-Fedora-Docker-Base-docker', | ||||||
|  | @@ -923,11 +924,11 @@ class TestCreateImageBuildThread(PungiTestCase):
 | ||||||
|  |                      'target': 'f24', | ||||||
|  |                      'disk_size': 3, | ||||||
|  |                      'name': 'Fedora-Docker-Base', | ||||||
|  | -                    'arches': 'amd64,x86_64',
 | ||||||
|  | +                    'arches': ['amd64', 'x86_64'],
 | ||||||
|  |                      'version': 'Rawhide', | ||||||
|  |                      'ksurl': 'git://git.fedorahosted.org/git/spin-kickstarts.git', | ||||||
|  |                      'distro': 'Fedora-20', | ||||||
|  | -                    'can_fail': 'amd64',
 | ||||||
|  | +                    'can_fail': ['amd64'],
 | ||||||
|  |                  } | ||||||
|  |              }, | ||||||
|  |              "conf_file": 'amd64,x86_64-Client-Fedora-Docker-Base-docker', | ||||||
|  | -- 
 | ||||||
|  | 2.11.0 | ||||||
|  | 
 | ||||||
							
								
								
									
										55
									
								
								63aa7db5aad4690b72898d01fa82270c1f503241.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								63aa7db5aad4690b72898d01fa82270c1f503241.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | |||||||
|  | From 63aa7db5aad4690b72898d01fa82270c1f503241 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Patrick Uiterwijk <puiterwijk@redhat.com> | ||||||
|  | Date: Jan 18 2017 18:52:45 +0000 | ||||||
|  | Subject: Add some debugging about ref updating | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | Signed-off-by: Patrick Uiterwijk <puiterwijk@redhat.com> | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  | 
 | ||||||
|  | diff --git a/pungi/ostree/tree.py b/pungi/ostree/tree.py
 | ||||||
|  | index 1b616b2..68b6d70 100644
 | ||||||
|  | --- a/pungi/ostree/tree.py
 | ||||||
|  | +++ b/pungi/ostree/tree.py
 | ||||||
|  | @@ -63,10 +63,13 @@ class Tree(OSTree):
 | ||||||
|  |          if self.extra_config: | ||||||
|  |              tag_ref = self.extra_config.get('tag_ref', True) | ||||||
|  |          if not tag_ref: | ||||||
|  | +            print('Not updating ref as configured')
 | ||||||
|  |              return | ||||||
|  |          ref = get_ref_from_treefile(self.treefile) | ||||||
|  |          commitid = get_commitid_from_commitid_file(self.commitid_file) | ||||||
|  | +        print('Ref: %r, Commit ID: %r' % (ref, commitid))
 | ||||||
|  |          if ref and commitid: | ||||||
|  | +            print('Updating ref')
 | ||||||
|  |              # Let's write the tag out ourselves | ||||||
|  |              heads_dir = os.path.join(self.repo, 'refs', 'heads') | ||||||
|  |              if not os.path.exists(heads_dir): | ||||||
|  | diff --git a/pungi/ostree/utils.py b/pungi/ostree/utils.py
 | ||||||
|  | index fb5e330..02540c9 100644
 | ||||||
|  | --- a/pungi/ostree/utils.py
 | ||||||
|  | +++ b/pungi/ostree/utils.py
 | ||||||
|  | @@ -37,8 +37,10 @@ def get_ref_from_treefile(treefile):
 | ||||||
|  |              try: | ||||||
|  |                  parsed = json.loads(f.read()) | ||||||
|  |                  ref = parsed['ref'] | ||||||
|  | -            except Exception:
 | ||||||
|  | -                pass
 | ||||||
|  | +            except Exception as e:
 | ||||||
|  | +                print('Unable to get ref from treefile: %s' % e)
 | ||||||
|  | +    else:
 | ||||||
|  | +        print('Unable to open treefile')
 | ||||||
|  |      return ref | ||||||
|  |   | ||||||
|  |   | ||||||
|  | @@ -48,6 +50,8 @@ def get_commitid_from_commitid_file(commitid_file):
 | ||||||
|  |      if os.path.isfile(commitid_file): | ||||||
|  |          with open(commitid_file, 'r') as f: | ||||||
|  |              commitid = f.read().replace('\n', '') | ||||||
|  | +    else:
 | ||||||
|  | +        print('Unable to find commitid file')
 | ||||||
|  |      return commitid | ||||||
|  |   | ||||||
|  |   | ||||||
|  | 
 | ||||||
							
								
								
									
										1398
									
								
								pungi.spec
									
									
									
									
									
								
							
							
						
						
									
										1398
									
								
								pungi.spec
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user