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:10:31 UTC

git commit: updated refs/heads/4.4-forward to 5c2ddb2

Repository: cloudstack
Updated Branches:
  refs/heads/4.4-forward 0cdcab26f -> 5c2ddb248


Add OpenContrail support to devCloud environment

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/5c2ddb24
Tree: http://git-wip-us.apache.org/repos/asf/cloudstack/tree/5c2ddb24
Diff: http://git-wip-us.apache.org/repos/asf/cloudstack/diff/5c2ddb24

Branch: refs/heads/4.4-forward
Commit: 5c2ddb24886a6698492acfc418b7408d4511d3c8
Parents: 0cdcab2
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:09:45 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/5c2ddb24/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/5c2ddb24/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 ");
+        }
+    }
+}