mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	BUG-ID: CLOUDSTACK-9403 Co-Authored-By: Prashanth Manthena <prashanth.manthena@nuagenetworks.net> Co-Authored-By: Rahul Singal <rahul.singal@nuagenetworks.net> Co-Authored-By: Sigert Goeminne <sigert.goeminne@nuagenetworks.net> Co-Authored-By: Nick Livens <nick.livens@nuagenetworks.net>
		
			
				
	
	
		
			1459 lines
		
	
	
		
			70 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			1459 lines
		
	
	
		
			70 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # 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.
 | |
| 
 | |
| """ Component tests for Source NAT functionality with Nuage VSP SDN plugin
 | |
| """
 | |
| # Import Local Modules
 | |
| from nuageTestCase import nuageTestCase
 | |
| from marvin.lib.base import (Account,
 | |
|                              Network,
 | |
|                              VirtualMachine)
 | |
| # Import System Modules
 | |
| from nose.plugins.attrib import attr
 | |
| import copy
 | |
| import time
 | |
| 
 | |
| 
 | |
| class TestNuageSourceNat(nuageTestCase):
 | |
|     """Test Source NAT functionality with Nuage VSP SDN plugin
 | |
|     """
 | |
| 
 | |
|     @classmethod
 | |
|     def setUpClass(cls):
 | |
|         super(TestNuageSourceNat, cls).setUpClass()
 | |
|         return
 | |
| 
 | |
|     def setUp(self):
 | |
|         # Create an account
 | |
|         self.account = Account.create(self.api_client,
 | |
|                                       self.test_data["account"],
 | |
|                                       admin=True,
 | |
|                                       domainid=self.domain.id
 | |
|                                       )
 | |
|         self.cleanup = [self.account]
 | |
|         return
 | |
| 
 | |
|     # verify_vsd_SourceNAT_network - Verifies if Source NAT functionality of
 | |
|     # the given network is enabled in VSD
 | |
|     def verify_vsd_SourceNAT_network(self, network, vpc=None):
 | |
|         self.debug("Verifying if Source NAT functionality of Network - %s is "
 | |
|                    "enabled in VSD" % network.name)
 | |
|         ext_network_id_filter = self.get_externalID_filter(vpc.id) if vpc \
 | |
|             else self.get_externalID_filter(network.id)
 | |
|         vsd_domain = self.vsd.get_domain(filter=ext_network_id_filter)
 | |
|         self.assertEqual(vsd_domain.pat_enabled, "ENABLED",
 | |
|                          "VSD domain address translation support "
 | |
|                          "(pat_enabled flag) should be enabled for Source NAT "
 | |
|                          "service enabled network in CloudStack"
 | |
|                          )
 | |
|         self.assertEqual(vsd_domain.underlay_enabled, "ENABLED",
 | |
|                          "VSD domain underlay support (underlay_enabled flag) "
 | |
|                          "should be enabled for Source NAT service enabled "
 | |
|                          "network in CloudStack"
 | |
|                          )
 | |
|         self.debug("Successfully verified that Source NAT functionality of "
 | |
|                    "Network - %s is enabled in VSD" % network.name)
 | |
| 
 | |
|     # verify_SourceNAT_VM_traffic - Verifies Source NAT traffic
 | |
|     # (wget www.google.com) to the Internet from the given VM. This Source NAT
 | |
|     # traffic test is done through a custom init script in the guest VM
 | |
|     # template upon the VM boot up.
 | |
|     def verify_SourceNAT_VM_traffic(self, vm, network, vpc=None,
 | |
|                                     negative_test=False):
 | |
|         self.debug("Verifying Source NAT traffic (wget www.google.com) to the "
 | |
|                    "Internet from VM - %s" % vm.name)
 | |
|         if self.isInternetConnectivityAvailable:
 | |
|             # Adding Egress Network ACL rule
 | |
|             if vpc and self.http_proxy and not negative_test:
 | |
|                 self.debug("Adding Egress Network ACL rule in the created VPC "
 | |
|                            "network to allow access to the configured "
 | |
|                            "Internet proxy servers...")
 | |
|                 proxy_rule = copy.deepcopy(self.test_data["http_rule"])
 | |
|                 proxy_rule["privateport"] = 1080
 | |
|                 proxy_rule["publicport"] = 1080
 | |
|                 proxy_rule["startport"] = 1080
 | |
|                 proxy_rule["endport"] = 1080
 | |
|                 internet_proxy_server_rule = self.create_NetworkAclRule(
 | |
|                     proxy_rule, traffic_type="Egress", network=network)
 | |
| 
 | |
|                 # VSD verification
 | |
|                 self.verify_vsd_firewall_rule(
 | |
|                     internet_proxy_server_rule, traffic_type="Egress")
 | |
| 
 | |
|             # Triggering Source NAT traffic test
 | |
|             # Rebooting (stop - start) VM
 | |
|             self.debug("Triggering the Source NAT traffic test by rebooting "
 | |
|                        "the given VM...")
 | |
|             vm.stop(self.api_client)
 | |
|             vm.start(self.api_client)
 | |
|             self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|             # VSD verification
 | |
|             self.verify_vsd_vm(vm)
 | |
| 
 | |
|             # VSD verification for Source NAT functionality
 | |
|             self.verify_vsd_SourceNAT_network(network, vpc)
 | |
| 
 | |
|             self.debug("Waiting for the VM to perform the Source NAT traffic "
 | |
|                        "test (wget www.google.com) to the Internet...")
 | |
|             time.sleep(180) if negative_test else time.sleep(300)
 | |
| 
 | |
|             # Creating Static NAT rule
 | |
|             self.debug("Creating Static NAT rule to SSH into the VM for "
 | |
|                        "verifying its Source NAT traffic test...")
 | |
|             public_ip = self.acquire_PublicIPAddress(network, vpc=vpc)
 | |
|             self.validate_PublicIPAddress(public_ip, network)
 | |
|             self.create_StaticNatRule_For_VM(vm, public_ip, network)
 | |
|             self.validate_PublicIPAddress(
 | |
|                 public_ip, network, static_nat=True, vm=vm)
 | |
| 
 | |
|             # VSD verification
 | |
|             updated_vm_info = VirtualMachine.list(self.api_client, id=vm.id)[0]
 | |
|             self.verify_vsd_floating_ip(
 | |
|                 network, updated_vm_info, public_ip.ipaddress, vpc=vpc)
 | |
| 
 | |
|             # Adding Ingress Firewall/Network ACL rule
 | |
|             self.debug("Adding Ingress Firewall/Network ACL rule to make the "
 | |
|                        "created Static NAT rule (SSH) accessible...")
 | |
|             if vpc:
 | |
|                 public_ssh_rule = self.create_NetworkAclRule(
 | |
|                     self.test_data["ingress_rule"], network=network)
 | |
|             else:
 | |
|                 public_ssh_rule = self.create_FirewallRule(
 | |
|                     public_ip, self.test_data["ingress_rule"])
 | |
| 
 | |
|             # VSD verification
 | |
|             self.verify_vsd_firewall_rule(public_ssh_rule)
 | |
| 
 | |
|             # Checking for wget file
 | |
|             ssh_client = self.ssh_into_VM(vm, public_ip)
 | |
|             cmd = "ls /"
 | |
|             file_list = self.execute_cmd(ssh_client, cmd)
 | |
|             if "index.html" in str(file_list):
 | |
|                 cmd = "rm -rf /index.html*"
 | |
|                 self.execute_cmd(ssh_client, cmd)
 | |
| 
 | |
|             # Removing Ingress Firewall/Network ACL rule
 | |
|             self.debug("Removing the created Ingress Firewall/Network ACL "
 | |
|                        "rule in the network...")
 | |
|             public_ssh_rule.delete(self.api_client)
 | |
| 
 | |
|             # VSD verification
 | |
|             with self.assertRaises(Exception):
 | |
|                 self.verify_vsd_firewall_rule(public_ssh_rule)
 | |
|             self.debug("Ingress Firewall/Network ACL rule successfully "
 | |
|                        "deleted in VSD")
 | |
| 
 | |
