-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Refactor system VM default network creation #1360
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -17,15 +17,33 @@ | |
|
|
||
| package com.cloud.consoleproxy; | ||
|
|
||
| import static org.mockito.AdditionalMatchers.not; | ||
| import static org.mockito.Matchers.any; | ||
| import static org.mockito.Matchers.anyLong; | ||
| import static org.mockito.Matchers.eq; | ||
| import static org.mockito.Mockito.mock; | ||
| import static org.mockito.Mockito.when; | ||
|
|
||
| import java.util.Collections; | ||
|
|
||
| import org.apache.log4j.Logger; | ||
| import org.junit.Assert; | ||
| import org.junit.Before; | ||
| import org.junit.Test; | ||
| import org.mockito.Mock; | ||
| import org.mockito.Mockito; | ||
| import org.mockito.MockitoAnnotations; | ||
| import org.springframework.test.util.ReflectionTestUtils; | ||
|
|
||
| import com.cloud.dc.DataCenterVO; | ||
| import com.cloud.dc.DataCenter; | ||
| import com.cloud.dc.DataCenter.NetworkType; | ||
| import com.cloud.dc.dao.DataCenterDao; | ||
| import com.cloud.network.Networks.TrafficType; | ||
| import com.cloud.network.dao.NetworkDao; | ||
| import com.cloud.network.dao.NetworkVO; | ||
| import com.cloud.utils.db.GlobalLock; | ||
| import com.cloud.utils.exception.CloudRuntimeException; | ||
| import com.cloud.vm.ConsoleProxyVO; | ||
|
|
||
| public class ConsoleProxyManagerTest { | ||
|
|
@@ -37,13 +55,22 @@ public class ConsoleProxyManagerTest { | |
| @Mock | ||
| ConsoleProxyVO proxyVO; | ||
| @Mock | ||
| DataCenterDao _dcDao; | ||
| @Mock | ||
| NetworkDao _networkDao; | ||
| @Mock | ||
| ConsoleProxyManagerImpl cpvmManager; | ||
|
|
||
| @Before | ||
| public void setup() throws Exception { | ||
| MockitoAnnotations.initMocks(this); | ||
| ReflectionTestUtils.setField(cpvmManager, "_allocProxyLock", globalLock); | ||
| ReflectionTestUtils.setField(cpvmManager, "_dcDao", _dcDao); | ||
| ReflectionTestUtils.setField(cpvmManager, "_networkDao", _networkDao); | ||
| Mockito.doCallRealMethod().when(cpvmManager).expandPool(Mockito.anyLong(), Mockito.anyObject()); | ||
| Mockito.doCallRealMethod().when(cpvmManager).getDefaultNetworkForCreation(Mockito.any(DataCenter.class)); | ||
| Mockito.doCallRealMethod().when(cpvmManager).getDefaultNetworkForAdvancedZone(Mockito.any(DataCenter.class)); | ||
| Mockito.doCallRealMethod().when(cpvmManager).getDefaultNetworkForBasicZone(Mockito.any(DataCenter.class)); | ||
| } | ||
|
|
||
| @Test | ||
|
|
@@ -87,4 +114,136 @@ public void testExisingCPVMStartFailure() throws Exception { | |
|
|
||
| cpvmManager.expandPool(new Long(1), new Object()); | ||
| } | ||
|
|
||
| @Test | ||
| public void getDefaultNetworkForAdvancedNonSG() { | ||
| DataCenterVO dc = mock(DataCenterVO.class); | ||
| when(dc.getNetworkType()).thenReturn(NetworkType.Advanced); | ||
| when(dc.isSecurityGroupEnabled()).thenReturn(false); | ||
|
|
||
| when(_dcDao.findById(Mockito.anyLong())).thenReturn(dc); | ||
|
|
||
| NetworkVO network = Mockito.mock(NetworkVO.class); | ||
| NetworkVO badNetwork = Mockito.mock(NetworkVO.class); | ||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), eq(TrafficType.Public))) | ||
| .thenReturn(Collections.singletonList(network)); | ||
|
|
||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), not(eq(TrafficType.Public)))) | ||
| .thenReturn(Collections.singletonList(badNetwork)); | ||
|
|
||
| when(_networkDao.listByZoneSecurityGroup(anyLong())) | ||
| .thenReturn(Collections.singletonList(badNetwork)); | ||
|
|
||
| NetworkVO returnedNetwork = cpvmManager.getDefaultNetworkForAdvancedZone(dc); | ||
|
|
||
| Assert.assertNotNull(returnedNetwork); | ||
| Assert.assertEquals(network, returnedNetwork); | ||
| Assert.assertNotEquals(badNetwork, returnedNetwork); | ||
| } | ||
|
|
||
| @Test | ||
| public void getDefaultNetworkForAdvancedSG() { | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't see any security group related check in getDefaultNetworkForBasicZone(). Why do you need tests for SG/non-SG in case basic zone?
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. To cover all scenarios. Even if there is no security group-related checks in
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @ProjectMoon The unit tests getDefaultNetworkForBasicNonSG() and getDefaultNetworkForBasicSG() are same since SG has no impact on the method being tested. |
||
| DataCenterVO dc = Mockito.mock(DataCenterVO.class); | ||
| when(dc.getNetworkType()).thenReturn(NetworkType.Advanced); | ||
| when(dc.isSecurityGroupEnabled()).thenReturn(true); | ||
|
|
||
| when(_dcDao.findById(Mockito.anyLong())).thenReturn(dc); | ||
|
|
||
| NetworkVO network = Mockito.mock(NetworkVO.class); | ||
| NetworkVO badNetwork = Mockito.mock(NetworkVO.class); | ||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), any(TrafficType.class))) | ||
| .thenReturn(Collections.singletonList(badNetwork)); | ||
|
|
||
| when(_networkDao.listByZoneSecurityGroup(anyLong())) | ||
| .thenReturn(Collections.singletonList(network)); | ||
|
|
||
| NetworkVO returnedNetwork = cpvmManager.getDefaultNetworkForAdvancedZone(dc); | ||
|
|
||
| Assert.assertEquals(network, returnedNetwork); | ||
| Assert.assertNotEquals(badNetwork, returnedNetwork); | ||
| } | ||
|
|
||
| @Test | ||
| public void getDefaultNetworkForBasicNonSG() { | ||
| DataCenterVO dc = Mockito.mock(DataCenterVO.class); | ||
| when(dc.getNetworkType()).thenReturn(NetworkType.Basic); | ||
| when(dc.isSecurityGroupEnabled()).thenReturn(false); | ||
|
|
||
| when(_dcDao.findById(Mockito.anyLong())).thenReturn(dc); | ||
|
|
||
| NetworkVO network = Mockito.mock(NetworkVO.class); | ||
| NetworkVO badNetwork = Mockito.mock(NetworkVO.class); | ||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), eq(TrafficType.Guest))) | ||
| .thenReturn(Collections.singletonList(network)); | ||
|
|
||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), not(eq(TrafficType.Guest)))) | ||
| .thenReturn(Collections.singletonList(badNetwork)); | ||
|
|
||
| NetworkVO returnedNetwork = cpvmManager.getDefaultNetworkForBasicZone(dc); | ||
| Assert.assertNotNull(returnedNetwork); | ||
| Assert.assertEquals(network, returnedNetwork); | ||
| Assert.assertNotEquals(badNetwork, returnedNetwork); | ||
| } | ||
|
|
||
| @Test | ||
| public void getDefaultNetworkForBasicSG() { | ||
| DataCenterVO dc = Mockito.mock(DataCenterVO.class); | ||
| when(dc.getNetworkType()).thenReturn(NetworkType.Basic); | ||
| when(dc.isSecurityGroupEnabled()).thenReturn(true); | ||
|
|
||
| when(_dcDao.findById(Mockito.anyLong())).thenReturn(dc); | ||
|
|
||
| NetworkVO network = Mockito.mock(NetworkVO.class); | ||
| NetworkVO badNetwork = Mockito.mock(NetworkVO.class); | ||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), eq(TrafficType.Guest))) | ||
| .thenReturn(Collections.singletonList(network)); | ||
|
|
||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), not(eq(TrafficType.Guest)))) | ||
| .thenReturn(Collections.singletonList(badNetwork)); | ||
|
|
||
| NetworkVO returnedNetwork = cpvmManager.getDefaultNetworkForBasicZone(dc); | ||
|
|
||
| Assert.assertNotNull(returnedNetwork); | ||
| Assert.assertEquals(network, returnedNetwork); | ||
| Assert.assertNotEquals(badNetwork, returnedNetwork); | ||
| } | ||
|
|
||
| //also test invalid input | ||
| @Test(expected=CloudRuntimeException.class) | ||
| public void getDefaultNetworkForBasicSGWrongZoneType() { | ||
| DataCenterVO dc = Mockito.mock(DataCenterVO.class); | ||
| when(dc.getNetworkType()).thenReturn(NetworkType.Advanced); | ||
| when(dc.isSecurityGroupEnabled()).thenReturn(true); | ||
|
|
||
| when(_dcDao.findById(Mockito.anyLong())).thenReturn(dc); | ||
|
|
||
| NetworkVO network = Mockito.mock(NetworkVO.class); | ||
| NetworkVO badNetwork = Mockito.mock(NetworkVO.class); | ||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), eq(TrafficType.Guest))) | ||
| .thenReturn(Collections.singletonList(network)); | ||
|
|
||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), not(eq(TrafficType.Guest)))) | ||
| .thenReturn(Collections.singletonList(badNetwork)); | ||
|
|
||
| cpvmManager.getDefaultNetworkForBasicZone(dc); | ||
| } | ||
|
|
||
| @Test(expected=CloudRuntimeException.class) | ||
| public void getDefaultNetworkForAdvancedWrongZoneType() { | ||
| DataCenterVO dc = Mockito.mock(DataCenterVO.class); | ||
| when(dc.getNetworkType()).thenReturn(NetworkType.Basic); | ||
| when(dc.isSecurityGroupEnabled()).thenReturn(true); | ||
|
|
||
| when(_dcDao.findById(Mockito.anyLong())).thenReturn(dc); | ||
|
|
||
| NetworkVO network = Mockito.mock(NetworkVO.class); | ||
| NetworkVO badNetwork = Mockito.mock(NetworkVO.class); | ||
| when(_networkDao.listByZoneAndTrafficType(anyLong(), any(TrafficType.class))) | ||
| .thenReturn(Collections.singletonList(badNetwork)); | ||
|
|
||
| when(_networkDao.listByZoneSecurityGroup(anyLong())) | ||
| .thenReturn(Collections.singletonList(network)); | ||
|
|
||
| cpvmManager.getDefaultNetworkForAdvancedZone(dc); | ||
| } | ||
| } | ||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@ProjectMoon Could you please create a documentation and a test case for this method ("com.cloud.consoleproxy.ConsoleProxyManagerImpl.getDefaultNetworkForCreation(DataCenter)")?