unified-iso: Fall back to default config

When the configuration can not be read from the compose, we should use
default values instead of aborting. This allows us to work with composes
produced by Distill.

Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
This commit is contained in:
Lubomír Sedlář 2017-01-12 10:42:35 +01:00
parent a9b275f13b
commit 2c76313382

View File

@ -53,6 +53,9 @@ def ti_merge(one, two):
one.variants.add(var) one.variants.add(var)
DEFAULT_CHECKSUMS = ['md5', 'sha1', 'sha256']
class UnifiedISO(object): class UnifiedISO(object):
def __init__(self, compose_path, output_path=None): def __init__(self, compose_path, output_path=None):
self.compose_path = os.path.abspath(compose_path) self.compose_path = os.path.abspath(compose_path)
@ -252,7 +255,10 @@ class UnifiedISO(object):
conf_dump = glob.glob(os.path.join(self.compose_path, conf_dump = glob.glob(os.path.join(self.compose_path,
'../logs/global/config-dump*.global.log'))[0] '../logs/global/config-dump*.global.log'))[0]
except IndexError: except IndexError:
raise RuntimeError('Config dump not found, can not generate checksums...') print('Config dump not found, can not adhere to previous settings. '
'Expect weird naming and checksums.',
file=sys.stderr)
return {}
with open(conf_dump) as f: with open(conf_dump) as f:
return json.load(f) return json.load(f)
@ -292,7 +298,8 @@ class UnifiedISO(object):
supported = True supported = True
run(iso.get_implantisomd5_cmd(iso_path, supported)) run(iso.get_implantisomd5_cmd(iso_path, supported))
checksums = compute_file_checksums(iso_path, self.conf['media_checksums']) checksums = compute_file_checksums(
iso_path, self.conf.get('media_checksums', DEFAULT_CHECKSUMS))
# write manifest file # write manifest file
run(iso.get_manifest_cmd(iso_path)) run(iso.get_manifest_cmd(iso_path))
@ -316,7 +323,7 @@ class UnifiedISO(object):
self.images.setdefault(typed_arch, set()).add(iso_path + ".manifest") self.images.setdefault(typed_arch, set()).add(iso_path + ".manifest")
for checksum_type, checksum in checksums.iteritems(): for checksum_type, checksum in checksums.iteritems():
if not self.conf['media_checksum_one_file']: if not self.conf.get('media_checksum_one_file', False):
checksum_path = dump_checksums(iso_dir, checksum_type, checksum_path = dump_checksums(iso_dir, checksum_type,
{iso_name: checksum}, {iso_name: checksum},
'%s.%sSUM' % (iso_name, checksum_type.upper())) '%s.%sSUM' % (iso_name, checksum_type.upper()))
@ -388,7 +395,7 @@ class UnifiedISO(object):
'variant': variant, 'variant': variant,
'arch': arch, 'arch': arch,
} }
base_name = self.conf['media_checksum_base_filename'] base_name = self.conf.get('media_checksum_base_filename', '')
if base_name: if base_name:
base_name = (base_name % substs).format(**substs) base_name = (base_name % substs).format(**substs)
base_name += '-' base_name += '-'
@ -398,6 +405,6 @@ class UnifiedISO(object):
for (variant, arch, path), images in get_images(self.compose_path, self.compose.images).iteritems(): for (variant, arch, path), images in get_images(self.compose_path, self.compose.images).iteritems():
base_checksum_name = self._get_base_filename(variant, arch) base_checksum_name = self._get_base_filename(variant, arch)
make_checksums(variant, arch, path, images, make_checksums(variant, arch, path, images,
self.conf['media_checksums'], self.conf.get('media_checksums', DEFAULT_CHECKSUMS),
base_checksum_name, base_checksum_name,
self.conf['media_checksum_one_file']) self.conf.get('media_checksum_one_file', False))