|             # Deleting Static NAT Rule
 | |
|             self.debug("Deleting Static NAT Rule for the VM...")
 | |
|             self.delete_StaticNatRule_For_VM(public_ip)
 | |
|             with self.assertRaises(Exception):
 | |
|                 self.validate_PublicIPAddress(
 | |
|                     public_ip, network, static_nat=True, vm=vm)
 | |
|             self.debug("Static NAT Rule for the VM successfully deleted in "
 | |
|                        "CloudStack")
 | |
| 
 | |
|             # VSD verification
 | |
|             with self.assertRaises(Exception):
 | |
|                 self.verify_vsd_floating_ip(
 | |
|                     network, updated_vm_info, public_ip.ipaddress, vpc=vpc)
 | |
|             self.debug("Floating IP for the VM successfully deleted in VSD")
 | |
| 
 | |
|             # Releasing acquired public IP
 | |
|             self.debug("Releasing the acquired public IP in the network...")
 | |
|             public_ip.delete(self.api_client)
 | |
|             with self.assertRaises(Exception):
 | |
|                 self.validate_PublicIPAddress(public_ip, network)
 | |
|             self.debug("Acquired public IP in the network successfully "
 | |
|                        "released in CloudStack")
 | |
| 
 | |
|             # Removing Egress Network ACL rule
 | |
|             if vpc and self.http_proxy:
 | |
|                 self.debug("Removing the created Egress Network ACL rule in "
 | |
|                            "the VPC network...")
 | |
|                 internet_proxy_server_rule.delete(self.api_client)
 | |
| 
 | |
|                 # VSD verification
 | |
|                 with self.assertRaises(Exception):
 | |
|                     self.verify_vsd_firewall_rule(internet_proxy_server_rule)
 | |
|                 self.debug("Egress Network ACL rule successfully deleted in "
 | |
|                            "VSD")
 | |
| 
 | |
|             # Final test result
 | |
|             if "index.html" in str(file_list):
 | |
|                 self.debug("Successfully verified Source NAT traffic "
 | |
|                            "(wget www.google.com) to the Internet from VM - %s"
 | |
|                            % vm.name)
 | |
|             else:
 | |
|                 self.fail("Failed to verify Source NAT traffic "
 | |
|                           "(wget www.google.com) to the Internet from VM - %s"
 | |
|                           % vm.name)
 | |
|         else:
 | |
|             if negative_test:
 | |
|                 self.fail("Skipping Source NAT traffic (wget www.google.com) "
 | |
|                           "verification to the Internet from VM as there is "
 | |
|                           "no Internet connectivity in the data center")
 | |
|             else:
 | |
|                 self.debug("Skipping Source NAT traffic (wget www.google.com) "
 | |
|                            "verification to the Internet from VM as there is "
 | |
|                            "no Internet connectivity in the data center")
 | |
| 
 | |
|     @attr(tags=["advanced", "nuagevsp"], required_hardware="false")
 | |
|     def test_01_nuage_SourceNAT_isolated_networks(self):
 | |
|         """Test Nuage VSP Isolated networks with different combinations of
 | |
|         Source NAT service providers
 | |
|         """
 | |
| 
 | |
|         # 1. Create Nuage VSP Isolated Network offerings and corresponding
 | |
|         #    Isolated networks with different combinations of Source NAT
 | |
|         #    service providers (NuageVsp, VirtualRouter, no SourceNat service),
 | |
|         #    check if only the Isolated networks with Source NAT service
 | |
|         #    provider as NuageVsp are successfully created.
 | |
|         # 2. Recreate the above created Network offering with ispersistent flag
 | |
|         #    set to True, check if the network offering is successfully created
 | |
|         #    and enabled.
 | |
|         # 3. Recreate the above created Network offering with conserve mode On
 | |
|         #    (conserve_mode flag set to True), check if the network offering is
 | |
|         #    successfully created and enabled.
 | |
|         # 4. Recreate the above created Network offering with Source NAT
 | |
|         #    Service Capability SupportedSourceNatTypes as per account, check
 | |
|         #    if the network offering creation failed as Nuage VSP supports only
 | |
|         #    SupportedSourceNatTypes as per zone.
 | |
|         # 5. Create an Isolated network with Source NAT service provider as
 | |
|         #    NuageVsp and spawn a VM, check if the network is successfully
 | |
|         #    created, and the VM along with the VR is deployed successfully in
 | |
|         #    the network. Verify if the Source NAT functionality for this
 | |
|         #    network is successfully enabled in VSD.
 | |
|         # 6. Create a persistent Isolated network with Source NAT service
 | |
|         #    provider as NuageVsp and spawn a VM, check if the network is
 | |
|         #    successfully created, and the VM along with the VR is deployed
 | |
|         #    successfully in the network. Verify if the Source NAT
 | |
|         #    functionality for this network is successfully enabled in VSD.
 | |
|         # 7. Create a conserved Isolated network (conserve mode On) with Source
 | |
|         #    NAT service provider as NuageVsp and spawn a VM, check if the
 | |
|         #    network is successfully created, and the VM along with the VR is
 | |
|         #    deployed successfully in the network. Verify if the Source NAT
 | |
|         #    functionality for this network is successfully enabled in VSD.
 | |
|         # 8. Delete all the created objects (cleanup).
 | |
| 
 | |
|         # Creating network offerings
 | |
|         self.debug("Creating Nuage VSP Isolated Network offering with Source "
 | |
|                    "NAT service provider as NuageVsp...")
 | |
|         net_off_1 = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off_1, state="Enabled")
 | |
| 
 | |
|         self.debug("Recreating above Network offering with ispersistent "
 | |
|                    "True...")
 | |
|         network_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         network_offering["ispersistent"] = "True"
 | |
|         net_off_2 = self.create_NetworkOffering(network_offering)
 | |
|         self.validate_NetworkOffering(net_off_2, state="Enabled")
 | |
| 
 | |
|         self.debug("Recreating above Network offering with conserve mode "
 | |
|                    "On...")
 | |
|         net_off_3 = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"],
 | |
|             conserve_mode=True)
 | |
|         self.validate_NetworkOffering(net_off_3, state="Enabled")
 | |
| 
 | |
|         self.debug("Recreating above Network offering with Source NAT Service "
 | |
|                    "Capability SupportedSourceNatTypes as per account...")
 | |
|         network_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         service_list = network_offering["serviceCapabilityList"]
 | |
|         service_list["SourceNat"]["SupportedSourceNatTypes"] = "peraccount"
 | |
|         network_offering["serviceCapabilityList"] = service_list
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_NetworkOffering(network_offering)
 | |
|         self.debug("Nuage VSP does not support Network offerings with Source "
 | |
|                    "NAT Service Capability "
 | |
|                    "SupportedSourceNatTypes as per account")
 | |
| 
 | |
|         self.debug("Creating Nuage VSP Isolated Network offering with Source "
 | |
|                    "NAT service provider as VirtualRouter...")
 | |
|         network_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         network_offering["serviceProviderList"]["SourceNat"] = "VirtualRouter"
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_NetworkOffering(network_offering)
 | |
|         self.debug("Nuage VSP does not support Network offerings with Source "
 | |
|                    "NAT service provider as VirtualRouter")
 | |
| 
 | |
|         self.debug("Creating Nuage VSP Isolated Network offering without "
 | |
|                    "Source NAT service...")
 | |
|         network_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         network_offering["supportedservices"] = \
 | |
|             'Dhcp,Connectivity,StaticNat,UserData,Firewall,Dns'
 | |
|         del network_offering["serviceProviderList"]["SourceNat"]
 | |
|         del network_offering["serviceCapabilityList"]
 | |
|         net_off_4 = self.create_NetworkOffering(network_offering)
 | |
| 
 | |
|         # Creating Isolated networks, and deploying VMs
 | |
|         self.debug("Creating an Isolated network with Source NAT service "
 | |
|                    "provider as NuageVsp...")
 | |
|         network_1 = self.create_Network(net_off_1, gateway='10.1.1.1')
 | |
|         self.validate_Network(network_1, state="Allocated")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created Isolated network...")
 | |
