livemedia-creator: Output all the errors at once

Instead of handling one error at a time, gather them all up and print
them all in one block and then exit.
This commit is contained in:
Brian C. Lane 2014-04-03 10:22:54 -07:00
parent 71dd20607b
commit 39f9e14838

View File

@ -855,77 +855,75 @@ if __name__ == '__main__':
log.debug( opts ) log.debug( opts )
if os.getuid() != 0: # Check for invalid combinations of options, print all the errors and exit.
log.error("You need to run this as root") errors = []
sys.exit( 1 ) if not opts.disk_image and not opts.fs_image and not opts.ks:
errors.append("Image creation requires a kickstart file")
if opts.ks and not os.path.exists(opts.ks[0]):
errors.append("kickstart file (%s) is missing." % opts.ks[0])
if opts.make_iso and not os.path.exists( opts.lorax_templates ): if opts.make_iso and not os.path.exists( opts.lorax_templates ):
log.error( "The lorax templates directory ({0}) doesn't" errors.append("The lorax templates directory (%s) doesn't "
" exist.".format( opts.lorax_templates ) ) "exist." % opts.lorax_templates)
sys.exit( 1 )
if opts.result_dir and os.path.exists(opts.result_dir): if opts.result_dir and os.path.exists(opts.result_dir):
log.error( "The results_dir ({0}) should not exist, please delete or " errors.append("The results_dir (%s) should not exist, please delete or "
"move its contents".format( opts.result_dir )) "move its contents" % opts.result_dir)
sys.exit( 1 )
if opts.iso and not os.path.exists( opts.iso ): if opts.iso and not os.path.exists( opts.iso ):
log.error( "The iso {0} is missing.".format( opts.iso ) ) errors.append("The iso %s is missing." % opts.iso)
sys.exit( 1 )
if opts.disk_image and not os.path.exists( opts.disk_image ): if opts.disk_image and not os.path.exists( opts.disk_image ):
log.error( "The disk image {0} is missing.".format( opts.disk_image ) ) errors.append("The disk image %s is missing." % opts.disk_image)
sys.exit( 1 )
if opts.fs_image and not os.path.exists( opts.fs_image ): if opts.fs_image and not os.path.exists( opts.fs_image ):
log.error( "The filesystem image {0} is missing.".format( opts.fs_image ) ) errors.append("The filesystem image %s is missing." % opts.fs_image)
sys.exit( 1 )
is_install = not (opts.disk_image or opts.fs_image) is_install = not (opts.disk_image or opts.fs_image)
if is_install and not opts.no_virt and not opts.iso: if is_install and not opts.no_virt and not opts.iso:
log.error( "virt install needs an install iso." ) errors.append("virt install needs an install iso.")
sys.exit( 1 )
if opts.volid and len(opts.volid) > 32: if opts.volid and len(opts.volid) > 32:
log.fatal("the volume id cannot be longer than 32 characters") errors.append("the volume id cannot be longer than 32 characters")
sys.exit(1)
if is_install and not opts.no_virt and not libvirt: if is_install and not opts.no_virt and not libvirt:
log.error("virt install requires libvirt-python to be installed.") errors.append("virt install requires libvirt-python to be installed.")
sys.exit(1)
if is_install and not opts.no_virt \ if is_install and not opts.no_virt \
and not os.path.exists("/usr/bin/virt-install"): and not os.path.exists("/usr/bin/virt-install"):
log.error("virt-install needs to be installed.") errors.append("virt-install needs to be installed.")
sys.exit(1)
if is_install and opts.no_virt \ if is_install and opts.no_virt \
and not os.path.exists("/usr/sbin/anaconda"): and not os.path.exists("/usr/sbin/anaconda"):
log.error("no-virt requires anaconda to be installed.") errors.append("no-virt requires anaconda to be installed.")
sys.exit(1)
if opts.make_appliance and not opts.app_template: if opts.make_appliance and not opts.app_template:
opts.app_template = joinpaths(opts.lorax_templates, opts.app_template = joinpaths(opts.lorax_templates,
"appliance/libvirt.tmpl") "appliance/libvirt.tmpl")
if opts.make_appliance and not os.path.exists(opts.app_template): if opts.make_appliance and not os.path.exists(opts.app_template):
log.error("The appliance template ({0}) doesn't " errors.append("The appliance template (%s) doesn't "
"exist".format(opts.app_template)) "exist" % opts.app_template)
sys.exit(1)
if opts.image_name and os.path.exists(joinpaths(opts.tmp, opts.image_name)): if opts.image_name and os.path.exists(joinpaths(opts.tmp, opts.image_name)):
log.error("The disk image to be created should not exist.") errors.append("The disk image to be created should not exist.")
sys.exit(1)
if opts.qcow2 and not os.path.exists("/usr/bin/qemu-img"): if opts.qcow2 and not os.path.exists("/usr/bin/qemu-img"):
log.error("qcow2 requires the qemu-img utility to be installed.") errors.append("qcow2 requires the qemu-img utility to be installed.")
sys.exit(1)
if opts.qcow2 and opts.make_iso: if opts.qcow2 and opts.make_iso:
log.error("qcow2 cannot be used to make a bootable iso.") errors.append("qcow2 cannot be used to make a bootable iso.")
sys.exit(1)
# TODO check for qcow2 and fsimage if opts.make_fsimage and opts.qcow2:
errors.append("qcow2 cannot be used to make filesystem images.")
if os.getuid() != 0:
errors.append("You need to run this as root")
if errors:
map(log.error, errors)
sys.exit(1)
# AMI image is just a fsimage with an AMI label # AMI image is just a fsimage with an AMI label
if opts.make_ami: if opts.make_ami:
@ -943,19 +941,12 @@ if __name__ == '__main__':
# Parse the kickstart # Parse the kickstart
if opts.ks: if opts.ks:
if not os.path.exists(opts.ks[0]):
log.error("kickstart file ({0}) is missing.".format(opts.ks[0]))
sys.exit(1)
ks_version = makeVersion() ks_version = makeVersion()
ks = KickstartParser( ks_version, errorsAreFatal=False, missingIncludeIsFatal=False ) ks = KickstartParser( ks_version, errorsAreFatal=False, missingIncludeIsFatal=False )
ks.readKickstart( opts.ks[0] ) ks.readKickstart( opts.ks[0] )
# Make the disk or filesystem image # Make the disk or filesystem image
if not opts.disk_image and not opts.fs_image: if not opts.disk_image and not opts.fs_image:
if not opts.ks:
log.error("Image creation requires a kickstart file")
sys.exit(1)
errors = [] errors = []
if ks.handler.method.method != "url": if ks.handler.method.method != "url":
errors.append("Only url install method is currently supported. Please " errors.append("Only url install method is currently supported. Please "
@ -969,8 +960,7 @@ if __name__ == '__main__':
if errors: if errors:
for e in errors: map(log.error, errors)
log.error(e)
sys.exit(1) sys.exit(1)
# Make the image. Output of this is either a partitioned disk image or a fsimage # Make the image. Output of this is either a partitioned disk image or a fsimage