CLOUDSTACK-9963 Root Disk controller value is changing while migrating VM

This commit is contained in:
vedulasantosh 2017-06-15 11:37:58 +05:30 committed by Sateesh Chodapuneedi
parent a6b41c10c6
commit 48fa20698e
3 changed files with 163 additions and 2 deletions

View File

@ -1518,7 +1518,7 @@ public class VmwareResource implements StoragePoolResource, ServerResource, Vmwa
} else if (DiskControllerType.getType(scsiDiskController) == DiskControllerType.buslogic) { } else if (DiskControllerType.getType(scsiDiskController) == DiskControllerType.buslogic) {
vmMo.ensureBusLogicDeviceControllers(requiredNumScsiControllers, availableBusNum); vmMo.ensureBusLogicDeviceControllers(requiredNumScsiControllers, availableBusNum);
} else if (DiskControllerType.getType(scsiDiskController) == DiskControllerType.lsilogic) { } else if (DiskControllerType.getType(scsiDiskController) == DiskControllerType.lsilogic) {
vmMo.ensureScsiDeviceControllers(requiredNumScsiControllers, availableBusNum); vmMo.ensureLsiLogicDeviceControllers(requiredNumScsiControllers, availableBusNum);
} }
} }

View File

@ -2220,7 +2220,48 @@ public class VirtualMachineMO extends BaseMO {
if(devices != null && devices.size() > 0) { if(devices != null && devices.size() > 0) {
for(VirtualDevice device : devices) { for(VirtualDevice device : devices) {
if(device instanceof VirtualLsiLogicController) { if(device instanceof VirtualSCSIController) {
return device.getKey();
}
}
}
return -1;
}
public void ensureLsiLogicDeviceControllers(int count, int availableBusNum) throws Exception {
int scsiControllerKey = getLsiLogicDeviceControllerKeyNoException();
if (scsiControllerKey < 0) {
VirtualMachineConfigSpec vmConfig = new VirtualMachineConfigSpec();
int busNum = availableBusNum;
while (busNum < count) {
VirtualLsiLogicController scsiController = new VirtualLsiLogicController();
scsiController.setSharedBus(VirtualSCSISharing.NO_SHARING);
scsiController.setBusNumber(busNum);
scsiController.setKey(busNum - VmwareHelper.MAX_SCSI_CONTROLLER_COUNT);
VirtualDeviceConfigSpec scsiControllerSpec = new VirtualDeviceConfigSpec();
scsiControllerSpec.setDevice(scsiController);
scsiControllerSpec.setOperation(VirtualDeviceConfigSpecOperation.ADD);
vmConfig.getDeviceChange().add(scsiControllerSpec);
busNum++;
}
if (configureVm(vmConfig)) {
throw new Exception("Unable to add Lsi Logic controllers to the VM " + getName());
} else {
s_logger.info("Successfully added " + count + " LsiLogic Parallel SCSI controllers.");
}
}
}
private int getLsiLogicDeviceControllerKeyNoException() throws Exception {
List<VirtualDevice> devices = (List<VirtualDevice>)_context.getVimClient().
getDynamicProperty(_mor, "config.hardware.device");
if (devices != null && devices.size() > 0) {
for (VirtualDevice device : devices) {
if (device instanceof VirtualLsiLogicController) {
return device.getKey(); return device.getKey();
} }
} }

View File

@ -0,0 +1,120 @@
// 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.vmware.mo;
import com.cloud.hypervisor.vmware.util.VmwareClient;
import com.cloud.hypervisor.vmware.util.VmwareContext;
import com.vmware.vim25.ManagedObjectReference;
import com.vmware.vim25.VirtualDevice;
import com.vmware.vim25.VirtualLsiLogicController;
import com.vmware.vim25.VirtualLsiLogicSASController;
import com.vmware.vim25.VirtualSCSIController;
import com.vmware.vim25.VirtualSCSISharing;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.mockito.runners.MockitoJUnitRunner;
import java.util.ArrayList;
import java.util.List;
import static org.junit.Assert.fail;
import static org.mockito.Matchers.any;
import static org.mockito.Mockito.when;
@RunWith(MockitoJUnitRunner.class)
public class VirtualMachineMOTest {
@Mock
VmwareContext context;
@Mock
VmwareClient client;
@Mock
ManagedObjectReference mor;
VirtualMachineMO vmMo;
private List<VirtualDevice> getVirtualScSiDeviceList(Class<?> cls) {
List<VirtualDevice> deviceList = new ArrayList<>();
try {
VirtualSCSIController scsiController = (VirtualSCSIController)cls.newInstance();
scsiController.setSharedBus(VirtualSCSISharing.NO_SHARING);
scsiController.setBusNumber(0);
scsiController.setKey(1);
deviceList.add(scsiController);
}
catch (Exception ex) {
}
return deviceList;
}
@Before
public void setup() {
MockitoAnnotations.initMocks(this);
vmMo = new VirtualMachineMO(context, mor);
when(context.getVimClient()).thenReturn(client);
}
@BeforeClass
public static void setUpBeforeClass() throws Exception {
}
@AfterClass
public static void tearDownAfterClass() throws Exception {
}
@Before
public void setUp() throws Exception {
}
@After
public void tearDown() throws Exception {
}
@Test
public void testEnsureScsiDeviceController() {
try {
when(client.getDynamicProperty(any(ManagedObjectReference.class), any(String.class))).thenReturn(getVirtualScSiDeviceList(VirtualLsiLogicSASController.class));
vmMo.ensureScsiDeviceController();
}
catch (Exception e) {
fail("Received exception when success expected: " + e.getMessage());
}
}
@Test
public void TestEnsureLsiLogicDeviceControllers() {
try {
when(client.getDynamicProperty(any(ManagedObjectReference.class), any(String.class))).thenReturn(getVirtualScSiDeviceList(VirtualLsiLogicController.class));
vmMo.ensureLsiLogicDeviceControllers(1, 0);
}
catch (Exception e) {
fail("Received exception when success expected: " + e.getMessage());
}
}
}