|         vm_1 = self.create_VM(network_1)
 | |
|         self.validate_Network(network_1, state="Implemented")
 | |
|         vr_1 = self.get_Router(network_1)
 | |
|         self.check_Router_state(vr_1, state="Running")
 | |
|         self.check_VM_state(vm_1, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network_1)
 | |
|         self.verify_vsd_router(vr_1)
 | |
|         self.verify_vsd_vm(vm_1)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network_1)
 | |
| 
 | |
|         # Bug CLOUDSTACK-9398
 | |
|         """
 | |
|         self.debug("Creating a persistent Isolated network with Source NAT "
 | |
|                    "service...")
 | |
|         network_2 = self.create_Network(net_off_2, gateway='10.1.2.1')
 | |
|         self.validate_Network(network_2, state="Implemented")
 | |
|         vr_2 = self.get_Router(network_2)
 | |
|         self.check_Router_state(vr_2, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network_2)
 | |
|         self.verify_vsd_router(vr_2)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network_2)
 | |
| 
 | |
|         self.debug("Deploying a VM in the created Isolated network...")
 | |
|         vm_2 = self.create_VM(network_2)
 | |
|         self.check_VM_state(vm_2, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vm_2)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network_2)
 | |
|         """
 | |
| 
 | |
|         self.debug("Creating an Isolated network with Source NAT service and "
 | |
|                    "conserve mode On...")
 | |
|         network_3 = self.create_Network(net_off_3, gateway='10.1.3.1')
 | |
|         self.validate_Network(network_3, state="Allocated")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created Isolated network...")
 | |
|         vm_3 = self.create_VM(network_3)
 | |
|         self.validate_Network(network_3, state="Implemented")
 | |
|         vr_3 = self.get_Router(network_3)
 | |
|         self.check_Router_state(vr_3, state="Running")
 | |
|         self.check_VM_state(vm_3, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network_3)
 | |
|         self.verify_vsd_router(vr_3)
 | |
|         self.verify_vsd_vm(vm_3)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network_3)
 | |
| 
 | |
|         self.debug("Creating an Isolated network without Source NAT "
 | |
|                    "service...")
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_Network(net_off_4, gateway='10.1.4.1')
 | |
|         self.debug("Nuage VSP does not support creation of Isolated networks "
 | |
|                    "without Source NAT service")
 | |
| 
 | |
|     @attr(tags=["advanced", "nuagevsp"], required_hardware="false")
 | |
|     def test_02_nuage_SourceNAT_vpc_networks(self):
 | |
|         """Test Nuage VSP VPC networks with different combinations of Source
 | |
|         NAT service providers
 | |
|         """
 | |
| 
 | |
|         # 1. Create Nuage VSP VPC offering with different combinations of
 | |
|         #    Source NAT service providers
 | |
|         #    (NuageVsp, VirtualRouter, no SourceNat service), check if all the
 | |
|         #    VPC offerings are successfully created and enabled.
 | |
|         # 2. Create VPCs with different combinations of Source NAT service
 | |
|         #    providers (NuageVsp, VirtualRouter, no SourceNat service), check
 | |
|         #    if only the VPCs with Source NAT service provider as NuageVsp and
 | |
|         #    no SourceNat service are successfully created and enabled.
 | |
|         # 3. Create Nuage VSP VPC Network offering with different combinations
 | |
|         #    of Source NAT service providers
 | |
|         #    (NuageVsp, VirtualRouter, no SourceNat service), check if only the
 | |
|         #    network offering with Source NAT service provider as NuageVsp is
 | |
|         #    successfully created and enabled.
 | |
|         # 4. Recreate the above created Network offering with ispersistent flag
 | |
|         #    set to False, check if the network offering is successfully
 | |
|         #    created and enabled.
 | |
|         # 5. Recreate the above created Network offering with conserve mode On
 | |
|         #    (conserve_mode flag set to True), check if the network offering
 | |
|         #    creation failed as only networks with conserve mode Off can belong
 | |
|         #    to VPC.
 | |
|         # 6. Recreate the above created Network offering with with Source NAT
 | |
|         #    Service Capability SupportedSourceNatTypes as per account, check
 | |
|         #    if the network offering creation failed as Nuage VSP supports only
 | |
|         #    SupportedSourceNatTypes as per zone.
 | |
|         # 7. Create a VPC network with Source NAT service provider as NuageVsp
 | |
|         #    in the VPC with SourceNat service and spawn a VM, check if the
 | |
|         #    tier is added to the VPC VR, and the VM is deployed successfully
 | |
|         #    in the tier. Verify if the Source NAT functionality for this
 | |
|         #    network is successfully enabled in VSD.
 | |
|         # 8. Create a non persistent VPC network with Source NAT service
 | |
|         #    provider as NuageVsp in the VPC with SourceNat service and spawn a
 | |
|         #    VM, check if the tier creation failed as Nuage VSP does not
 | |
|         #    support non persistent VPC networks.
 | |
|         # 9. Create another VPC network with Source NAT service provider as
 | |
|         #    NuageVsp in the VPC with SourceNat service and spawn a VM, check
 | |
|         #    if the tier is added to the VPC VR, and the VM is deployed
 | |
|         #    successfully in the tier. Verify if the Source NAT functionality
 | |
|         #    for this network is successfully enabled in VSD.
 | |
|         # 10. Create a VPC network with Source NAT service provider as NuageVsp
 | |
|         #     in the VPC without SourceNat service, check if the tier creation
 | |
|         #     failed as the VPC does not support Source NAT service.
 | |
|         # 11. Delete all the created objects (cleanup).
 | |
| 
 | |
|         # Creating VPC offerings
 | |
|         self.debug("Creating Nuage VSP VPC offering with Source NAT service "
 | |
|                    "provider as NuageVsp...")
 | |
|         vpc_off_1 = self.create_VpcOffering(
 | |
|             self.test_data["nuagevsp"]["vpc_offering"])
 | |
|         self.validate_VpcOffering(vpc_off_1, state="Enabled")
 | |
| 
 | |
|         self.debug("Creating Nuage VSP VPC offering with Source NAT service "
 | |
|                    "provider as VpcVirtualRouter...")
 | |
|         vpc_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["vpc_offering"])
 | |
|         vpc_offering["serviceProviderList"]["SourceNat"] = "VpcVirtualRouter"
 | |
|         vpc_off_2 = self.create_VpcOffering(vpc_offering)
 | |
|         self.validate_VpcOffering(vpc_off_2, state="Enabled")
 | |
| 
 | |
|         self.debug("Creating Nuage VSP VPC offering without Source NAT "
 | |
|                    "service...")
 | |
|         vpc_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["vpc_offering"])
 | |
|         vpc_offering["supportedservices"] = \
 | |
|             'Dhcp,StaticNat,NetworkACL,Connectivity,UserData,Dns'
 | |
|         del vpc_offering["serviceProviderList"]["SourceNat"]
 | |
|         vpc_off_3 = self.create_VpcOffering(vpc_offering)
 | |
|         self.validate_VpcOffering(vpc_off_3, state="Enabled")
 | |
| 
 | |
|         # Creating VPCs
 | |
|         self.debug("Creating a VPC with Source NAT service provider as "
 | |
|                    "NuageVsp...")
 | |
|         vpc_1 = self.create_Vpc(vpc_off_1, cidr='10.1.0.0/16')
 | |
|         self.validate_Vpc(vpc_1, state="Enabled")
 | |
| 
 | |
|         self.debug("Creating a VPC with Source NAT service provider as "
 | |
|                    "VpcVirtualRouter...")
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_Vpc(vpc_off_2, cidr='10.1.0.0/16')
 | |
|         self.debug("Nuage VSP does not support provider VpcVirtualRouter for "
 | |
|                    "service Source NAT for VPCs")
 | |
| 
 | |
|         self.debug("Creating a VPC without Source NAT service...")
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_Vpc(vpc_off_3, cidr='10.1.0.0/16')
 | |
|         self.debug("Nuage VSP does not support VPCs without Source NAT "
 | |
|                    "service")
 | |
| 
 | |
|         # Creating network offerings
 | |
