blob: 686089b9e34108264018b49506f9c8c27b1e3e1c [file] [log] [blame]
// 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.capacity;
import static org.mockito.Matchers.anyLong;
import static org.mockito.Matchers.eq;
import static org.mockito.Matchers.isA;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import org.junit.Assert;
import org.junit.Test;
import com.cloud.capacity.dao.CapacityDao;
import com.cloud.dc.ClusterDetailsDao;
import com.cloud.dc.ClusterDetailsVO;
import com.cloud.service.ServiceOfferingVO;
import com.cloud.service.dao.ServiceOfferingDao;
import com.cloud.vm.VirtualMachine;
public class CapacityManagerTest {
CapacityDao CDao = mock(CapacityDao.class);
ServiceOfferingDao SOfferingDao = mock(ServiceOfferingDao.class);
ClusterDetailsDao ClusterDetailsDao = mock(com.cloud.dc.ClusterDetailsDao.class);
CapacityManagerImpl capMgr;
private ServiceOfferingVO svo = mock(ServiceOfferingVO.class);
private CapacityVO cvoCpu = mock(CapacityVO.class);
private CapacityVO cvoRam = mock(CapacityVO.class);
private VirtualMachine vm = mock(VirtualMachine.class);
private ClusterDetailsVO clusterDetailCpu = mock(ClusterDetailsVO.class);
private ClusterDetailsVO clusterDetailRam = mock(ClusterDetailsVO.class);
public CapacityManagerImpl setUp() {
CapacityManagerImpl capMgr = new CapacityManagerImpl();
capMgr._clusterDetailsDao = ClusterDetailsDao;
capMgr._capacityDao = CDao;
capMgr._offeringsDao = SOfferingDao;
return capMgr;
}
@Test
public void allocateCapacityTest() {
capMgr = setUp();
when(vm.getHostId()).thenReturn(1l);
when(vm.getServiceOfferingId()).thenReturn(2l);
when(SOfferingDao.findById(anyLong(), anyLong())).thenReturn(svo);
when(CDao.findByHostIdType(anyLong(), eq(Capacity.CAPACITY_TYPE_CPU))).thenReturn(cvoCpu);
when(CDao.findByHostIdType(anyLong(), eq(Capacity.CAPACITY_TYPE_MEMORY))).thenReturn(cvoRam);
when(cvoCpu.getUsedCapacity()).thenReturn(500l);
when(cvoCpu.getTotalCapacity()).thenReturn(2000l);
when(cvoRam.getUsedCapacity()).thenReturn(3000l);
when(cvoRam.getTotalCapacity()).thenReturn((long)1024 * 1024 * 1024);
when(svo.getCpu()).thenReturn(500);
when(svo.getRamSize()).thenReturn(512);
when(cvoCpu.getReservedCapacity()).thenReturn(0l);
when(cvoRam.getReservedCapacity()).thenReturn(0l);
when(clusterDetailRam.getValue()).thenReturn("1.5");
when(clusterDetailCpu.getValue()).thenReturn("2");
when(CDao.update(anyLong(), isA(CapacityVO.class))).thenReturn(true);
boolean hasCapacity = capMgr.checkIfHostHasCapacity(1l, 500, 1024 * 1024 * 1024, false, 2, 2, false);
Assert.assertTrue(hasCapacity);
}
}