| // Licensed to the Apache Software Foundation (ASF) under one |
| // or more contributor license agreements. See the NOTICE file |
| // distributed with this work for additional information |
| // regarding copyright ownership. The ASF licenses this file |
| // to you under the Apache License, Version 2.0 (the |
| // "License"); you may not use this file except in compliance |
| // with the License. You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, |
| // software distributed under the License is distributed on an |
| // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| // KIND, either express or implied. See the License for the |
| // specific language governing permissions and limitations |
| // under the License. |
| package com.cloud.hypervisor.xenserver.resource.wrapper.xenbase; |
| |
| import static org.junit.Assert.assertFalse; |
| import static org.junit.Assert.assertNotNull; |
| import static org.junit.Assert.assertTrue; |
| import static org.junit.Assert.fail; |
| import static org.mockito.Mockito.times; |
| import static org.mockito.Mockito.verify; |
| import static org.mockito.Mockito.when; |
| |
| import java.util.ArrayList; |
| import java.util.HashMap; |
| import java.util.List; |
| import java.util.Map; |
| |
| import com.google.gson.Gson; |
| import org.apache.xmlrpc.XmlRpcException; |
| import org.junit.Test; |
| import org.junit.runner.RunWith; |
| import org.mockito.Mock; |
| import org.mockito.Mockito; |
| import org.powermock.modules.junit4.PowerMockRunner; |
| |
| import com.cloud.agent.api.Answer; |
| import com.cloud.agent.api.CheckNetworkCommand; |
| import com.cloud.agent.api.MigrateWithStorageCommand; |
| import com.cloud.agent.api.MigrateWithStorageCompleteCommand; |
| import com.cloud.agent.api.MigrateWithStorageReceiveCommand; |
| import com.cloud.agent.api.MigrateWithStorageSendCommand; |
| import com.cloud.agent.api.SetupCommand; |
| import com.cloud.agent.api.storage.MigrateVolumeCommand; |
| import com.cloud.agent.api.to.NicTO; |
| import com.cloud.agent.api.to.StorageFilerTO; |
| import com.cloud.agent.api.to.VirtualMachineTO; |
| import com.cloud.agent.api.to.VolumeTO; |
| import com.cloud.host.HostEnvironment; |
| import com.cloud.hypervisor.xenserver.resource.XenServer610Resource; |
| import com.cloud.hypervisor.xenserver.resource.XsHost; |
| import com.cloud.hypervisor.xenserver.resource.XsLocalNetwork; |
| import com.cloud.network.Networks.TrafficType; |
| import com.cloud.network.PhysicalNetworkSetupInfo; |
| import com.cloud.storage.StoragePool; |
| import com.cloud.utils.Pair; |
| import com.xensource.xenapi.Connection; |
| import com.xensource.xenapi.Network; |
| import com.xensource.xenapi.SR; |
| import com.xensource.xenapi.Task; |
| import com.xensource.xenapi.Types.BadServerResponse; |
| import com.xensource.xenapi.Types.XenAPIException; |
| import com.xensource.xenapi.VDI; |
| import com.xensource.xenapi.VIF; |
| |
| @RunWith(PowerMockRunner.class) |
| public class XenServer610WrapperTest { |
| |
| @Mock |
| protected XenServer610Resource xenServer610Resource; |
| |
| @Test |
| public void testCheckNetworkCommandFailure() { |
| final XenServer610Resource xenServer610Resource = new XenServer610Resource(); |
| |
| final PhysicalNetworkSetupInfo info = new PhysicalNetworkSetupInfo(); |
| |
| final List<PhysicalNetworkSetupInfo> setupInfos = new ArrayList<PhysicalNetworkSetupInfo>(); |
| setupInfos.add(info); |
| |
| final CheckNetworkCommand checkNet = new CheckNetworkCommand(setupInfos); |
| |
| final Answer answer = xenServer610Resource.executeRequest(checkNet); |
| |
| assertTrue(answer.getResult()); |
| } |
| |
| @Test |
| public void testSetupCommand() { |
| final XenServer610Resource xenServer610Resource = new XenServer610Resource(); |
| |
| final HostEnvironment env = Mockito.mock(HostEnvironment.class); |
| |
| final SetupCommand setupCommand = new SetupCommand(env); |
| |
| final Answer answer = xenServer610Resource.executeRequest(setupCommand); |
| |
| assertFalse(answer.getResult()); |
| } |
| |
| @Test |
| public void testMigrateWithStorageCommand() { |
| final String vmName = "small"; |
| final String uuid = "206b21a7-c6ec-40e2-b5e2-f861b9612f04"; |
| final String path = "/"; |
| |
| final Connection conn = Mockito.mock(Connection.class); |
| final VirtualMachineTO vmSpec = Mockito.mock(VirtualMachineTO.class); |
| |
| final VolumeTO vol1 = Mockito.mock(VolumeTO.class); |
| final VolumeTO vol2 = Mockito.mock(VolumeTO.class); |
| final StorageFilerTO storage1 = Mockito.mock(StorageFilerTO.class); |
| final StorageFilerTO storage2 = Mockito.mock(StorageFilerTO.class); |
| |
| final Map<VolumeTO, StorageFilerTO> volumeToFiler = new HashMap<VolumeTO, StorageFilerTO>(); |
| volumeToFiler.put(vol1, storage1); |
| volumeToFiler.put(vol2, storage2); |
| |
| final NicTO nicTO1 = Mockito.mock(NicTO.class); |
| final NicTO nicTO2 = Mockito.mock(NicTO.class); |
| final NicTO nicTO3 = Mockito.mock(NicTO.class); |
| final NicTO [] nicTOs = {nicTO1, nicTO2, nicTO3}; |
| |
| final XsLocalNetwork nativeNetworkForTraffic = Mockito.mock(XsLocalNetwork.class); |
| final Network networkForSm = Mockito.mock(Network.class); |
| final XsHost xsHost = Mockito.mock(XsHost.class); |
| |
| final SR sr1 = Mockito.mock(SR.class); |
| final SR sr2 = Mockito.mock(SR.class); |
| |
| final VDI vdi1 = Mockito.mock(VDI.class); |
| final VDI vdi2 = Mockito.mock(VDI.class); |
| |
| final MigrateWithStorageCommand migrateStorageCommand = new MigrateWithStorageCommand(vmSpec, volumeToFiler); |
| |
| final CitrixRequestWrapper wrapper = CitrixRequestWrapper.getInstance(); |
| assertNotNull(wrapper); |
| |
| when(xenServer610Resource.getConnection()).thenReturn(conn); |
| when(vmSpec.getName()).thenReturn(vmName); |
| when(vmSpec.getNics()).thenReturn(nicTOs); |
| |
| when(storage1.getUuid()).thenReturn(uuid); |
| when(storage2.getUuid()).thenReturn(uuid); |
| |
| when(vol1.getPath()).thenReturn(path); |
| when(vol2.getPath()).thenReturn(path); |
| |
| when(xenServer610Resource.getStorageRepository(conn, storage1.getUuid())).thenReturn(sr1); |
| when(xenServer610Resource.getStorageRepository(conn, storage2.getUuid())).thenReturn(sr2); |
| |
| when(xenServer610Resource.getVDIbyUuid(conn, storage1.getPath())).thenReturn(vdi1); |
| when(xenServer610Resource.getVDIbyUuid(conn, storage2.getPath())).thenReturn(vdi2); |
| |
| try { |
| when(xenServer610Resource.getNativeNetworkForTraffic(conn, TrafficType.Storage, null)).thenReturn(nativeNetworkForTraffic); |
| when(nativeNetworkForTraffic.getNetwork()).thenReturn(networkForSm); |
| |
| when(xenServer610Resource.getHost()).thenReturn(xsHost); |
| when(xsHost.getUuid()).thenReturn(uuid); |
| } catch (final XenAPIException e) { |
| fail(e.getMessage()); |
| } catch (final XmlRpcException e) { |
| fail(e.getMessage()); |
| } |
| |
| final Answer answer = wrapper.execute(migrateStorageCommand, xenServer610Resource); |
| |
| verify(xenServer610Resource, times(1)).getConnection(); |
| |
| try { |
| verify(xenServer610Resource, times(1)).prepareISO(conn, vmName, null, null); |
| verify(xenServer610Resource, times(1)).getNetwork(conn, nicTO1); |
| verify(xenServer610Resource, times(1)).getNetwork(conn, nicTO2); |
| verify(xenServer610Resource, times(1)).getNetwork(conn, nicTO3); |
| |
| verify(xenServer610Resource, times(1)).getNativeNetworkForTraffic(conn, TrafficType.Storage, null); |
| verify(nativeNetworkForTraffic, times(1)).getNetwork(); |
| |
| verify(xenServer610Resource, times(1)).getHost(); |
| verify(xsHost, times(1)).getUuid(); |
| } catch (final XenAPIException e) { |
| fail(e.getMessage()); |
| } catch (final XmlRpcException e) { |
| fail(e.getMessage()); |
| } |
| |
| assertFalse(answer.getResult()); |
| } |
| |
| @Test |
| public void testMigrateWithStorageReceiveCommand() { |
| final String vmName = "small"; |
| final String uuid = "206b21a7-c6ec-40e2-b5e2-f861b9612f04"; |
| |
| final Connection conn = Mockito.mock(Connection.class); |
| final VirtualMachineTO vmSpec = Mockito.mock(VirtualMachineTO.class); |
| |
| final VolumeTO vol1 = Mockito.mock(VolumeTO.class); |
| final VolumeTO vol2 = Mockito.mock(VolumeTO.class); |
| final StorageFilerTO storage1 = Mockito.mock(StorageFilerTO.class); |
| final StorageFilerTO storage2 = Mockito.mock(StorageFilerTO.class); |
| |
| final List<Pair<VolumeTO, String>> volumeToFiler = new ArrayList<>(); |
| volumeToFiler.add(new Pair<>(vol1, storage1.getPath())); |
| volumeToFiler.add(new Pair<>(vol2, storage2.getPath())); |
| |
| final NicTO nicTO1 = Mockito.mock(NicTO.class); |
| final NicTO nicTO2 = Mockito.mock(NicTO.class); |
| final NicTO nicTO3 = Mockito.mock(NicTO.class); |
| final NicTO [] nicTOs = {nicTO1, nicTO2, nicTO3}; |
| |
| final XsLocalNetwork nativeNetworkForTraffic = Mockito.mock(XsLocalNetwork.class); |
| final Network network = Mockito.mock(Network.class); |
| final XsHost xsHost = Mockito.mock(XsHost.class); |
| |
| final Network nw1 = Mockito.mock(Network.class); |
| final Network nw2 = Mockito.mock(Network.class); |
| final Network nw3 = Mockito.mock(Network.class); |
| |
| final SR sr1 = Mockito.mock(SR.class); |
| final SR sr2 = Mockito.mock(SR.class); |
| |
| final MigrateWithStorageReceiveCommand migrateStorageCommand = new MigrateWithStorageReceiveCommand(vmSpec, volumeToFiler); |
| |
| final CitrixRequestWrapper wrapper = CitrixRequestWrapper.getInstance(); |
| assertNotNull(wrapper); |
| |
| when(xenServer610Resource.getConnection()).thenReturn(conn); |
| when(vmSpec.getName()).thenReturn(vmName); |
| when(vmSpec.getNics()).thenReturn(nicTOs); |
| |
| when(storage1.getUuid()).thenReturn(uuid); |
| when(storage2.getUuid()).thenReturn(uuid); |
| |
| when(xenServer610Resource.getStorageRepository(conn, storage1.getUuid())).thenReturn(sr1); |
| when(xenServer610Resource.getStorageRepository(conn, storage2.getUuid())).thenReturn(sr2); |
| |
| try { |
| |
| when(xenServer610Resource.getNetwork(conn, nicTO1)).thenReturn(nw1); |
| when(xenServer610Resource.getNetwork(conn, nicTO2)).thenReturn(nw2); |
| when(xenServer610Resource.getNetwork(conn, nicTO3)).thenReturn(nw3); |
| |
| when(xenServer610Resource.getNativeNetworkForTraffic(conn, TrafficType.Storage, null)).thenReturn(nativeNetworkForTraffic); |
| when(nativeNetworkForTraffic.getNetwork()).thenReturn(network); |
| |
| when(xenServer610Resource.getHost()).thenReturn(xsHost); |
| when(xsHost.getUuid()).thenReturn(uuid); |
| } catch (final XenAPIException e) { |
| fail(e.getMessage()); |
| } catch (final XmlRpcException e) { |
| fail(e.getMessage()); |
| } |
| |
| final Answer answer = wrapper.execute(migrateStorageCommand, xenServer610Resource); |
| |
| verify(xenServer610Resource, times(1)).getConnection(); |
| |
| try { |
| verify(xenServer610Resource, times(1)).getNetwork(conn, nicTO1); |
| verify(xenServer610Resource, times(1)).getNetwork(conn, nicTO2); |
| verify(xenServer610Resource, times(1)).getNetwork(conn, nicTO3); |
| |
| verify(xenServer610Resource, times(1)).getNativeNetworkForTraffic(conn, TrafficType.Storage, null); |
| verify(nativeNetworkForTraffic, times(1)).getNetwork(); |
| |
| verify(xenServer610Resource, times(1)).getHost(); |
| verify(xsHost, times(1)).getUuid(); |
| } catch (final XenAPIException e) { |
| fail(e.getMessage()); |
| } catch (final XmlRpcException e) { |
| fail(e.getMessage()); |
| } |
| |
| assertFalse(answer.getResult()); |
| } |
| |
| @Test |
| public void testMigrateWithStorageSendCommand() { |
| final String vmName = "small"; |
| final String path = "/"; |
| final String mac = "3c:15:c2:c4:4f:18"; |
| |
| final Connection conn = Mockito.mock(Connection.class); |
| final VirtualMachineTO vmSpec = Mockito.mock(VirtualMachineTO.class); |
| |
| final VolumeTO volume1 = Mockito.mock(VolumeTO.class); |
| final VolumeTO volume2 = Mockito.mock(VolumeTO.class); |
| |
| final SR sr1 = Mockito.mock(SR.class); |
| final SR sr2 = Mockito.mock(SR.class); |
| |
| final VDI vdi1 = Mockito.mock(VDI.class); |
| final VDI vdi2 = Mockito.mock(VDI.class); |
| |
| final NicTO nic1 = Mockito.mock(NicTO.class); |
| final NicTO nic2 = Mockito.mock(NicTO.class); |
| |
| final Network network1 = Mockito.mock(Network.class); |
| final Network network2 = Mockito.mock(Network.class); |
| |
| final List<Pair<VolumeTO, Object>> volumeToSr = new ArrayList<Pair<VolumeTO, Object>>(); |
| volumeToSr.add(new Pair<VolumeTO, Object>(volume1, sr1)); |
| volumeToSr.add(new Pair<VolumeTO, Object>(volume2, sr2)); |
| |
| final List<Pair<NicTO, Object>> nicToNetwork = new ArrayList<Pair<NicTO, Object>>(); |
| nicToNetwork.add(new Pair<NicTO, Object>(nic1, network1)); |
| nicToNetwork.add(new Pair<NicTO, Object>(nic2, network2)); |
| |
| final Map<String, String> token = new HashMap<String, String>(); |
| |
| final VIF vif1 = Mockito.mock(VIF.class); |
| final VIF vif2 = Mockito.mock(VIF.class); |
| |
| final MigrateWithStorageSendCommand migrateStorageCommand = new MigrateWithStorageSendCommand(vmSpec, volumeToSr, nicToNetwork, token); |
| |
| final CitrixRequestWrapper wrapper = CitrixRequestWrapper.getInstance(); |
| assertNotNull(wrapper); |
| |
| when(xenServer610Resource.getConnection()).thenReturn(conn); |
| when(vmSpec.getName()).thenReturn(vmName); |
| |
| when(volume1.getPath()).thenReturn(path); |
| when(volume2.getPath()).thenReturn(path); |
| |
| when(nic1.getMac()).thenReturn(mac); |
| when(nic2.getMac()).thenReturn(mac); |
| |
| when(xenServer610Resource.getVDIbyUuid(conn, volume1.getPath())).thenReturn(vdi1); |
| when(xenServer610Resource.getVDIbyUuid(conn, volume2.getPath())).thenReturn(vdi2); |
| |
| try { |
| when(xenServer610Resource.getVifByMac(conn, null, nic1.getMac())).thenReturn(vif1); |
| when(xenServer610Resource.getVifByMac(conn, null, nic2.getMac())).thenReturn(vif2); |
| } catch (final XenAPIException e) { |
| fail(e.getMessage()); |
| } catch (final XmlRpcException e) { |
| fail(e.getMessage()); |
| } |
| |
| final Answer answer = wrapper.execute(migrateStorageCommand, xenServer610Resource); |
| |
| verify(xenServer610Resource, times(1)).getConnection(); |
| |
| try { |
| verify(xenServer610Resource, times(2)).getVDIbyUuid(conn, volume1.getPath()); |
| verify(xenServer610Resource, times(2)).getVifByMac(conn, null, nic1.getMac()); |
| } catch (final XenAPIException e) { |
| fail(e.getMessage()); |
| } catch (final XmlRpcException e) { |
| fail(e.getMessage()); |
| } |
| |
| assertFalse(answer.getResult()); |
| } |
| |
| @Test |
| public void testMigrateWithStorageSendCommandSRException() { |
| final String vmName = "small"; |
| |
| final Connection conn = Mockito.mock(Connection.class); |
| final VirtualMachineTO vmSpec = Mockito.mock(VirtualMachineTO.class); |
| |
| final VolumeTO volume1 = Mockito.mock(VolumeTO.class); |
| final VolumeTO volume2 = Mockito.mock(VolumeTO.class); |
| |
| final List<Pair<VolumeTO, Object>> volumeToSr = new ArrayList<Pair<VolumeTO, Object>>(); |
| volumeToSr.add(new Pair<VolumeTO, Object>(volume1, new String("a"))); |
| volumeToSr.add(new Pair<VolumeTO, Object>(volume2, new String("b"))); |
| |
| final List<Pair<NicTO, Object>> nicToNetwork = new ArrayList<Pair<NicTO, Object>>(); |
| final Map<String, String> token = new HashMap<String, String>(); |
| |
| final MigrateWithStorageSendCommand migrateStorageCommand = new MigrateWithStorageSendCommand(vmSpec, volumeToSr, nicToNetwork, token); |
| |
| final CitrixRequestWrapper wrapper = CitrixRequestWrapper.getInstance(); |
| assertNotNull(wrapper); |
| |
| when(xenServer610Resource.getConnection()).thenReturn(conn); |
| when(vmSpec.getName()).thenReturn(vmName); |
| |
| final Answer answer = wrapper.execute(migrateStorageCommand, xenServer610Resource); |
| |
| verify(xenServer610Resource, times(1)).getConnection(); |
| |
| assertFalse(answer.getResult()); |
| } |
| |
| @Test |
| public void testMigrateWithStorageSendCommandNetException() { |
| final String vmName = "small"; |
| final String path = "/"; |
| |
| final Connection conn = Mockito.mock(Connection.class); |
| final VirtualMachineTO vmSpec = Mockito.mock(VirtualMachineTO.class); |
| |
| final VolumeTO volume1 = Mockito.mock(VolumeTO.class); |
| final VolumeTO volume2 = Mockito.mock(VolumeTO.class); |
| |
| final SR sr1 = Mockito.mock(SR.class); |
| final SR sr2 = Mockito.mock(SR.class); |
| |
| final VDI vdi1 = Mockito.mock(VDI.class); |
| final VDI vdi2 = Mockito.mock(VDI.class); |
| |
| final NicTO nic1 = Mockito.mock(NicTO.class); |
| final NicTO nic2 = Mockito.mock(NicTO.class); |
| |
| Gson gson = new Gson(); |
| final List<Pair<VolumeTO, Object>> volumeToSr = new ArrayList<Pair<VolumeTO, Object>>(); |
| volumeToSr.add(new Pair<VolumeTO, Object>(volume1, sr1)); |
| volumeToSr.add(new Pair<VolumeTO, Object>(volume2, sr2)); |
| |
| final List<Pair<NicTO, Object>> nicToNetwork = new ArrayList<Pair<NicTO, Object>>(); |
| nicToNetwork.add(new Pair<NicTO, Object>(nic1, new String("a"))); |
| nicToNetwork.add(new Pair<NicTO, Object>(nic2, new String("b"))); |
| |
| final Map<String, String> token = new HashMap<String, String>(); |
| |
| final MigrateWithStorageSendCommand migrateStorageCommand = new MigrateWithStorageSendCommand(vmSpec, volumeToSr, nicToNetwork, token); |
| |
| final CitrixRequestWrapper wrapper = CitrixRequestWrapper.getInstance(); |
| assertNotNull(wrapper); |
| |
| when(xenServer610Resource.getConnection()).thenReturn(conn); |
| when(vmSpec.getName()).thenReturn(vmName); |
| |
| when(volume1.getPath()).thenReturn(path); |
| when(volume2.getPath()).thenReturn(path); |
| |
| when(xenServer610Resource.getVDIbyUuid(conn, volume1.getPath())).thenReturn(vdi1); |
| when(xenServer610Resource.getVDIbyUuid(conn, volume2.getPath())).thenReturn(vdi2); |
| |
| final Answer answer = wrapper.execute(migrateStorageCommand, xenServer610Resource); |
| |
| verify(xenServer610Resource, times(1)).getConnection(); |
| |
| assertFalse(answer.getResult()); |
| } |
| |
| @Test |
| public void testMigrateWithStorageCompleteCommand() { |
| final String vmName = "small"; |
| final String uuid = "206b21a7-c6ec-40e2-b5e2-f861b9612f04"; |
| |
| final Connection conn = Mockito.mock(Connection.class); |
| final XsHost xsHost = Mockito.mock(XsHost.class); |
| |
| final VirtualMachineTO vm = Mockito.mock(VirtualMachineTO.class); |
| |
| final MigrateWithStorageCompleteCommand createStorageCommand = new MigrateWithStorageCompleteCommand(vm); |
| |
| final CitrixRequestWrapper wrapper = CitrixRequestWrapper.getInstance(); |
| assertNotNull(wrapper); |
| |
| when(xenServer610Resource.getConnection()).thenReturn(conn); |
| when(vm.getName()).thenReturn(vmName); |
| when(xenServer610Resource.getHost()).thenReturn(xsHost); |
| when(xsHost.getUuid()).thenReturn(uuid); |
| |
| final Answer answer = wrapper.execute(createStorageCommand, xenServer610Resource); |
| |
| verify(xenServer610Resource, times(1)).getConnection(); |
| |
| assertFalse(answer.getResult()); |
| } |
| |
| @Test |
| public void testXenServer610MigrateVolumeCommandWrapper() { |
| final String uuid = "206b21a7-c6ec-40e2-b5e2-f861b9612f04"; |
| |
| final Connection conn = Mockito.mock(Connection.class); |
| final SR destinationPool = Mockito.mock(SR.class); |
| final VDI srcVolume = Mockito.mock(VDI.class); |
| final Task task = Mockito.mock(Task.class); |
| |
| final long volumeId = 1l; |
| final String volumePath = "206b21a7-c6ec-40e2-b5e2-f861b9612f04"; |
| final StoragePool pool = Mockito.mock(StoragePool.class); |
| final int timeout = 120; |
| |
| final Map<String, String> other = new HashMap<String, String>(); |
| other.put("live", "true"); |
| |
| final MigrateVolumeCommand createStorageCommand = new MigrateVolumeCommand(volumeId, volumePath, pool, timeout); |
| |
| final CitrixRequestWrapper wrapper = CitrixRequestWrapper.getInstance(); |
| assertNotNull(wrapper); |
| |
| when(xenServer610Resource.getConnection()).thenReturn(conn); |
| when(pool.getUuid()).thenReturn(uuid); |
| when(xenServer610Resource.getStorageRepository(conn, uuid)).thenReturn(destinationPool); |
| when(xenServer610Resource.getVDIbyUuid(conn, volumePath)).thenReturn(srcVolume); |
| |
| try { |
| when(srcVolume.poolMigrateAsync(conn, destinationPool, other)).thenReturn(task); |
| } catch (final BadServerResponse e) { |
| fail(e.getMessage()); |
| } catch (final XenAPIException e) { |
| fail(e.getMessage()); |
| } catch (final XmlRpcException e) { |
| fail(e.getMessage()); |
| } |
| |
| when(xenServer610Resource.getMigrateWait()).thenReturn(120); |
| |
| final Answer answer = wrapper.execute(createStorageCommand, xenServer610Resource); |
| |
| verify(xenServer610Resource, times(1)).getConnection(); |
| |
| // try { |
| // verify(xenServer610Resource, times(1)).waitForTask(conn, task, 1000, timeout); |
| // verify(xenServer610Resource, times(1)).checkForSuccess(conn, task); |
| // } catch (final XenAPIException e) { |
| // fail(e.getMessage()); |
| // } catch (final XmlRpcException e) { |
| // fail(e.getMessage()); |
| // } catch (final TimeoutException e) { |
| // fail(e.getMessage()); |
| // } |
| |
| assertFalse(answer.getResult()); |
| } |
| } |