|         self.debug("Creating Nuage VSP VPC Network offering with Source NAT "
 | |
|                    "service provider as NuageVsp...")
 | |
|         net_off_1 = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["vpc_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off_1, state="Enabled")
 | |
| 
 | |
|         self.debug("Recreating above Network offering with ispersistent "
 | |
|                    "False...")
 | |
|         network_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["vpc_network_offering"])
 | |
|         network_offering["ispersistent"] = "False"
 | |
|         net_off_2 = self.create_NetworkOffering(network_offering)
 | |
|         self.validate_NetworkOffering(net_off_2, state="Enabled")
 | |
| 
 | |
|         self.debug("Recreating above Network offering with conserve mode "
 | |
|                    "On...")
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_NetworkOffering(
 | |
|                 self.test_data["nuagevsp"]["vpc_network_offering"],
 | |
|                 conserve_mode=True)
 | |
|         self.debug("Network offering creation failed as only networks with "
 | |
|                    "conserve mode Off can belong to VPC")
 | |
| 
 | |
|         self.debug("Recreating above Network offering with Source NAT Service "
 | |
|                    "Capability SupportedSourceNatTypes as per account...")
 | |
|         network_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["vpc_network_offering"])
 | |
|         service_list = network_offering["serviceCapabilityList"]
 | |
|         service_list["SourceNat"]["SupportedSourceNatTypes"] = "peraccount"
 | |
|         network_offering["serviceCapabilityList"] = service_list
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_NetworkOffering(network_offering)
 | |
|         self.debug("Nuage VSP does not support Network offerings with Source "
 | |
|                    "NAT Service Capability SupportedSourceNatTypes as per "
 | |
|                    "account")
 | |
| 
 | |
|         self.debug("Creating Nuage VSP VPC Network offering with Source NAT "
 | |
|                    "service provider as VpcVirtualRouter...")
 | |
|         network_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["vpc_network_offering"])
 | |
|         network_offering["serviceProviderList"]["SourceNat"] = \
 | |
|             "VpcVirtualRouter"
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_NetworkOffering(network_offering)
 | |
|         self.debug("Nuage VSP does not support Network offerings with Source "
 | |
|                    "NAT service provider as VpcVirtualRouter")
 | |
| 
 | |
|         self.debug("Creating Nuage VSP VPC Network offering without Source "
 | |
|                    "NAT service...")
 | |
|         network_offering = copy.deepcopy(
 | |
|             self.test_data["nuagevsp"]["vpc_network_offering"])
 | |
|         network_offering["supportedservices"] = \
 | |
|             'Dhcp,StaticNat,NetworkACL,Connectivity,UserData,Dns'
 | |
|         del network_offering["serviceProviderList"]["SourceNat"]
 | |
|         del network_offering["serviceCapabilityList"]
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_NetworkOffering(network_offering)
 | |
|         self.debug("Nuage VSP does not support Network offerings without "
 | |
|                    "Source NAT service")
 | |
| 
 | |
|         # Creating VPC networks in the VPCs, and deploying VMs
 | |
|         self.debug("Creating a VPC network with Source NAT service provider "
 | |
|                    "as NuageVsp in vpc_1...")
 | |
|         vpc_tier_1 = self.create_Network(
 | |
|             net_off_1, gateway='10.1.1.1', vpc=vpc_1)
 | |
|         self.validate_Network(vpc_tier_1, state="Implemented")
 | |
|         vpc_vr = self.get_Router(vpc_tier_1)
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier_1, vpc_1)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier_1, vpc=vpc_1)
 | |
| 
 | |
|         self.debug("Deploying a VM in the created VPC network...")
 | |
|         vpc_vm_1 = self.create_VM(vpc_tier_1)
 | |
|         self.check_VM_state(vpc_vm_1, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vpc_vm_1)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier_1, vpc=vpc_1)
 | |
| 
 | |
|         self.debug("Creating a non persistent VPC network with Source NAT "
 | |
|                    "service in vpc_1...")
 | |
|         with self.assertRaises(Exception):
 | |
|             self.create_Network(net_off_2, gateway='10.1.2.1', vpc=vpc_1)
 | |
|         self.debug("Nuage VSP does not support non persistent VPC networks")
 | |
| 
 | |
|         self.debug("Creating another VPC network with Source NAT service in "
 | |
|                    "vpc_1...")
 | |
|         vpc_tier_2 = self.create_Network(
 | |
|             net_off_1, gateway='10.1.2.1', vpc=vpc_1)
 | |
|         self.validate_Network(vpc_tier_2, state="Implemented")
 | |
|         vpc_vr = self.get_Router(vpc_tier_2)
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier_2, vpc_1)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier_2, vpc=vpc_1)
 | |
| 
 | |
|         self.debug("Deploying a VM in the created VPC network...")
 | |
|         vpc_vm_2 = self.create_VM(vpc_tier_2)
 | |
|         self.check_VM_state(vpc_vm_2, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vpc_vm_2)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier_2, vpc=vpc_1)
 | |
| 
 | |
|     @attr(tags=["advanced", "nuagevsp"], required_hardware="true")
 | |
|     def test_03_nuage_SourceNAT_isolated_network_traffic(self):
 | |
|         """Test Nuage VSP Source NAT functionality for Isolated network by
 | |
|         performing (wget) traffic tests to the Internet
 | |
|         """
 | |
| 
 | |
|         # 1. Check if the configured Nuage VSP SDN platform infrastructure
 | |
|         #    supports underlay networking, if not, skip this test.
 | |
|         # 2. Create an Isolated network with Source NAT service provider as
 | |
|         #    NuageVsp and spawn a VM, check if the network is successfully
 | |
|         #    created, and the VM along with the VR is deployed successfully in
 | |
|         #    the network. Verify if the Source NAT functionality for this
 | |
|         #    network is successfully enabled in VSD.
 | |
|         # 3. Verify Source NAT traffic test (wget www.google.com) to the
 | |
|         #    Internet from the deployed VM.
 | |
|         # 4. Deploy another VM in the created Isolated network, check if the VM
 | |
|         #    is deployed successfully in the network. Verify if the Source NAT
 | |
|         #    functionality for this network is successfully enabled in VSD.
 | |
|         # 5. Verify Source NAT traffic test (wget www.google.com) to the
 | |
|         #    Internet from the deployed VM.
 | |
|         # 6. Delete all the created objects (cleanup).
 | |
|         # Note: Above mentioned Source NAT traffic tests are done through a
 | |
|         #       custom init script in the guest VM template upon the VM boot
 | |
|         #       up. This traffic tests are verified by SSHing into the VM
 | |
|         #       using a Static NAT rule.
 | |
| 
 | |
|         if not self.isNuageInfraUnderlay:
 | |
|             self.skipTest("Configured Nuage VSP SDN platform infrastructure "
 | |
|                           "does not support underlay networking: "
 | |
|                           "skipping test")
 | |
| 
 | |
|         # Creating network offering
 | |
|         self.debug("Creating Nuage VSP Isolated Network offering with Source "
 | |
|                    "NAT service provider as NuageVsp...")
 | |
|         net_off = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off, state="Enabled")
 | |
| 
 | |
|         # Creating Isolated networks, deploying VMs, and verifying Source NAT
 | |
|         # traffic
 | |
|         self.debug("Creating an Isolated network with Source NAT service...")
 | |
|         network = self.create_Network(net_off, gateway='10.1.1.1')
 | |
|         self.validate_Network(network, state="Allocated")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created Isolated network...")
 | |
|         vm_1 = self.create_VM(network)
 | |
|         self.validate_Network(network, state="Implemented")
 | |
|         vr = self.get_Router(network)
 | |
|         self.check_Router_state(vr, state="Running")
 | |
|         self.check_VM_state(vm_1, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network)
 | |
|         self.verify_vsd_router(vr)
 | |
|         self.verify_vsd_vm(vm_1)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm_1, network)
 | |
| 
 | |
|         self.debug("Deploying another VM in the created Isolated network...")
 | |
|         vm_2 = self.create_VM(network)
 | |
|         self.check_VM_state(vm_2, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vm_2)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm_2, network)
 | |
