From 4a414d399004aa9f848ccdd428f64496a0176596 Mon Sep 17 00:00:00 2001 From: Kelven Yang Date: Tue, 28 Jan 2014 17:16:04 -0800 Subject: [PATCH] Pragrammatically Answer HA question posted in vCenter since it will block CloudStack from continuously operating on the VM --- .../vmware/mo/VirtualMachineMO.java | 23 ++++++++----------- 1 file changed, 9 insertions(+), 14 deletions(-) diff --git a/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java b/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java index 3e83bb6cb0c..663adbff9cd 100644 --- a/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java +++ b/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java @@ -190,10 +190,10 @@ public class VirtualMachineMO extends BaseMO { } public boolean powerOn() throws Exception { - if(getResetSafePowerState() == VirtualMachinePowerState.POWERED_ON) - return true; + if (getResetSafePowerState() == VirtualMachinePowerState.POWERED_ON) + return true; - ManagedObjectReference morTask = _context.getService().powerOnVMTask(_mor, null); + ManagedObjectReference morTask = _context.getService().powerOnVMTask(_mor, null); // Monitor VM questions final Boolean[] flags = {false}; final VirtualMachineMO vmMo = this; @@ -248,17 +248,12 @@ public class VirtualMachineMO extends BaseMO { } }); - try { - boolean result = _context.getVimClient().waitForTask(morTask); - if (result) { - _context.waitForTaskProgressDone(morTask); - return true; - } else { - s_logger.error("VMware powerOnVM_Task failed due to " + TaskMO.getTaskFailureInfo(_context, morTask)); - } - } finally { - // make sure to let VM question monitor exit - flags[0] = true; + boolean result = _context.getVimClient().waitForTask(morTask); + if (result) { + _context.waitForTaskProgressDone(morTask); + return true; + } else { + s_logger.error("VMware powerOnVM_Task failed due to " + TaskMO.getTaskFailureInfo(_context, morTask)); } return false;