This is an automated email from the ASF dual-hosted git repository.

pearl11594 pushed a commit to branch nsx-add-unit-test-cov
in repository https://gitbox.apache.org/repos/asf/cloudstack.git


The following commit(s) were added to refs/heads/nsx-add-unit-test-cov by this 
push:
     new 6f80fc249a9 add more tests-1
6f80fc249a9 is described below

commit 6f80fc249a97b504be864ab0e9557a7436ddf192
Author: Pearl Dsilva <[email protected]>
AuthorDate: Thu Dec 21 09:56:53 2023 -0500

    add more tests-1
---
 .../network/router/CommandSetupHelperTest.java     | 113 +++++++++++++++++++++
 .../network/router/NetworkHelperImplTest.java      |  77 ++++++++++++++
 2 files changed, 190 insertions(+)

diff --git 
a/server/src/test/java/com/cloud/network/router/CommandSetupHelperTest.java 
b/server/src/test/java/com/cloud/network/router/CommandSetupHelperTest.java
index f03ae9d62b2..8f68e7b6793 100644
--- a/server/src/test/java/com/cloud/network/router/CommandSetupHelperTest.java
+++ b/server/src/test/java/com/cloud/network/router/CommandSetupHelperTest.java
@@ -17,20 +17,92 @@
 package com.cloud.network.router;
 
 import com.cloud.agent.api.routing.VmDataCommand;
+import com.cloud.agent.manager.Commands;
+import com.cloud.configuration.ConfigurationManager;
+import com.cloud.dc.DataCenter;
+import com.cloud.dc.DataCenterVO;
+import com.cloud.dc.VlanVO;
+import com.cloud.dc.dao.DataCenterDao;
+import com.cloud.dc.dao.VlanDao;
+import com.cloud.network.NetworkModel;
+import com.cloud.network.PublicIpAddress;
+import com.cloud.network.addr.PublicIp;
+import com.cloud.network.dao.IPAddressDao;
+import com.cloud.network.dao.IPAddressVO;
+import com.cloud.network.dao.NetworkDao;
+import com.cloud.network.dao.NetworkDetailsDao;
+import com.cloud.network.dao.NetworkVO;
+import com.cloud.network.guru.PublicNetworkGuru;
+import com.cloud.network.vpc.VpcVO;
+import com.cloud.network.vpc.dao.VpcDao;
+import com.cloud.offering.NetworkOffering;
+import com.cloud.offerings.NetworkOfferingVO;
+import com.cloud.offerings.dao.NetworkOfferingDao;
+import com.cloud.offerings.dao.NetworkOfferingDetailsDao;
+import com.cloud.utils.net.Ip;
+import com.cloud.vm.NicVO;
+import com.cloud.vm.VirtualMachine;
+import com.cloud.vm.dao.NicDao;
 import org.junit.Assert;
+import org.junit.Before;
 import org.junit.Test;
 import org.junit.runner.RunWith;
+import org.mockito.ArgumentMatchers;
 import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.Mockito;
 import org.mockito.junit.MockitoJUnitRunner;
+import org.springframework.test.util.ReflectionTestUtils;
 
 import java.util.ArrayList;