| 
 | |
|     @attr(tags=["advanced", "nuagevsp"], required_hardware="true")
 | |
|     def test_04_nuage_SourceNAT_vpc_network_traffic(self):
 | |
|         """Test Nuage VSP Source NAT functionality for VPC network by
 | |
|         performing (wget) traffic tests to the Internet
 | |
|         """
 | |
| 
 | |
|         # 1. Check if the configured Nuage VSP SDN platform infrastructure
 | |
|         #    supports underlay networking, if not, skip this test.
 | |
|         # 2. Create a VPC network with Source NAT service provider as NuageVsp
 | |
|         #    in the VPC with SourceNat service and spawn a VM, check if the
 | |
|         #    tier is added to the VPC VR, and the VM is deployed successfully
 | |
|         #    in the tier. Verify if the Source NAT functionality for this
 | |
|         #    network is successfully enabled in VSD.
 | |
|         # 3. Verify Source NAT traffic test (wget www.google.com) to the
 | |
|         #    Internet from the deployed VM.
 | |
|         # 4. Deploy another VM in the created VPC network, check if the VM is
 | |
|         #    deployed successfully in the network. Verify if the Source NAT
 | |
|         #    functionality for this network is successfully enabled in VSD.
 | |
|         # 5. Verify Source NAT traffic test (wget www.google.com) to the
 | |
|         #    Internet from the deployed VM.
 | |
|         # 6. Delete all the created objects (cleanup).
 | |
|         # Note: Above mentioned Source NAT traffic tests are done through a
 | |
|         #       custom init script in the guest VM template upon the VM boot
 | |
|         #       up. This traffic tests are verified by SSHing into the VM using
 | |
|         #       a Static NAT rule.
 | |
| 
 | |
|         if not self.isNuageInfraUnderlay:
 | |
|             self.skipTest("Configured Nuage VSP SDN platform infrastructure "
 | |
|                           "does not support underlay networking: "
 | |
|                           "skipping test")
 | |
| 
 | |
|         # Creating VPC offering
 | |
|         self.debug("Creating Nuage VSP VPC offering with Source NAT service "
 | |
|                    "provider as NuageVsp...")
 | |
|         vpc_off = self.create_VpcOffering(
 | |
|             self.test_data["nuagevsp"]["vpc_offering"])
 | |
|         self.validate_VpcOffering(vpc_off, state="Enabled")
 | |
| 
 | |
|         # Creating VPC
 | |
|         self.debug("Creating a VPC with Source NAT service provider as "
 | |
|                    "NuageVsp...")
 | |
|         vpc = self.create_Vpc(vpc_off, cidr='10.1.0.0/16')
 | |
|         self.validate_Vpc(vpc, state="Enabled")
 | |
| 
 | |
|         # Creating network offering
 | |
|         self.debug("Creating Nuage VSP VPC Network offering with Source NAT "
 | |
|                    "service provider as NuageVsp...")
 | |
|         net_off = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["vpc_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off, state="Enabled")
 | |
| 
 | |
|         # Creating VPC networks in the VPC, deploying VMs, and verifying
 | |
|         # Source NAT traffic
 | |
|         self.debug("Creating a VPC network with Source NAT service...")
 | |
|         vpc_tier = self.create_Network(net_off, gateway='10.1.1.1', vpc=vpc)
 | |
|         self.validate_Network(vpc_tier, state="Implemented")
 | |
|         vpc_vr = self.get_Router(vpc_tier)
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier, vpc)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Adding Egress Network ACL rules
 | |
|         self.debug("Adding Egress Network ACL rules in the created VPC "
 | |
|                    "network to allow Source NAT (DNS & HTTP) traffic to the "
 | |
|                    "Internet from the VMs in the network...")
 | |
|         dns_rule = self.create_NetworkAclRule(
 | |
|             self.test_data["dns_rule"], traffic_type="Egress",
 | |
|             network=vpc_tier)
 | |
|         http_rule = self.create_NetworkAclRule(
 | |
|             self.test_data["http_rule"], traffic_type="Egress",
 | |
|             network=vpc_tier)
 | |
| 
 | |
|         # VSD verification for added Egress Network ACL rules
 | |
|         self.verify_vsd_firewall_rule(dns_rule, traffic_type="Egress")
 | |
|         self.verify_vsd_firewall_rule(http_rule, traffic_type="Egress")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created VPC network...")
 | |
|         vpc_vm_1 = self.create_VM(vpc_tier)
 | |
|         self.check_VM_state(vpc_vm_1, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vpc_vm_1)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm_1, vpc_tier, vpc=vpc)
 | |
| 
 | |
|         self.debug("Deploying another VM in the created VPC network...")
 | |
|         vpc_vm_2 = self.create_VM(vpc_tier)
 | |
|         self.check_VM_state(vpc_vm_2, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vpc_vm_2)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm_2, vpc_tier, vpc=vpc)
 | |
| 
 | |
|     @attr(tags=["advanced", "nuagevsp"], required_hardware="true")
 | |
|     def test_05_nuage_SourceNAT_acl_rules_traffic(self):
 | |
|         """Test Nuage VSP Source NAT functionality with different Egress
 | |
|         Firewall/Network ACL rules by performing (wget) traffic tests to the
 | |
|         Internet
 | |
|         """
 | |
| 
 | |
|         # Check if the configured Nuage VSP SDN platform infrastructure
 | |
|         # supports underlay networking, if not, skip this test.
 | |
|         # Repeat the tests in the testcases
 | |
|         # "test_03_nuage_SourceNAT_isolated_network_traffic" and
 | |
|         # "test_04_nuage_SourceNAT_vpc_network_traffic" with different Egress
 | |
|         # Firewall/Network ACL rules:
 | |
|         # 1. Allow and block Egress Firewall rules
 | |
|         # 2. Allow and block Egress Network ACL rules
 | |
|         # Verify the above Egress Firewall/Network ACL rules by verifying its
 | |
|         # Source NAT traffic test (wget www.google.com) to the Internet.
 | |
|         # Delete all the created objects (cleanup).
 | |
| 
 | |
|         if not self.isNuageInfraUnderlay:
 | |
|             self.skipTest("Configured Nuage VSP SDN platform infrastructure "
 | |
|                           "does not support underlay networking: "
 | |
|                           "skipping test")
 | |
| 
 | |
|         # Creating Isolated network offering
 | |
|         self.debug("Creating Nuage VSP Isolated Network offering with Source "
 | |
|                    "NAT service provider as NuageVsp...")
 | |
|         net_off = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off, state="Enabled")
 | |
| 
 | |
|         # Creating an Isolated network, deploying a VM, and verifying Source
 | |
|         # NAT traffic with Egress Firewall rules
 | |
|         self.debug("Creating an Isolated network with Source NAT service...")
 | |
|         network = self.create_Network(net_off, gateway='10.1.1.1')
 | |
|         self.validate_Network(network, state="Allocated")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created Isolated network...")
 | |
|         vm = self.create_VM(network)
 | |
|         self.validate_Network(network, state="Implemented")
 | |
|         vr = self.get_Router(network)
 | |
|         self.check_Router_state(vr, state="Running")
 | |
|         self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network)
 | |
|         self.verify_vsd_router(vr)
 | |
|         self.verify_vsd_vm(vm)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network)
 | |
| 
 | |
|         # Adding Egress Firewall rule
 | |
|         self.debug("Adding an Egress Firewall rule in the created Isolated "
 | |
|                    "network to block/drop Source NAT (DNS) traffic to the "
 | |
|                    "Internet from the VMs in the network...")
 | |
|         dns_rule_1 = self.create_EgressFirewallRule(
 | |
|             network, self.test_data["dns_rule"])
 | |
| 
 | |
|         # VSD verification for added Egress Firewall rule
 | |
|         self.verify_vsd_firewall_rule(dns_rule_1, traffic_type="Egress")
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         with self.assertRaises(Exception):
 | |
|             self.verify_SourceNAT_VM_traffic(vm, network, negative_test=True)
 | |
|         self.debug("Source NAT (DNS) traffic to the Internet from the "
 | |
|                    "deployed VM is blocked/dropped by the added Egress "
 | |
|                    "Firewall rule")
 | |
