mirror of
https://github.com/apache/cloudstack.git
synced 2025-11-03 04:12:31 +01:00
CLOUDSTACK-9252: Mock application context for unit test
This commit is contained in:
parent
068fceae95
commit
c5677cf634
@ -112,6 +112,7 @@ import com.cloud.storage.StorageLayer;
|
|||||||
import com.cloud.utils.FileUtil;
|
import com.cloud.utils.FileUtil;
|
||||||
import com.cloud.utils.NumbersUtil;
|
import com.cloud.utils.NumbersUtil;
|
||||||
import com.cloud.utils.Pair;
|
import com.cloud.utils.Pair;
|
||||||
|
import com.cloud.utils.component.ComponentContext;
|
||||||
import com.cloud.utils.component.ManagerBase;
|
import com.cloud.utils.component.ManagerBase;
|
||||||
import com.cloud.utils.concurrency.NamedThreadFactory;
|
import com.cloud.utils.concurrency.NamedThreadFactory;
|
||||||
import com.cloud.utils.db.DB;
|
import com.cloud.utils.db.DB;
|
||||||
@ -200,10 +201,12 @@ public class VmwareManagerImpl extends ManagerBase implements VmwareManager, Vmw
|
|||||||
|
|
||||||
private final ScheduledExecutorService _hostScanScheduler = Executors.newScheduledThreadPool(1, new NamedThreadFactory("Vmware-Host-Scan"));
|
private final ScheduledExecutorService _hostScanScheduler = Executors.newScheduledThreadPool(1, new NamedThreadFactory("Vmware-Host-Scan"));
|
||||||
|
|
||||||
|
private ApplicationContext applicationContext;
|
||||||
|
|
||||||
public VmwareManagerImpl() {
|
public VmwareManagerImpl() {
|
||||||
_storageMgr = new VmwareStorageManagerImpl(this);
|
applicationContext = ComponentContext.getApplicationContext();
|
||||||
ApplicationContext applicationContext = com.cloud.utils.component.ComponentContext.getApplicationContext();
|
|
||||||
imageStoreDetailsUtil = applicationContext.getBean("imageStoreDetailsUtil", ImageStoreDetailsUtil.class);
|
imageStoreDetailsUtil = applicationContext.getBean("imageStoreDetailsUtil", ImageStoreDetailsUtil.class);
|
||||||
|
_storageMgr = new VmwareStorageManagerImpl(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@ -38,6 +38,8 @@ import org.mockito.Matchers;
|
|||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.springframework.context.ApplicationContext;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.ComponentScan;
|
import org.springframework.context.annotation.ComponentScan;
|
||||||
import org.springframework.context.annotation.ComponentScan.Filter;
|
import org.springframework.context.annotation.ComponentScan.Filter;
|
||||||
@ -54,8 +56,6 @@ import org.apache.cloudstack.api.command.admin.zone.RemoveVmwareDcCmd;
|
|||||||
import org.apache.cloudstack.context.CallContext;
|
import org.apache.cloudstack.context.CallContext;
|
||||||
import org.apache.cloudstack.engine.subsystem.api.storage.DataStoreManager;
|
import org.apache.cloudstack.engine.subsystem.api.storage.DataStoreManager;
|
||||||
import org.apache.cloudstack.framework.config.dao.ConfigurationDao;
|
import org.apache.cloudstack.framework.config.dao.ConfigurationDao;
|
||||||
import org.apache.cloudstack.storage.datastore.db.ImageStoreDao;
|
|
||||||
import org.apache.cloudstack.storage.datastore.db.ImageStoreDetailsDao;
|
|
||||||
import org.apache.cloudstack.test.utils.SpringUtils;
|
import org.apache.cloudstack.test.utils.SpringUtils;
|
||||||
|
|
||||||
import com.cloud.agent.AgentManager;
|
import com.cloud.agent.AgentManager;
|
||||||
@ -101,6 +101,7 @@ import com.cloud.vm.dao.UserVmDao;
|
|||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
@ContextConfiguration(loader = AnnotationConfigContextLoader.class)
|
@ContextConfiguration(loader = AnnotationConfigContextLoader.class)
|
||||||
|
@PrepareForTest({ComponentContext.class, ApplicationContext.class})
|
||||||
public class VmwareDatacenterApiUnitTest {
|
public class VmwareDatacenterApiUnitTest {
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
@ -133,9 +134,6 @@ public class VmwareDatacenterApiUnitTest {
|
|||||||
@Inject
|
@Inject
|
||||||
AccountManager _acctMgr;
|
AccountManager _acctMgr;
|
||||||
|
|
||||||
@Inject
|
|
||||||
ImageStoreDetailsUtil imageStoreDetailsUtil;
|
|
||||||
|
|
||||||
long zoneId;
|
long zoneId;
|
||||||
long podId;
|
long podId;
|
||||||
long clusterId;
|
long clusterId;
|
||||||
@ -163,6 +161,13 @@ public class VmwareDatacenterApiUnitTest {
|
|||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public static void setUp() throws ConfigurationException {
|
public static void setUp() throws ConfigurationException {
|
||||||
|
ComponentContext ctx = new ComponentContext();
|
||||||
|
ImageStoreDetailsUtil imgSDUtil = Mockito.mock(ImageStoreDetailsUtil.class);
|
||||||
|
Mockito.when(imgSDUtil.getNfsVersion(Mockito.anyLong())).thenReturn("3");
|
||||||
|
Mockito.when(imgSDUtil.getNfsVersionByUuid(Mockito.anyString())).thenReturn("3");
|
||||||
|
ApplicationContext appCtx = Mockito.mock(ApplicationContext.class);
|
||||||
|
Mockito.when(appCtx.getBean(Mockito.anyString(), Mockito.any(ImageStoreDetailsUtil.class))).thenReturn(imgSDUtil);
|
||||||
|
ctx.setApplicationContext(appCtx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
@ -230,8 +235,6 @@ public class VmwareDatacenterApiUnitTest {
|
|||||||
Mockito.when(addCmd.getPassword()).thenReturn(password);
|
Mockito.when(addCmd.getPassword()).thenReturn(password);
|
||||||
Mockito.when(addCmd.getName()).thenReturn(vmwareDcName);
|
Mockito.when(addCmd.getName()).thenReturn(vmwareDcName);
|
||||||
Mockito.when(removeCmd.getZoneId()).thenReturn(1L);
|
Mockito.when(removeCmd.getZoneId()).thenReturn(1L);
|
||||||
Mockito.when(imageStoreDetailsUtil.getNfsVersion(Mockito.anyLong())).thenReturn(null);
|
|
||||||
Mockito.when(imageStoreDetailsUtil.getNfsVersionByUuid(Mockito.anyString())).thenReturn(null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
@ -439,21 +442,6 @@ public class VmwareDatacenterApiUnitTest {
|
|||||||
return Mockito.mock(DataStoreManager.class);
|
return Mockito.mock(DataStoreManager.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
|
||||||
public ImageStoreDetailsUtil imageStoreDetailsUtil() {
|
|
||||||
return Mockito.mock(ImageStoreDetailsUtil.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public ImageStoreDao imageStoreDao() {
|
|
||||||
return Mockito.mock(ImageStoreDao.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public ImageStoreDetailsDao imageStoreDetailsDao() {
|
|
||||||
return Mockito.mock(ImageStoreDetailsDao.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class Library implements TypeFilter {
|
public static class Library implements TypeFilter {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user