mirror of
https://github.com/apache/cloudstack.git
synced 2025-11-03 04:12:31 +01:00
engine/orchestration: fix missing vm powerstate update vm state (#10407)
* engine/orchestration: fix missing vm powerstate update vm state Fixes #10406 VMs were not moving to Stopped state when PowerReportMissing is processed. Signed-off-by: Abhishek Kumar <abhishek.mrt22@gmail.com> * add unit tests Signed-off-by: Abhishek Kumar <abhishek.mrt22@gmail.com> * add license Signed-off-by: Abhishek Kumar <abhishek.mrt22@gmail.com> * add lenient Signed-off-by: Abhishek Kumar <abhishek.mrt22@gmail.com> --------- Signed-off-by: Abhishek Kumar <abhishek.mrt22@gmail.com>
This commit is contained in:
parent
08ad1c70ba
commit
e8ac477e9f
@ -77,19 +77,19 @@ public class VirtualMachinePowerStateSyncImpl implements VirtualMachinePowerStat
|
|||||||
processReport(hostId, translatedInfo, force);
|
processReport(hostId, translatedInfo, force);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateAndPublishVmPowerStates(long hostId, Map<Long, VirtualMachine.PowerState> instancePowerStates,
|
protected void updateAndPublishVmPowerStates(long hostId, Map<Long, VirtualMachine.PowerState> instancePowerStates,
|
||||||
Date updateTime) {
|
Date updateTime) {
|
||||||
if (instancePowerStates.isEmpty()) {
|
if (instancePowerStates.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Set<Long> vmIds = instancePowerStates.keySet();
|
Set<Long> vmIds = instancePowerStates.keySet();
|
||||||
Map<Long, VirtualMachine.PowerState> notUpdated = _instanceDao.updatePowerState(instancePowerStates, hostId,
|
Map<Long, VirtualMachine.PowerState> notUpdated =
|
||||||
updateTime);
|
_instanceDao.updatePowerState(instancePowerStates, hostId, updateTime);
|
||||||
if (notUpdated.size() > vmIds.size()) {
|
if (notUpdated.size() > vmIds.size()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
for (Long vmId : vmIds) {
|
for (Long vmId : vmIds) {
|
||||||
if (!notUpdated.isEmpty() && !notUpdated.containsKey(vmId)) {
|
if (!notUpdated.containsKey(vmId)) {
|
||||||
logger.debug("VM state report is updated. {}, {}, power state: {}",
|
logger.debug("VM state report is updated. {}, {}, power state: {}",
|
||||||
() -> hostCache.get(hostId), () -> vmCache.get(vmId), () -> instancePowerStates.get(vmId));
|
() -> hostCache.get(hostId), () -> vmCache.get(vmId), () -> instancePowerStates.get(vmId));
|
||||||
_messageBus.publish(null, VirtualMachineManager.Topics.VM_POWER_STATE,
|
_messageBus.publish(null, VirtualMachineManager.Topics.VM_POWER_STATE,
|
||||||
|
|||||||
@ -0,0 +1,107 @@
|
|||||||
|
// 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.vm;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.cloudstack.framework.messagebus.MessageBus;
|
||||||
|
import org.apache.cloudstack.framework.messagebus.PublishScope;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.InjectMocks;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.Mockito;
|
||||||
|
import org.mockito.junit.MockitoJUnitRunner;
|
||||||
|
|
||||||
|
import com.cloud.host.HostVO;
|
||||||
|
import com.cloud.host.dao.HostDao;
|
||||||
|
import com.cloud.vm.dao.VMInstanceDao;
|
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class VirtualMachinePowerStateSyncImplTest {
|
||||||
|
@Mock
|
||||||
|
MessageBus messageBus;
|
||||||
|
@Mock
|
||||||
|
VMInstanceDao instanceDao;
|
||||||
|
@Mock
|
||||||
|
HostDao hostDao;
|
||||||
|
|
||||||
|
@InjectMocks
|
||||||
|
VirtualMachinePowerStateSyncImpl virtualMachinePowerStateSync = new VirtualMachinePowerStateSyncImpl();
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setup() {
|
||||||
|
Mockito.lenient().when(instanceDao.findById(Mockito.anyLong())).thenReturn(Mockito.mock(VMInstanceVO.class));
|
||||||
|
Mockito.lenient().when(hostDao.findById(Mockito.anyLong())).thenReturn(Mockito.mock(HostVO.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test_updateAndPublishVmPowerStates_emptyStates() {
|
||||||
|
virtualMachinePowerStateSync.updateAndPublishVmPowerStates(1L, new HashMap<>(), new Date());
|
||||||
|
Mockito.verify(instanceDao, Mockito.never()).updatePowerState(Mockito.anyMap(), Mockito.anyLong(),
|
||||||
|
Mockito.any(Date.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test_updateAndPublishVmPowerStates_moreNotUpdated() {
|
||||||
|
Map<Long, VirtualMachine.PowerState> powerStates = new HashMap<>();
|
||||||
|
powerStates.put(1L, VirtualMachine.PowerState.PowerOff);
|
||||||
|
Map<Long, VirtualMachine.PowerState> notUpdated = new HashMap<>(powerStates);
|
||||||
|
notUpdated.put(2L, VirtualMachine.PowerState.PowerOn);
|
||||||
|
Mockito.when(instanceDao.updatePowerState(Mockito.anyMap(), Mockito.anyLong(),
|
||||||
|
Mockito.any(Date.class))).thenReturn(notUpdated);
|
||||||
|
virtualMachinePowerStateSync.updateAndPublishVmPowerStates(1L, powerStates, new Date());
|
||||||
|
Mockito.verify(messageBus, Mockito.never()).publish(Mockito.nullable(String.class), Mockito.anyString(),
|
||||||
|
Mockito.any(PublishScope.class), Mockito.anyLong());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test_updateAndPublishVmPowerStates_allUpdated() {
|
||||||
|
Map<Long, VirtualMachine.PowerState> powerStates = new HashMap<>();
|
||||||
|
powerStates.put(1L, VirtualMachine.PowerState.PowerOff);
|
||||||
|
Mockito.when(instanceDao.updatePowerState(Mockito.anyMap(), Mockito.anyLong(),
|
||||||
|
Mockito.any(Date.class))).thenReturn(new HashMap<>());
|
||||||
|
virtualMachinePowerStateSync.updateAndPublishVmPowerStates(1L, powerStates, new Date());
|
||||||
|
Mockito.verify(messageBus, Mockito.times(1)).publish(null,
|
||||||
|
VirtualMachineManager.Topics.VM_POWER_STATE,
|
||||||
|
PublishScope.GLOBAL,
|
||||||
|
1L);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test_updateAndPublishVmPowerStates_partialUpdated() {
|
||||||
|
Map<Long, VirtualMachine.PowerState> powerStates = new HashMap<>();
|
||||||
|
powerStates.put(1L, VirtualMachine.PowerState.PowerOn);
|
||||||
|
powerStates.put(2L, VirtualMachine.PowerState.PowerOff);
|
||||||
|
Map<Long, VirtualMachine.PowerState> notUpdated = new HashMap<>();
|
||||||
|
notUpdated.put(2L, VirtualMachine.PowerState.PowerOff);
|
||||||
|
Mockito.when(instanceDao.updatePowerState(Mockito.anyMap(), Mockito.anyLong(),
|
||||||
|
Mockito.any(Date.class))).thenReturn(notUpdated);
|
||||||
|
virtualMachinePowerStateSync.updateAndPublishVmPowerStates(1L, powerStates, new Date());
|
||||||
|
Mockito.verify(messageBus, Mockito.times(1)).publish(null,
|
||||||
|
VirtualMachineManager.Topics.VM_POWER_STATE,
|
||||||
|
PublishScope.GLOBAL,
|
||||||
|
1L);
|
||||||
|
Mockito.verify(messageBus, Mockito.never()).publish(null,
|
||||||
|
VirtualMachineManager.Topics.VM_POWER_STATE,
|
||||||
|
PublishScope.GLOBAL,
|
||||||
|
2L);
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user