| 
 | |
|         # Removing Egress Firewall rule
 | |
|         self.debug("Removing the added Egress Firewall rule in the created "
 | |
|                    "Isolated network to allow Source NAT (DNS) traffic to "
 | |
|                    "the Internet from the VMs in the network "
 | |
|                    "(Default Egress Firewall rule)...")
 | |
|         dns_rule_1.delete(self.api_client)
 | |
| 
 | |
|         # VSD verification for removed Egress Firewall rule
 | |
|         with self.assertRaises(Exception):
 | |
|             self.verify_vsd_firewall_rule(dns_rule_1, traffic_type="Egress")
 | |
|         self.debug("Egress Firewall rule successfully deleted in VSD")
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network)
 | |
| 
 | |
|         # Creating VPC offering
 | |
|         self.debug("Creating Nuage VSP VPC offering with Source NAT service "
 | |
|                    "provider as NuageVsp...")
 | |
|         vpc_off = self.create_VpcOffering(
 | |
|             self.test_data["nuagevsp"]["vpc_offering"])
 | |
|         self.validate_VpcOffering(vpc_off, state="Enabled")
 | |
| 
 | |
|         # Creating VPC
 | |
|         self.debug("Creating a VPC with Source NAT service provider as "
 | |
|                    "NuageVsp...")
 | |
|         vpc = self.create_Vpc(vpc_off, cidr='10.1.0.0/16')
 | |
|         self.validate_Vpc(vpc, state="Enabled")
 | |
| 
 | |
|         # Creating VPC network offering
 | |
|         self.debug("Creating Nuage VSP VPC Network offering with Source NAT "
 | |
|                    "service provider as NuageVsp...")
 | |
|         net_off = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["vpc_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off, state="Enabled")
 | |
| 
 | |
|         # Creating a VPC network in the VPC, deploying a VM, and verifying
 | |
|         # Source NAT traffic with Network ACl rules
 | |
|         self.debug("Creating a VPC network with Source NAT service...")
 | |
|         vpc_tier = self.create_Network(net_off, gateway='10.1.1.1', vpc=vpc)
 | |
|         self.validate_Network(vpc_tier, state="Implemented")
 | |
|         vpc_vr = self.get_Router(vpc_tier)
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier, vpc)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Adding Egress Network ACL rules
 | |
|         self.debug("Adding Egress Network ACL rules in the created VPC "
 | |
|                    "network to allow Source NAT (DNS & HTTP) traffic to the "
 | |
|                    "Internet from the VMs in the network...")
 | |
|         dns_rule_2 = self.create_NetworkAclRule(
 | |
|             self.test_data["dns_rule"], traffic_type="Egress",
 | |
|             network=vpc_tier)
 | |
|         http_rule = self.create_NetworkAclRule(
 | |
|             self.test_data["http_rule"], traffic_type="Egress",
 | |
|             network=vpc_tier)
 | |
| 
 | |
|         # VSD verification for added Egress Network ACL rules
 | |
|         self.verify_vsd_firewall_rule(dns_rule_2, traffic_type="Egress")
 | |
|         self.verify_vsd_firewall_rule(http_rule, traffic_type="Egress")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created VPC network...")
 | |
|         vpc_vm = self.create_VM(vpc_tier)
 | |
|         self.check_VM_state(vpc_vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vpc_vm)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm, vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Removing Egress Network ACL rule
 | |
|         self.debug("Removing the added Egress Network ACL rule in the created "
 | |
|                    "VPC network to block Source NAT (DNS) traffic to the "
 | |
|                    "Internet from the VMs in the network "
 | |
|                    "(Default Egress Network ACL rule)...")
 | |
|         dns_rule_2.delete(self.api_client)
 | |
| 
 | |
|         # VSD verification for removed Egress Network ACL rule
 | |
|         with self.assertRaises(Exception):
 | |
|             self.verify_vsd_firewall_rule(dns_rule_2, traffic_type="Egress")
 | |
|         self.debug("Egress Network ACL rule successfully deleted in VSD")
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         with self.assertRaises(Exception):
 | |
|             self.verify_SourceNAT_VM_traffic(vpc_vm, vpc_tier, vpc=vpc,
 | |
|                                              negative_test=True)
 | |
|         self.debug("Source NAT (DNS) traffic to the Internet from the "
 | |
|                    "deployed VM is blocked by the Default Egress Network ACL "
 | |
|                    "rule")
 | |
| 
 | |
|         # Re-adding Egress Network ACL rule
 | |
|         self.debug("Re-adding the Egress Network ACL rule in the created VPC "
 | |
|                    "network to allow Source NAT (DNS) traffic to the "
 | |
|                    "Internet from the VMs in the network...")
 | |
|         dns_rule_2 = self.create_NetworkAclRule(
 | |
|             self.test_data["dns_rule"], traffic_type="Egress",
 | |
|             network=vpc_tier)
 | |
| 
 | |
|         # VSD verification for re-added Egress Network ACL rule
 | |
|         self.verify_vsd_firewall_rule(dns_rule_2, traffic_type="Egress")
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm, vpc_tier, vpc=vpc)
 | |
| 
 | |
|     @attr(tags=["advanced", "nuagevsp"], required_hardware="true")
 | |
|     def test_06_nuage_SourceNAT_vm_nic_operations_traffic(self):
 | |
|         """Test Nuage VSP Source NAT functionality with VM NIC operations by
 | |
|         performing (wget) traffic tests to the
 | |
|         Internet
 | |
|         """
 | |
| 
 | |
|         # Check if the configured Nuage VSP SDN platform infrastructure
 | |
|         # supports underlay networking, if not, skip this test.
 | |
|         # Repeat the tests in the testcase "test_03_nuage_SourceNAT_isolated_
 | |
|         # network_traffic" with VM NIC operations:
 | |
|         # 1. Updating default VM NIC
 | |
|         # 2. Removing non-default VM NIC
 | |
|         # 3. Adding and updating default VM NIC
 | |
|         # Verify the above VM NIC operations by verifying its Source NAT
 | |
|         # traffic test (wget www.google.com) to the Internet.
 | |
|         # Delete all the created objects (cleanup).
 | |
| 
 | |
|         if not self.isNuageInfraUnderlay:
 | |
|             self.skipTest("Configured Nuage VSP SDN platform infrastructure "
 | |
|                           "does not support underlay networking: "
 | |
|                           "skipping test")
 | |
| 
 | |
|         # Creating network offering
 | |
|         self.debug("Creating Nuage VSP Isolated Network offering with Source "
 | |
|                    "NAT service provider as NuageVsp...")
 | |
|         net_off = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off, state="Enabled")
 | |
| 
 | |
|         # Creating Isolated networks, deploying a multi-nic VM, and verifying
 | |
|         # Source NAT traffic with VM NIC operations
 | |
|         self.debug("Creating an Isolated network with Source NAT service...")
 | |
|         network_1 = self.create_Network(net_off, gateway='10.1.1.1')
 | |
|         self.validate_Network(network_1, state="Allocated")
 | |
| 
 | |
|         self.debug("Creating another Isolated network with Source NAT "
 | |
|                    "service...")
 | |
|         network_2 = self.create_Network(net_off, gateway='10.1.2.1')
 | |
|         self.validate_Network(network_2, state="Allocated")
 | |
| 
 | |
|         self.debug("Deploying a multi-nic VM in the created Isolated "
 | |
|                    "networks...")
 | |
|         vm = self.create_VM([network_1, network_2])
 | |
|         self.validate_Network(network_1, state="Implemented")
 | |
|         vr_1 = self.get_Router(network_1)
 | |
|         self.check_Router_state(vr_1, state="Running")
 | |
|         self.validate_Network(network_2, state="Implemented")
 | |
|         vr_2 = self.get_Router(network_2)
 | |
|         self.check_Router_state(vr_2, state="Running")
 | |
|         self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network_1)
 | |
|         self.verify_vsd_router(vr_1)
 | |
|         self.verify_vsd_network(self.domain.id, network_2)
 | |
|         self.verify_vsd_router(vr_2)
 | |
