When trying to start a running vm, shutoff or poweroff a shutdown vm,
the retrieved error was 500 (Internal Server Error). A better error
would be 400 (Invalid Request).
Signed-off-by: Ramon Medeiros <ramonn(a)linux.vnet.ibm.com>
---
src/kimchi/i18n.py | 4 ++++
src/kimchi/model/vms.py | 20 ++++++++++++++++++++
2 files changed, 24 insertions(+)
diff --git a/src/kimchi/i18n.py b/src/kimchi/i18n.py
index 862df7f..7b89751 100644
--- a/src/kimchi/i18n.py
+++ b/src/kimchi/i18n.py
@@ -119,6 +119,10 @@ messages = {
"KCHVM0045E": _("There are not enough free slots of 1024 Mib in the
guest."),
"KCHVM0046E": _("Host's libvirt version does not support memory
devices. Libvirt must be >= 1.2.14"),
"KCHVM0047E": _("Error attaching memory device. Details:
%(error)s"),
+ "KCHVM0048E": _("Cannot start %(name)s. Virtual machine is already
running."),
+ "KCHVM0049E": _("Cannot power off %(name)s. Virtual machine is shut
off."),
+ "KCHVM0050E": _("Cannot shutdown %(name)s. Virtual machine is shut
off."),
+ "KCHVM0051E": _("Cannot reset %(name)s. Virtual machine is already
shut off."),
"KCHVMHDEV0001E": _("VM %(vmid)s does not contain directly assigned
host device %(dev_name)s."),
"KCHVMHDEV0002E": _("The host device %(dev_name)s is not allowed to
directly assign to VM."),
diff --git a/src/kimchi/model/vms.py b/src/kimchi/model/vms.py
index 106e9bc..4fbbb1f 100644
--- a/src/kimchi/model/vms.py
+++ b/src/kimchi/model/vms.py
@@ -1102,6 +1102,11 @@ class VMModel(object):
run_setfacl_set_attr(iso, user=user)
dom = self.get_vm(name, self.conn)
+
+ # vm already running: return error 400
+ if DOM_STATE_MAP[dom.info()[0]] == "running":
+ raise InvalidOperation("KCHVM0048E", {'name': name})
+
try:
dom.create()
except libvirt.libvirtError as e:
@@ -1110,6 +1115,11 @@ class VMModel(object):
def poweroff(self, name):
dom = self.get_vm(name, self.conn)
+
+ # vm already powered off: return error 400
+ if DOM_STATE_MAP[dom.info()[0]] == "shutoff":
+ raise InvalidOperation("KCHVM0049E", {'name': name})
+
try:
dom.destroy()
except libvirt.libvirtError as e:
@@ -1118,6 +1128,11 @@ class VMModel(object):
def shutdown(self, name):
dom = self.get_vm(name, self.conn)
+
+ # vm already powered off: return error 400
+ if DOM_STATE_MAP[dom.info()[0]] == "shutoff":
+ raise InvalidOperation("KCHVM0050E", {'name': name})
+
try:
dom.shutdown()
except libvirt.libvirtError as e:
@@ -1126,6 +1141,11 @@ class VMModel(object):
def reset(self, name):
dom = self.get_vm(name, self.conn)
+
+ # vm already powered off: return error 400
+ if DOM_STATE_MAP[dom.info()[0]] == "shutoff":
+ raise InvalidOperation("KCHVM0051E", {'name': name})
+
try:
dom.reset(flags=0)
except libvirt.libvirtError as e:
--
2.1.0