mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
CLOUDSTACK-9963 Root Disk controller value is changing while migrating VM
This commit is contained in:
parent
a6b41c10c6
commit
48fa20698e
@ -1518,7 +1518,7 @@ public class VmwareResource implements StoragePoolResource, ServerResource, Vmwa
|
||||
} else if (DiskControllerType.getType(scsiDiskController) == DiskControllerType.buslogic) {
|
||||
vmMo.ensureBusLogicDeviceControllers(requiredNumScsiControllers, availableBusNum);
|
||||
} else if (DiskControllerType.getType(scsiDiskController) == DiskControllerType.lsilogic) {
|
||||
vmMo.ensureScsiDeviceControllers(requiredNumScsiControllers, availableBusNum);
|
||||
vmMo.ensureLsiLogicDeviceControllers(requiredNumScsiControllers, availableBusNum);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -2220,7 +2220,48 @@ public class VirtualMachineMO extends BaseMO {
|
||||
|
||||
if(devices != null && devices.size() > 0) {
|
||||
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();
|
||||
}
|
||||
}
|
||||
|
||||
@ -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());
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user