|         self.verify_vsd_vm(vm)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network_1)
 | |
|         self.verify_vsd_SourceNAT_network(network_2)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network_1)
 | |
| 
 | |
|         # Updating default VM NIC
 | |
|         # This VM NIC operation has no effect on the Source NAT functionality
 | |
|         self.debug("Updating the default nic of the multi-nic VM...")
 | |
|         self.nic_operation_VM(vm, network_2, operation="update")
 | |
| 
 | |
|         # Rebooting (stop - start) VM
 | |
|         self.debug("Rebooting the multi-nic VM after updating its default nic "
 | |
|                    "for changes to apply to the VM...")
 | |
|         vm.stop(self.api_client)
 | |
|         vm.start(self.api_client)
 | |
|         self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         updated_vm_info = VirtualMachine.list(self.api_client, id=vm.id)[0]
 | |
|         self.verify_vsd_vm(updated_vm_info)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network_1)
 | |
|         self.verify_vsd_SourceNAT_network(network_2)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network_2)
 | |
| 
 | |
|         # Removing non-default VM NIC
 | |
|         # This VM NIC operation has no effect on the Source NAT functionality
 | |
|         self.debug("Removing the non-default nic of the multi-nic VM...")
 | |
|         self.nic_operation_VM(vm, network_1, operation="remove")
 | |
| 
 | |
|         # Rebooting (stop - start) VM
 | |
|         self.debug("Rebooting the multi-nic VM after removing its non-default "
 | |
|                    "nic for changes to apply to the VM...")
 | |
|         vm.stop(self.api_client)
 | |
|         vm.start(self.api_client)
 | |
|         self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         updated_vm_info = VirtualMachine.list(self.api_client, id=vm.id)[0]
 | |
|         self.verify_vsd_vm(updated_vm_info)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network_1)
 | |
|         self.verify_vsd_SourceNAT_network(network_2)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network_2)
 | |
| 
 | |
|         # Adding and updating default VM NIC
 | |
|         # This VM NIC operation has no effect on the Source NAT functionality
 | |
|         self.debug("Re-adding the non-default nic and updating the default "
 | |
|                    "nic of the multi-nic VM...")
 | |
|         self.nic_operation_VM(vm, network_1, operation="add")
 | |
|         self.nic_operation_VM(vm, network_1, operation="update")
 | |
| 
 | |
|         # Rebooting (stop - start) VM
 | |
|         self.debug("Rebooting the multi-nic VM after re-adding its "
 | |
|                    "non-default nic for changes to apply to the VM...")
 | |
|         vm.stop(self.api_client)
 | |
|         vm.start(self.api_client)
 | |
|         self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         updated_vm_info = VirtualMachine.list(self.api_client, id=vm.id)[0]
 | |
|         self.verify_vsd_vm(updated_vm_info)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network_1)
 | |
|         self.verify_vsd_SourceNAT_network(network_2)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network_1)
 | |
| 
 | |
|     @attr(tags=["advanced", "nuagevsp"], required_hardware="true")
 | |
|     def test_07_nuage_SourceNAT_vm_migration_traffic(self):
 | |
|         """Test Nuage VSP Source NAT functionality with VM migration by
 | |
|         performing (wget) traffic tests to the Internet
 | |
|         """
 | |
| 
 | |
|         # Check if the configured Nuage VSP SDN platform infrastructure
 | |
|         # supports underlay networking, if not, skip this test.
 | |
|         # Repeat the tests in the testcase
 | |
|         # "test_03_nuage_SourceNAT_isolated_network_traffic" with migration of
 | |
|         # one of the VMs to another host (if available).
 | |
|         # Verify the above VM migration by verifying its Source NAT traffic
 | |
|         # test (wget www.google.com) to the Internet.
 | |
|         # Delete all the created objects (cleanup).
 | |
| 
 | |
|         if not self.isNuageInfraUnderlay:
 | |
|             self.skipTest("Configured Nuage VSP SDN platform infrastructure "
 | |
|                           "does not support underlay networking: "
 | |
|                           "skipping test")
 | |
| 
 | |
|         # Creating network offering
 | |
|         self.debug("Creating Nuage VSP Isolated Network offering with Source "
 | |
|                    "NAT service provider as NuageVsp...")
 | |
|         net_off = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off, state="Enabled")
 | |
| 
 | |
|         # Creating an Isolated network, deploying VMs, and verifying Source NAT
 | |
|         # traffic with VM migrations
 | |
|         self.debug("Creating an Isolated network with Source NAT service...")
 | |
|         network = self.create_Network(net_off, gateway='10.1.1.1')
 | |
|         self.validate_Network(network, state="Allocated")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created Isolated network...")
 | |
|         vm_1 = self.create_VM(network)
 | |
|         self.validate_Network(network, state="Implemented")
 | |
|         vr = self.get_Router(network)
 | |
|         self.check_Router_state(vr, state="Running")
 | |
|         self.check_VM_state(vm_1, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network)
 | |
|         self.verify_vsd_router(vr)
 | |
|         self.verify_vsd_vm(vm_1)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm_1, network)
 | |
| 
 | |
|         self.debug("Deploying another VM in the created Isolated network...")
 | |
|         vm_2 = self.create_VM(network)
 | |
|         self.check_VM_state(vm_2, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vm_2)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm_2, network)
 | |
| 
 | |
|         # VM migration
 | |
|         # This VM migration has no effect on the Source NAT functionality
 | |
|         self.debug("Migrating one of the VMs in the created Isolated network "
 | |
|                    "to another host, if available...")
 | |
|         self.migrate_VM(vm_1)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm_1, network)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm_2, network)
 | |
| 
 | |
|     @attr(tags=["advanced", "nuagevsp"], required_hardware="true")
 | |
|     def test_08_nuage_SourceNAT_network_restarts_traffic(self):
 | |
|         """Test Nuage VSP Source NAT functionality with network restarts by
 | |
|         performing (wget) traffic tests to the Internet
 | |
|         """
 | |
| 
 | |
|         # Check if the configured Nuage VSP SDN platform infrastructure
 | |
|         # supports underlay networking, if not, skip this test.
 | |
|         # Repeat the tests in the testcases
 | |
|         # "test_03_nuage_SourceNAT_isolated_network_traffic" and
 | |
|         # "test_04_nuage_SourceNAT_vpc_network_traffic" with network restarts:
 | |
|         # 1. Restart Isolated Network (cleanup = false)
 | |
|         # 2. Restart Isolated Network (cleanup = true)
 | |
|         # 3. Reboot VM in the Isolated Network
 | |
|         # 4. Restart VPC Network (cleanup = false)
 | |
|         # 5. Restart VPC Network (cleanup = true)
 | |
|         # 6. Reboot VM in the VPC Network
 | |
|         # 7. Restart VPC (cleanup = false)
 | |
|         # 8. Restart VPC (cleanup = true)
 | |
|         # Verify the above with network restarts by verifying its Source NAT
 | |
|         # traffic test (wget www.google.com) to the Internet.
 | |
|         # Delete all the created objects (cleanup).
 | |
| 
 | |
|         if not self.isNuageInfraUnderlay:
 | |
|             self.skipTest("Configured Nuage VSP SDN platform infrastructure "
 | |
|                           "does not support underlay networking: "
 | |
|                           "skipping test")
 | |
| 
 | |
|         # Creating network offering
 | |
|         self.debug("Creating Nuage VSP Isolated Network offering with Source "
 | |
|                    "NAT service provider as NuageVsp...")
 | |
|         net_off = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["isolated_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off, state="Enabled")
 | |
| 
 | |
|         # Creating an Isolated network, deploying a VM, and verifying Source
 | |
|         # NAT traffic with Isolated network restarts
 | |
|         self.debug("Creating an Isolated network with Source NAT service...")
 | |
|         network = self.create_Network(net_off, gateway='10.1.1.1')
 | |
|         self.validate_Network(network, state="Allocated")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created Isolated network...")
 | |
|         vm = self.create_VM(network)
 | |
|         self.validate_Network(network, state="Implemented")
 | |
|         vr = self.get_Router(network)
 | |
|         self.check_Router_state(vr, state="Running")
 | |
|         self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network)
 | |