+import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
 
 @RunWith(MockitoJUnitRunner.class)
 public class CommandSetupHelperTest {
 
     @InjectMocks
     protected CommandSetupHelper commandSetupHelper = new CommandSetupHelper();
+    @Mock
+    NicDao nicDao;
+    @Mock
+    NetworkDao networkDao;
+    @Mock
+    IPAddressDao ipAddressDao;
+    @Mock
+    VlanDao vlanDao;
+    @Mock
+    NetworkModel networkModel;
+    @Mock
+    NetworkOfferingDao networkOfferingDao;
+    @Mock
+    ConfigurationManager configurationManager;
+    @Mock
+    NetworkOfferingDetailsDao networkOfferingDetailsDao;
+    @Mock
+    NetworkDetailsDao networkDetailsDao;
+    @Mock
+    VpcDao vpcDao;
+    @Mock
+    RouterControlHelper routerControlHelper;
+    @Mock
+    DataCenterDao dcDao;
+
+    @Before
+    public void setUp() {
+        ReflectionTestUtils.setField(commandSetupHelper, "_nicDao", nicDao);
+        ReflectionTestUtils.setField(commandSetupHelper, "_networkDao", 
networkDao);
+        ReflectionTestUtils.setField(commandSetupHelper, "_ipAddressDao", 
ipAddressDao);
+        ReflectionTestUtils.setField(commandSetupHelper, "_vlanDao", vlanDao);
+        ReflectionTestUtils.setField(commandSetupHelper, "_networkModel", 
networkModel);
+        ReflectionTestUtils.setField(commandSetupHelper, 
"_networkOfferingDao", networkOfferingDao);
+        ReflectionTestUtils.setField(commandSetupHelper, 
"networkOfferingDetailsDao", networkOfferingDetailsDao);
+        ReflectionTestUtils.setField(commandSetupHelper, "networkDetailsDao", 
networkDetailsDao);
+        ReflectionTestUtils.setField(commandSetupHelper, "_vpcDao", vpcDao);
+        ReflectionTestUtils.setField(commandSetupHelper, 
"_routerControlHelper", routerControlHelper);
+        ReflectionTestUtils.setField(commandSetupHelper, "_dcDao", dcDao);
+    }
 
     @Test
     public void testUserDataDetails() {
@@ -79,4 +151,45 @@ public class CommandSetupHelperTest {
         Assert.assertEquals("value1", metadataFile1[2]);
         Assert.assertEquals("value2", metadataFile2[2]);
     }
+
+    @Test
+    public void testCreateVpcAssociatePublicIP() {
+        VirtualRouter router = Mockito.mock(VirtualRouter.class);
+        Ip ip = new Ip("10.10.10.10");
+        IPAddressVO ipAddressVO = new IPAddressVO(ip, 1L, 0x0ac00000L, 2L, 
true);
+        VlanVO vlanVO = new VlanVO();
+        vlanVO.setNetworkId(15L);
+        PublicIpAddress publicIpAddress = new PublicIp(ipAddressVO, vlanVO, 
0x0ac00000L);
+        List<PublicIpAddress> pubIpList = new ArrayList<>(1);
+        pubIpList.add(publicIpAddress);
+        Commands commands = Mockito.mock(Commands.class);
+        Map<String, String> vlanMacAddress = new HashMap<>();
+        NicVO nicVO = new NicVO("nic", 1L, 2L, VirtualMachine.Type.User);
+        NetworkVO networkVO = new NetworkVO();
+        networkVO.setNetworkOfferingId(12L);
+        List<IPAddressVO> userIps = List.of(ipAddressVO);
+        NetworkOfferingVO networkOfferingVO = new NetworkOfferingVO();
+        Map<NetworkOffering.Detail, String> details = new HashMap<>();
+        VpcVO vpc = new VpcVO();
+        DataCenterVO dc = new DataCenterVO(1L, null, null, null, null, null, 
null, null, null, null, DataCenter.NetworkType.Advanced, null, null);
+
+        Mockito.when(router.getId()).thenReturn(14L);
+        Mockito.when(router.getDataCenterId()).thenReturn(4L);
+        
Mockito.when(nicDao.listByVmId(ArgumentMatchers.anyLong())).thenReturn(List.of(nicVO));
+        
Mockito.when(networkDao.findById(ArgumentMatchers.anyLong())).thenReturn(networkVO);
+        
Mockito.when(ipAddressDao.listByAssociatedVpc(ArgumentMatchers.anyLong(), 
ArgumentMatchers.nullable(Boolean.class))).thenReturn(userIps);
+        
Mockito.when(vlanDao.findById(ArgumentMatchers.anyLong())).thenReturn(vlanVO);
+        Mockito.when(networkModel.getNetworkRate(ArgumentMatchers.anyLong(), 
ArgumentMatchers.anyLong())).thenReturn(1200);
+        
Mockito.when(networkModel.getNetwork(ArgumentMatchers.anyLong())).thenReturn(networkVO);
+        
Mockito.when(networkOfferingDao.findById(ArgumentMatchers.anyLong())).thenReturn(networkOfferingVO);
+        
Mockito.when(configurationManager.getNetworkOfferingNetworkRate(ArgumentMatchers.anyLong(),
 ArgumentMatchers.anyLong())).thenReturn(1200);
+        
Mockito.when(networkModel.isSecurityGroupSupportedInNetwork(networkVO)).thenReturn(false);
+        
Mockito.when(networkOfferingDetailsDao.getNtwkOffDetails(ArgumentMatchers.anyLong())).thenReturn(details);
+        Mockito.when(networkDetailsDao.findDetail(ArgumentMatchers.anyLong(), 
ArgumentMatchers.anyString())).thenReturn(null);
+        
Mockito.when(vpcDao.findById(ArgumentMatchers.anyLong())).thenReturn(vpc);
+        
Mockito.when(routerControlHelper.getRouterControlIp(ArgumentMatchers.anyLong())).thenReturn("10.1.11.101");
+        
Mockito.when(dcDao.findById(ArgumentMatchers.anyLong())).thenReturn(dc);
+
+        commandSetupHelper.createVpcAssociatePublicIPCommands(router, 
pubIpList, commands, vlanMacAddress);
+    }
 }
diff --git 
a/server/src/test/java/com/cloud/network/router/NetworkHelperImplTest.java 
b/server/src/test/java/com/cloud/network/router/NetworkHelperImplTest.java
index 24a51059e05..71387510e6e 100644
--- a/server/src/test/java/com/cloud/network/router/NetworkHelperImplTest.java
+++ b/server/src/test/java/com/cloud/network/router/NetworkHelperImplTest.java
@@ -20,18 +20,44 @@ import com.cloud.agent.AgentManager;
 import com.cloud.agent.api.Answer;
 import com.cloud.agent.api.Command;
 import com.cloud.agent.manager.Commands;
+import com.cloud.deploy.DeploymentPlan;
 import com.cloud.exception.AgentUnavailableException;
+import com.cloud.exception.InsufficientAddressCapacityException;
 import com.cloud.exception.OperationTimedoutException;
 import com.cloud.exception.ResourceUnavailableException;
+import com.cloud.network.Network;
+import com.cloud.network.NetworkModel;
+import com.cloud.network.addr.PublicIp;
+import com.cloud.network.dao.NetworkDao;
+import com.cloud.network.dao.NetworkVO;
+import com.cloud.offering.NetworkOffering;
+import com.cloud.offerings.NetworkOfferingVO;
+import com.cloud.user.Account;
+import com.cloud.utils.net.Ip;
+import com.cloud.vm.NicProfile;
+import com.cloud.vm.NicVO;
+import com.cloud.vm.dao.NicDao;
+import 
org.apache.cloudstack.engine.orchestration.service.NetworkOrchestrationService;
+import 
org.apache.cloudstack.network.router.deployment.RouterDeploymentDefinition;
+import org.junit.Before;
 import org.junit.Test;
 import org.junit.runner.RunWith;
 import org.mockito.InjectMocks;
 import org.mockito.Matchers;
 import org.mockito.Mock;
+import org.mockito.Mockito;
 import org.mockito.runners.MockitoJUnitRunner;
 
+import javax.inject.Inject;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.LinkedHashMap;
+import java.util.List;
+
 import static org.junit.Assert.assertFalse;
 import static org.junit.Assert.assertTrue;
+import static org.mockito.ArgumentMatchers.*;
 import static org.mockito.Mockito.doReturn;
 import static org.mockito.Mockito.lenient;
 import static org.mockito.Mockito.mock;
@@ -51,6 +77,20 @@ public class NetworkHelperImplTest {
 
     @InjectMocks
     protected NetworkHelperImpl nwHelper = new NetworkHelperImpl();
+    @Mock
+    NetworkOrchestrationService networkOrchestrationService;
+    @Mock
+    NetworkDao networkDao;
+    @Mock
+    NetworkModel networkModel;
+    @Mock
+    NicDao nicDao;
+
+    @Before
+    public void setUp() {
+        nwHelper._networkDao = networkDao;
+        nwHelper._networkModel = networkModel;
+    }
 
     @Test(expected=ResourceUnavailableException.class)
     public void testSendCommandsToRouterWrongRouterVersion()
@@ -169,4 +209,41 @@ public class NetworkHelperImplTest {
         assertFalse(result);
     }
 
+    @Test
+    public void testConfigurePublicNicForNsxBroadcastDomainType() throws 
InsufficientAddressCapacityException {
+        nwHelper._networkDao = networkDao;
+        nwHelper._nicDao = nicDao;
+        networkOrchestrationService = mock(NetworkOrchestrationService.class);
+        RouterDeploymentDefinition deploymentDefinition = 
mock(RouterDeploymentDefinition.class);
+        PublicIp publicIp = mock(PublicIp.class);
+        NicProfile nicProfile = mock(NicProfile.class);
+        NetworkVO pubNetwork = mock(NetworkVO.class);
+        NicVO nicVO = mock(NicVO.class);
+        DeploymentPlan plan = mock(DeploymentPlan.class);
+
+
+        NetworkOfferingVO testOffering = new NetworkOfferingVO();
+        final List<NetworkOfferingVO> offerings = new 
ArrayList<NetworkOfferingVO>(1);
+        offerings.add(testOffering);
+
+        NetworkVO publicNetwork = new NetworkVO();
+
+        final List<NetworkVO> publicNetList = new ArrayList<>(1);
+        publicNetList.add(publicNetwork);
+
+        when(deploymentDefinition.isPublicNetwork()).thenReturn(true);
+        when(deploymentDefinition.getSourceNatIP()).thenReturn(publicIp);
+        when(publicIp.getAddress()).thenReturn(Mockito.mock(Ip.class));
+        
when(networkDao.findById(anyLong())).thenReturn(Mockito.mock(NetworkVO.class));
+        when(nicProfile.getIPv4Address()).thenReturn("10.10.10.10");
+        when(pubNetwork.getId()).thenReturn(1L);
+        when(nicDao.findByIp4AddressAndNetworkId(anyString(), 
anyLong())).thenReturn(nicVO);
+        
doReturn(offerings).when(networkModel).getSystemAccountNetworkOfferings(any());
+        when(deploymentDefinition.getPlan()).thenReturn(plan);
+        
doReturn(publicNetList).when(networkOrchestrationService).setupNetwork(nullable(Account.class),
 any(NetworkOffering.class), any(DeploymentPlan.class), nullable(String.class), 
nullable(String.class), anyBoolean());
+
+        LinkedHashMap<Network, List<? extends NicProfile>> configuredNic = 
nwHelper.configurePublicNic(deploymentDefinition, false);
+        configuredNic.get(publicNetList.get(0));
+    }
+
 }

Reply via email to