You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cloudstack.apache.org by da...@apache.org on 2014/05/04 21:46:25 UTC
git commit: updated refs/heads/master to bd3ec50
Repository: cloudstack
Updated Branches:
refs/heads/master 1080de5d6 -> bd3ec50de
Added unit tests for Juniper contrail VM Interface Model and Instance Ip Model class
Signed-off-by: Daan Hoogland <da...@onecht.net>
Project: http://git-wip-us.apache.org/repos/asf/cloudstack/repo
Commit: http://git-wip-us.apache.org/repos/asf/cloudstack/commit/bd3ec50d
Tree: http://git-wip-us.apache.org/repos/asf/cloudstack/tree/bd3ec50d
Diff: http://git-wip-us.apache.org/repos/asf/cloudstack/diff/bd3ec50d
Branch: refs/heads/master
Commit: bd3ec50dea87b938929a5448ac83e8da154af1a7
Parents: 1080de5
Author: Sachchidanand Vaidya <va...@juniper.net>
Authored: Thu Apr 17 23:13:04 2014 -0700
Committer: Daan Hoogland <da...@onecht.net>
Committed: Sun May 4 21:46:11 2014 +0200
----------------------------------------------------------------------
.../contrail/model/InstanceIpModelTest.java | 139 ++++++++++++++++++
.../contrail/model/VMInterfaceModelTest.java | 143 +++++++++++++++++++
2 files changed, 282 insertions(+)
----------------------------------------------------------------------
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/bd3ec50d/plugins/network-elements/juniper-contrail/test/org/apache/cloudstack/network/contrail/model/InstanceIpModelTest.java
----------------------------------------------------------------------
diff --git a/plugins/network-elements/juniper-contrail/test/org/apache/cloudstack/network/contrail/model/InstanceIpModelTest.java b/plugins/network-elements/juniper-contrail/test/org/apache/cloudstack/network/contrail/model/InstanceIpModelTest.java
new file mode 100644
index 0000000..a996900
--- /dev/null
+++ b/plugins/network-elements/juniper-contrail/test/org/apache/cloudstack/network/contrail/model/InstanceIpModelTest.java
@@ -0,0 +1,139 @@
+// 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 org.apache.cloudstack.network.contrail.model;
+import java.util.UUID;
+
+import java.io.IOException;
+
+import org.apache.cloudstack.network.contrail.management.ContrailManagerImpl;
+import org.apache.log4j.Logger;
+
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+import static org.mockito.Mockito.anyLong;
+import static org.mockito.Mockito.anyInt;
+import static org.mockito.Mockito.anyString;
+
+import com.cloud.network.Network;
+import com.cloud.network.Networks.TrafficType;
+import com.cloud.network.dao.NetworkVO;
+import com.cloud.network.dao.NetworkDao;
+import com.cloud.vm.NicVO;
+import com.cloud.vm.VMInstanceVO;
+import com.cloud.vm.VirtualMachine;
+import com.cloud.vm.dao.UserVmDao;
+
+import net.juniper.contrail.api.ApiConnectorMock;
+import net.juniper.contrail.api.ApiConnector;
+
+import org.junit.Test;
+import junit.framework.TestCase;
+
+public class InstanceIpModelTest extends TestCase {
+ private static final Logger s_logger =
+ Logger.getLogger(InstanceIpModelTest.class);
+
+ @Test
+ public void testCreateInstanceIp() throws IOException {
+
+ ContrailManagerImpl contrailMgr = mock(ContrailManagerImpl.class);
+ ModelController controller = mock(ModelController.class);
+ ApiConnector api = new ApiConnectorMock(null, 0);
+ when(controller.getApiAccessor()).thenReturn(api);
+ when(controller.getManager()).thenReturn(contrailMgr);
+
+ // Create Virtual-Network (VN)
+ NetworkVO network = mock(NetworkVO.class);
+ when(network.getName()).thenReturn("testnetwork");
+ when(network.getState()).thenReturn(Network.State.Implemented);
+ when(network.getGateway()).thenReturn("10.1.1.1");
+ when(network.getCidr()).thenReturn("10.1.1.0/24");
+ when(network.getPhysicalNetworkId()).thenReturn(42L);
+ when(network.getDomainId()).thenReturn(10L);
+ when(network.getAccountId()).thenReturn(42L);
+ NetworkDao networkDao = mock(NetworkDao.class);
+ when(networkDao.findById(anyLong())).thenReturn(network);
+ when(controller.getNetworkDao()).thenReturn(networkDao);
+
+ when(contrailMgr.getCanonicalName(network)).thenReturn("testnetwork");
+ when(contrailMgr.getProjectId(network.getDomainId(), network.getAccountId())).thenReturn("testProjectId");
+
+ VirtualNetworkModel vnModel = new VirtualNetworkModel(network, UUID.randomUUID().toString(), "test",
+ TrafficType.Guest);
+ vnModel.build(controller, network);
+ try {
+ vnModel.update(controller);
+ } catch (Exception ex) {
+ fail("virtual-network update failed ");
+ }
+
+ // Create Virtual-Machine (VM)
+ VMInstanceVO vm = mock(VMInstanceVO.class);
+ when(vm.getInstanceName()).thenReturn("testVM1");
+ when(vm.getState()).thenReturn(VirtualMachine.State.Running);
+ when(vm.getDomainId()).thenReturn(10L);
+ when(vm.getAccountId()).thenReturn(42L);
+ UserVmDao VmDao = mock(UserVmDao.class);
+ when(VmDao.findById(anyLong())).thenReturn(null);
+ when(controller.getVmDao()).thenReturn(VmDao);
+
+ VirtualMachineModel vmModel = new VirtualMachineModel(vm, UUID.randomUUID().toString());
+ vmModel.build(controller, vm);
+ try {
+ vmModel.update(controller);
+ } catch (Exception ex) {
+ fail("virtual-machine update failed ");
+ }
+
+ // Create Virtual=Machine-Interface (VMInterface)
+ NicVO nic = mock(NicVO.class);
+ when(nic.getIp4Address()).thenReturn("10.1.1.2");
+ when(nic.getMacAddress()).thenReturn("00:01:02:03:04:05");
+ when(nic.getDeviceId()).thenReturn(100);
+ when(nic.getState()).thenReturn(NicVO.State.Allocated);
+ when(nic.getNetworkId()).thenReturn(10L);
+
+ when(contrailMgr.getVifNameByVmName(anyString(), anyInt())).thenReturn("testVM1-100");
+
+ VMInterfaceModel vmiModel = new VMInterfaceModel(UUID.randomUUID().toString());
+ vmiModel.addToVirtualMachine(vmModel);
+ vmiModel.addToVirtualNetwork(vnModel);
+
+ try {
+ vmiModel.build(controller, vm, nic);
+ vmiModel.setActive();
+ } catch (Exception ex) {
+ fail("vm-interface build failed ");
+ }
+
+ try {
+ vmiModel.update(controller);
+ } catch (Exception ex) {
+ fail("vm-interface update failed ");
+ }
+ InstanceIpModel ipModel = new InstanceIpModel(vm.getInstanceName(), nic.getDeviceId());
+ ipModel.addToVMInterface(vmiModel);
+ ipModel.setAddress(nic.getIp4Address());
+
+ try {
+ ipModel.update(controller);
+ } catch (Exception ex) {
+ fail("ipInstance update failed ");
+ }
+ }
+}
http://git-wip-us.apache.org/repos/asf/cloudstack/blob/bd3ec50d/plugins/network-elements/juniper-contrail/test/org/apache/cloudstack/network/contrail/model/VMInterfaceModelTest.java
----------------------------------------------------------------------
diff --git a/plugins/network-elements/juniper-contrail/test/org/apache/cloudstack/network/contrail/model/VMInterfaceModelTest.java b/plugins/network-elements/juniper-contrail/test/org/apache/cloudstack/network/contrail/model/VMInterfaceModelTest.java
new file mode 100644
index 0000000..ebc1f76
--- /dev/null
+++ b/plugins/network-elements/juniper-contrail/test/org/apache/cloudstack/network/contrail/model/VMInterfaceModelTest.java
@@ -0,0 +1,143 @@
+// 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 org.apache.cloudstack.network.contrail.model;
+import java.util.UUID;
+import java.io.IOException;
+
+import org.apache.cloudstack.network.contrail.management.ContrailManagerImpl;
+import org.apache.log4j.Logger;
+
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+import static org.mockito.Mockito.anyLong;
+import static org.mockito.Mockito.anyString;
+import static org.mockito.Mockito.anyInt;
+
+import com.cloud.network.Network;
+import com.cloud.network.Networks.TrafficType;
+import com.cloud.network.dao.NetworkVO;
+import com.cloud.network.dao.NetworkDao;
+import com.cloud.vm.NicVO;
+import com.cloud.vm.VMInstanceVO;
+import com.cloud.vm.VirtualMachine;
+import com.cloud.vm.dao.UserVmDao;
+
+import net.juniper.contrail.api.ApiConnectorMock;
+import net.juniper.contrail.api.types.VirtualMachineInterface;
+import net.juniper.contrail.api.ApiConnector;
+
+import org.junit.Test;
+import junit.framework.TestCase;
+
+public class VMInterfaceModelTest extends TestCase {
+ private static final Logger s_logger =
+ Logger.getLogger(VMInterfaceModelTest.class);
+
+ @Test
+ public void testCreateVMInterface() throws IOException {
+
+ String uuid;
+ ContrailManagerImpl contrailMgr = mock(ContrailManagerImpl.class);
+ ModelController controller = mock(ModelController.class);
+ ApiConnector api = new ApiConnectorMock(null, 0);
+ when(controller.getManager()).thenReturn(contrailMgr);
+ when(controller.getApiAccessor()).thenReturn(api);
+
+ // Create Virtual-Network (VN)
+ NetworkVO network = mock(NetworkVO.class);
+ when(network.getName()).thenReturn("testnetwork");
+ when(network.getState()).thenReturn(Network.State.Implemented);
+ when(network.getGateway()).thenReturn("10.1.1.1");
+ when(network.getCidr()).thenReturn("10.1.1.0/24");
+ when(network.getPhysicalNetworkId()).thenReturn(42L);
+ when(network.getDomainId()).thenReturn(10L);
+ when(network.getAccountId()).thenReturn(42L);
+ NetworkDao networkDao = mock(NetworkDao.class);
+ when(networkDao.findById(anyLong())).thenReturn(network);
+ when(controller.getNetworkDao()).thenReturn(networkDao);
+
+ when(contrailMgr.getCanonicalName(network)).thenReturn("testnetwork");
+ when(contrailMgr.getProjectId(network.getDomainId(), network.getAccountId())).thenReturn("testProjectId");
+
+ VirtualNetworkModel vnModel = new VirtualNetworkModel(network, UUID.randomUUID().toString(),
+ "test", TrafficType.Guest);
+ vnModel.build(controller, network);
+ try {
+ vnModel.update(controller);
+ } catch (Exception ex) {
+ fail("virtual-network update failed ");
+ }
+
+ // Create Virtual-Machine (VM)
+ VMInstanceVO vm = mock(VMInstanceVO.class);
+ when(vm.getInstanceName()).thenReturn("testVM1");
+ when(vm.getState()).thenReturn(VirtualMachine.State.Running);
+ when(vm.getDomainId()).thenReturn(10L);
+ when(vm.getAccountId()).thenReturn(42L);
+ UserVmDao VmDao = mock(UserVmDao.class);
+ when(VmDao.findById(anyLong())).thenReturn(null);
+ when(controller.getVmDao()).thenReturn(VmDao);
+
+ VirtualMachineModel vmModel = new VirtualMachineModel(vm, UUID.randomUUID().toString());
+ vmModel.build(controller, vm);
+ try {
+ vmModel.update(controller);
+ } catch (Exception ex) {
+ fail("virtual-machine update failed ");
+ }
+
+ // Create Virtual=Machine-Interface (VMInterface)
+ NicVO nic = mock(NicVO.class);
+ when(nic.getIp4Address()).thenReturn("10.1.1.2");
+ when(nic.getMacAddress()).thenReturn("00:01:02:03:04:05");
+ when(nic.getDeviceId()).thenReturn(100);
+ when(nic.getState()).thenReturn(NicVO.State.Allocated);
+ when(nic.getNetworkId()).thenReturn(10L);
+
+ when(contrailMgr.getVifNameByVmName(anyString(), anyInt())).thenReturn("testVM1-100");
+
+ uuid = UUID.randomUUID().toString();
+ VMInterfaceModel vmiModel = new VMInterfaceModel(uuid);
+
+ assertEquals(uuid, vmiModel.getUuid());
+
+ vmiModel.addToVirtualMachine(vmModel);
+ vmiModel.addToVirtualNetwork(vnModel);
+
+ try {
+ vmiModel.build(controller, vm, nic);
+ vmiModel.setActive();
+ } catch (Exception ex) {
+ fail("vm-interface build failed ");
+ }
+
+ try {
+ vmiModel.update(controller);
+ } catch (Exception ex) {
+ fail("vm-interface update failed ");
+ }
+
+ // Verify virtual-machine-interface creation.
+ try {
+ VirtualMachineInterface vmi = (VirtualMachineInterface) api.findById(VirtualMachineInterface.class, vmiModel.getUuid());
+ assertNotNull(vmi);
+ } catch (Exception ex) {
+ fail("vm-interface verify failed ");
+ }
+ }
+}