|         self.verify_vsd_router(vr)
 | |
|         self.verify_vsd_vm(vm)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(network)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network)
 | |
| 
 | |
|         # Restarting Isolated network (cleanup = false)
 | |
|         # VR gets destroyed and deployed again in the Isolated network
 | |
|         # This restart has no effect on the Source NAT functionality
 | |
|         self.debug("Restarting the created Isolated network without "
 | |
|                    "cleanup...")
 | |
|         Network.restart(network, self.api_client, cleanup=False)
 | |
|         self.validate_Network(network, state="Implemented")
 | |
|         vr = self.get_Router(network)
 | |
|         self.check_Router_state(vr, state="Running")
 | |
|         self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network)
 | |
|         self.verify_vsd_router(vr)
 | |
|         self.verify_vsd_vm(vm)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network)
 | |
| 
 | |
|         # Restarting Isolated network (cleanup = true)
 | |
|         # VR gets destroyed and deployed again in the Isolated network
 | |
|         # This restart has no effect on the Source NAT functionality
 | |
|         self.debug("Restarting the created Isolated network with cleanup...")
 | |
|         Network.restart(network, self.api_client, cleanup=True)
 | |
|         self.validate_Network(network, state="Implemented")
 | |
|         vr = self.get_Router(network)
 | |
|         self.check_Router_state(vr, state="Running")
 | |
|         self.check_VM_state(vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, network)
 | |
|         self.verify_vsd_router(vr)
 | |
|         self.verify_vsd_vm(vm)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vm, network)
 | |
| 
 | |
|         # Creating VPC offering
 | |
|         self.debug("Creating Nuage VSP VPC offering with Source NAT service "
 | |
|                    "provider as NuageVsp...")
 | |
|         vpc_off = self.create_VpcOffering(
 | |
|             self.test_data["nuagevsp"]["vpc_offering"])
 | |
|         self.validate_VpcOffering(vpc_off, state="Enabled")
 | |
| 
 | |
|         # Creating VPC
 | |
|         self.debug("Creating a VPC with Source NAT service provider as "
 | |
|                    "NuageVsp...")
 | |
|         vpc = self.create_Vpc(vpc_off, cidr='10.1.0.0/16')
 | |
|         self.validate_Vpc(vpc, state="Enabled")
 | |
| 
 | |
|         # Creating VPC network offering
 | |
|         self.debug("Creating Nuage VSP VPC Network offering with Source NAT "
 | |
|                    "service provider as NuageVsp...")
 | |
|         net_off = self.create_NetworkOffering(
 | |
|             self.test_data["nuagevsp"]["vpc_network_offering"])
 | |
|         self.validate_NetworkOffering(net_off, state="Enabled")
 | |
| 
 | |
|         # Creating a VPC network in the VPC, deploying a VM, and verifying
 | |
|         # Source NAT traffic with VPC network restarts
 | |
|         self.debug("Creating a VPC network with Source NAT service...")
 | |
|         vpc_tier = self.create_Network(net_off, gateway='10.1.1.1', vpc=vpc)
 | |
|         self.validate_Network(vpc_tier, state="Implemented")
 | |
|         vpc_vr = self.get_Router(vpc_tier)
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier, vpc)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Adding Egress Network ACL rules
 | |
|         self.debug("Adding Egress Network ACL rules in the created VPC "
 | |
|                    "network to allow Source NAT (DNS & HTTP) traffic to the "
 | |
|                    "Internet from the VMs in the network...")
 | |
|         dns_rule = self.create_NetworkAclRule(
 | |
|             self.test_data["dns_rule"], traffic_type="Egress",
 | |
|             network=vpc_tier)
 | |
|         http_rule = self.create_NetworkAclRule(
 | |
|             self.test_data["http_rule"], traffic_type="Egress",
 | |
|             network=vpc_tier)
 | |
| 
 | |
|         # VSD verification for added Egress Network ACL rules
 | |
|         self.verify_vsd_firewall_rule(dns_rule, traffic_type="Egress")
 | |
|         self.verify_vsd_firewall_rule(http_rule, traffic_type="Egress")
 | |
| 
 | |
|         self.debug("Deploying a VM in the created VPC network...")
 | |
|         vpc_vm = self.create_VM(vpc_tier)
 | |
|         self.check_VM_state(vpc_vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_vm(vpc_vm)
 | |
| 
 | |
|         # VSD verification for Source NAT functionality
 | |
|         self.verify_vsd_SourceNAT_network(vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm, vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Restarting VPC network (cleanup = false)
 | |
|         # This restart has no effect on the Source NAT functionality
 | |
|         self.debug("Restarting the created VPC network without cleanup...")
 | |
|         Network.restart(vpc_tier, self.api_client, cleanup=False)
 | |
|         self.validate_Network(vpc_tier, state="Implemented")
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
|         self.check_VM_state(vpc_vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier, vpc)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
|         self.verify_vsd_vm(vpc_vm)
 | |
|         self.verify_vsd_firewall_rule(dns_rule, traffic_type="Egress")
 | |
|         self.verify_vsd_firewall_rule(http_rule, traffic_type="Egress")
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm, vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Restarting VPC network (cleanup = true)
 | |
|         # This restart has no effect on the Source NAT functionality
 | |
|         self.debug("Restarting the created VPC network with cleanup...")
 | |
|         Network.restart(vpc_tier, self.api_client, cleanup=True)
 | |
|         self.validate_Network(vpc_tier, state="Implemented")
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
|         self.check_VM_state(vpc_vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier, vpc)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
|         self.verify_vsd_vm(vpc_vm)
 | |
|         self.verify_vsd_firewall_rule(dns_rule, traffic_type="Egress")
 | |
|         self.verify_vsd_firewall_rule(http_rule, traffic_type="Egress")
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm, vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Restarting VPC (cleanup = false)
 | |
|         # VPC VR gets destroyed and deployed again in the VPC
 | |
|         # This restart has no effect on the Source NAT functionality
 | |
|         self.debug("Restarting the VPC without cleanup...")
 | |
|         self.restart_Vpc(vpc, cleanup=False)
 | |
|         self.validate_Network(vpc_tier, state="Implemented")
 | |
|         vpc_vr = self.get_Router(vpc_tier)
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
|         self.check_VM_state(vpc_vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier, vpc)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
|         self.verify_vsd_vm(vpc_vm)
 | |
|         self.verify_vsd_firewall_rule(dns_rule, traffic_type="Egress")
 | |
|         self.verify_vsd_firewall_rule(http_rule, traffic_type="Egress")
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm, vpc_tier, vpc=vpc)
 | |
| 
 | |
|         # Restarting VPC (cleanup = true)
 | |
|         # VPC VR gets destroyed and deployed again in the VPC
 | |
|         # This restart has no effect on the Source NAT functionality
 | |
|         self.debug("Restarting the VPC with cleanup...")
 | |
|         self.restart_Vpc(vpc, cleanup=True)
 | |
|         self.validate_Network(vpc_tier, state="Implemented")
 | |
|         vpc_vr = self.get_Router(vpc_tier)
 | |
|         self.check_Router_state(vpc_vr, state="Running")
 | |
|         self.check_VM_state(vpc_vm, state="Running")
 | |
| 
 | |
|         # VSD verification
 | |
|         self.verify_vsd_network(self.domain.id, vpc_tier, vpc)
 | |
|         self.verify_vsd_router(vpc_vr)
 | |
|         self.verify_vsd_vm(vpc_vm)
 | |
|         self.verify_vsd_firewall_rule(dns_rule, traffic_type="Egress")
 | |
|         self.verify_vsd_firewall_rule(http_rule, traffic_type="Egress")
 | |
| 
 | |
|         # Verifying Source NAT traffic (wget www.google.com) to the Internet
 | |
|         # from the deployed VM. This Source NAT traffic test is done through a
 | |
|         # custom init script in the guest VM template upon the VM boot up.
 | |
|         self.verify_SourceNAT_VM_traffic(vpc_vm, vpc_tier, vpc=vpc)
 |