virt-xml: Denest and comment code flow a bit

Add lots of early exits to remove implicit fall through
behavior that I find hard to follow
This commit is contained in:
Cole Robinson 2019-06-16 16:00:17 -04:00
parent 0221471e4f
commit 52c6094c65
2 changed files with 58 additions and 36 deletions

View File

@ -1085,7 +1085,7 @@ vixml = App("virt-xml")
c = vixml.add_category("misc", "") c = vixml.add_category("misc", "")
c.add_valid("--help") # basic --help test c.add_valid("--help") # basic --help test
c.add_valid("--sound=? --tpm=?") # basic introspection test c.add_valid("--sound=? --tpm=?") # basic introspection test
c.add_valid("test-state-shutoff --edit --update --boot menu=on") # --update with inactive VM, should work but warn c.add_valid("test-state-shutoff --edit --update --boot menu=on", grep="The VM is not running") # --update with inactive VM, should work but warn
c.add_valid("test-for-virtxml --edit --graphics password=foo --update --confirm", input_text="no\nno\n") # prompt exiting c.add_valid("test-for-virtxml --edit --graphics password=foo --update --confirm", input_text="no\nno\n") # prompt exiting
c.add_valid("test-for-virtxml --edit --cpu host-passthrough --no-define --start --confirm", input_text="no") # transient prompt exiting c.add_valid("test-for-virtxml --edit --cpu host-passthrough --no-define --start --confirm", input_text="no") # transient prompt exiting
c.add_valid("test-for-virtxml --edit --metadata name=test-for-virtxml", grep="requested changes will have no effect") c.add_valid("test-for-virtxml --edit --metadata name=test-for-virtxml", grep="requested changes will have no effect")
@ -1093,8 +1093,8 @@ c.add_invalid("test --edit 2 --events on_poweroff=destroy", grep="'--edit 2' doe
c.add_invalid("test --os-variant fedora26 --edit --cpu host-passthrough", grep="--os-variant is not supported") c.add_invalid("test --os-variant fedora26 --edit --cpu host-passthrough", grep="--os-variant is not supported")
c.add_invalid("test-for-virtxml --os-variant fedora26 --remove-device --disk 1", grep="--os-variant is not supported") c.add_invalid("test-for-virtxml --os-variant fedora26 --remove-device --disk 1", grep="--os-variant is not supported")
c.add_invalid("--build-xml --os-variant fedora26 --disk path=foo", grep="--os-variant is not supported") c.add_invalid("--build-xml --os-variant fedora26 --disk path=foo", grep="--os-variant is not supported")
c.add_invalid("domain-idontexist --cpu host-passthrough --start", grep="Could not find domain") c.add_invalid("domain-idontexist --edit --cpu host-passthrough --start", grep="Could not find domain")
c.add_invalid("test-state-shutoff --edit --update --boot menu=on --start", grep="Either update or start") c.add_invalid("test-state-shutoff --edit --update --boot menu=on --start", grep="Cannot mix --update")
c.add_invalid("test --edit --update --events on_poweroff=destroy", grep="Don't know how to --update for --events") c.add_invalid("test --edit --update --events on_poweroff=destroy", grep="Don't know how to --update for --events")
c.add_invalid("--edit --cpu host-passthrough --confirm", input_file=(XMLDIR + "/virtxml-stdin-edit.xml"), grep="Can't use --confirm with stdin") c.add_invalid("--edit --cpu host-passthrough --confirm", input_file=(XMLDIR + "/virtxml-stdin-edit.xml"), grep="Can't use --confirm with stdin")
c.add_invalid("--edit --cpu host-passthrough --update", input_file=(XMLDIR + "/virtxml-stdin-edit.xml"), grep="Can't use --update with stdin") c.add_invalid("--edit --cpu host-passthrough --update", input_file=(XMLDIR + "/virtxml-stdin-edit.xml"), grep="Can't use --update with stdin")

View File

@ -436,9 +436,6 @@ def main(conn=None):
options.quiet = False options.quiet = False
cli.setupLogging("virt-xml", options.debug, options.quiet) cli.setupLogging("virt-xml", options.debug, options.quiet)
if options.update and options.start:
fail(_("Either update or start a domain"))
if cli.check_option_introspection(options): if cli.check_option_introspection(options):
return 0 return 0
@ -453,6 +450,10 @@ def main(conn=None):
else: else:
fail(_("A domain must be specified")) fail(_("A domain must be specified"))
# Default to --define, unless:
# --no-define explicitly specified
# --print-* option is used
# XML input came from stdin
if not options.print_xml and not options.print_diff: if not options.print_xml and not options.print_diff:
if options.stdinxml: if options.stdinxml:
if not options.define: if not options.define:
@ -463,6 +464,21 @@ def main(conn=None):
if options.confirm and not options.print_xml: if options.confirm and not options.print_xml:
options.print_diff = True options.print_diff = True
# Ensure only one of these actions wash specified
# --edit
# --remove-device
# --add-device
# --build-xml
check_action_collision(options)
# Ensure there wasn't more than one device/xml config option
# specified. So reject '--disk X --network X'
parserclass = check_xmlopt_collision(options)
if options.update and not parserclass.guest_propname:
fail(_("Don't know how to --update for --%s") %
(parserclass.cli_arg_name))
conn = cli.getConnection(options.connect, conn) conn = cli.getConnection(options.connect, conn)
domain = None domain = None
@ -472,15 +488,8 @@ def main(conn=None):
domain, inactive_xmlobj, active_xmlobj = get_domain_and_guest( domain, inactive_xmlobj, active_xmlobj = get_domain_and_guest(
conn, options.domain) conn, options.domain)
else: else:
inactive_xmlobj = virtinst.Guest(conn, inactive_xmlobj = virtinst.Guest(conn, parsexml=options.stdinxml)
parsexml=options.stdinxml) vm_is_running = bool(active_xmlobj)
check_action_collision(options)
parserclass = check_xmlopt_collision(options)
if options.update and not parserclass.guest_propname:
fail(_("Don't know how to --update for --%s") %
(parserclass.cli_arg_name))
if options.build_xml: if options.build_xml:
devs = action_build_xml(conn, options, parserclass, inactive_xmlobj) devs = action_build_xml(conn, options, parserclass, inactive_xmlobj)
@ -489,35 +498,48 @@ def main(conn=None):
print_stdout(dev.get_xml()) print_stdout(dev.get_xml())
return 0 return 0
performed_update = False
if options.update: if options.update:
if active_xmlobj: if options.update and options.start:
fail(_("Cannot mix --update and --start"))
if vm_is_running:
devs, action = prepare_changes(active_xmlobj, options, parserclass) devs, action = prepare_changes(active_xmlobj, options, parserclass)
update_changes(domain, devs, action, options.confirm) update_changes(domain, devs, action, options.confirm)
performed_update = True
else: else:
logging.warning( logging.warning(
_("The VM is not running, --update is inapplicable.")) _("The VM is not running, --update is inapplicable."))
if not options.define:
# --update and --no-define passed, so we are done
# It's hard to hit this case with the test suite
return 0 # pragma: no cover
if options.define or options.start:
devs, action = prepare_changes(inactive_xmlobj, options, parserclass) devs, action = prepare_changes(inactive_xmlobj, options, parserclass)
if options.define: if not options.define:
if options.start:
start_domain_transient(conn, inactive_xmlobj, devs,
action, options.confirm)
return 0
dom = define_changes(conn, inactive_xmlobj, dom = define_changes(conn, inactive_xmlobj,
devs, action, options.confirm) devs, action, options.confirm)
if dom and options.start: if not dom:
# --confirm user said 'no'
return 0
if options.start:
try: try:
dom.create() dom.create()
except libvirt.libvirtError as e: # pragma: no cover except libvirt.libvirtError as e: # pragma: no cover
fail(_("Failed starting domain '%s': %s") % (inactive_xmlobj.name, e)) fail(_("Failed starting domain '%s': %s") % (
inactive_xmlobj.name, e))
print_stdout(_("Domain '%s' started successfully.") % print_stdout(_("Domain '%s' started successfully.") %
inactive_xmlobj.name) inactive_xmlobj.name)
elif not options.update and active_xmlobj and dom:
elif vm_is_running and not performed_update:
print_stdout( print_stdout(
_("Changes will take effect after the domain is fully powered off.")) _("Changes will take effect after the domain is fully powered off."))
else:
dom = start_domain_transient(conn, inactive_xmlobj, devs,
action, options.confirm)
if not options.update and not options.define and not options.start:
prepare_changes(inactive_xmlobj, options, parserclass)
return 0 return 0