mirror of https://github.com/apache/cloudstack.git
test: Added Marvin test for domain specific VPC offerings
Signed-off-by: Abhishek Kumar <abhishek.kumar@shapeblue.com>
This commit is contained in:
parent
b749fe18bd
commit
89859e4fba
|
|
@ -0,0 +1,403 @@
|
|||
# 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.
|
||||
""" BVT tests for Vpc offerings"""
|
||||
|
||||
#Import Local Modules
|
||||
from marvin.codes import FAILED
|
||||
from marvin.cloudstackTestCase import cloudstackTestCase
|
||||
from marvin.cloudstackAPI import (createVPCOffering,
|
||||
listVPCOfferings,
|
||||
updateVPCOffering)
|
||||
from marvin.lib.utils import (isAlmostEqual,
|
||||
cleanup_resources,
|
||||
random_gen)
|
||||
from marvin.lib.base import (Domain,
|
||||
VpcOffering,
|
||||
Account,
|
||||
VPC)
|
||||
from marvin.lib.common import (get_domain,
|
||||
get_zone)
|
||||
from nose.plugins.attrib import attr
|
||||
|
||||
import time
|
||||
from marvin.sshClient import SshClient
|
||||
from marvin.cloudstackException import CloudstackAPIException
|
||||
from marvin.lib.decoratorGenerators import skipTestIf
|
||||
|
||||
|
||||
_multiprocess_shared_ = True
|
||||
|
||||
class Services:
|
||||
"""Test VPC network services - Port Forwarding Rules Test Data Class.
|
||||
"""
|
||||
|
||||
def __init__(self):
|
||||
self.services = {
|
||||
"vpc_offering": {
|
||||
"name": 'Redundant VPC off',
|
||||
"displaytext": 'Redundant VPC off',
|
||||
"supportedservices": 'Dhcp,Dns,SourceNat,PortForwarding,Vpn,Lb,UserData,StaticNat',
|
||||
"serviceProviderList": {
|
||||
"Vpn": 'VpcVirtualRouter',
|
||||
"Dhcp": 'VpcVirtualRouter',
|
||||
"Dns": 'VpcVirtualRouter',
|
||||
"SourceNat": 'VpcVirtualRouter',
|
||||
"PortForwarding": 'VpcVirtualRouter',
|
||||
"Lb": 'VpcVirtualRouter',
|
||||
"UserData": 'VpcVirtualRouter',
|
||||
"StaticNat": 'VpcVirtualRouter',
|
||||
"NetworkACL": 'VpcVirtualRouter'
|
||||
},
|
||||
},
|
||||
"vpc": {
|
||||
"name": "TestVPC",
|
||||
"displaytext": "TestVPC",
|
||||
"cidr": '10.0.0.0/16'
|
||||
}
|
||||
}
|
||||
|
||||
class TestCreateDomainsVpcOffering(cloudstackTestCase):
|
||||
|
||||
def setUp(self):
|
||||
self.services = self.testClient.getParsedTestDataConfig()
|
||||
self.localservices = Services().services
|
||||
self.apiclient = self.testClient.getApiClient()
|
||||
self.dbclient = self.testClient.getDbConnection()
|
||||
self.cleanup = []
|
||||
return
|
||||
|
||||
def tearDown(self):
|
||||
try:
|
||||
#Clean up, terminate the created templates
|
||||
cleanup_resources(self.apiclient, self.cleanup)
|
||||
|
||||
except Exception as e:
|
||||
raise Exception("Warning: Exception during cleanup : %s" % e)
|
||||
return
|
||||
|
||||
@classmethod
|
||||
def setUpClass(cls):
|
||||
testClient = super(TestCreateDomainsVpcOffering, cls).getClsTestClient()
|
||||
cls.apiclient = testClient.getApiClient()
|
||||
cls.services = testClient.getParsedTestDataConfig()
|
||||
# Create domains
|
||||
cls.domain_1 = Domain.create(
|
||||
cls.apiclient,
|
||||
cls.services["acl"]["domain1"]
|
||||
)
|
||||
cls.domain_11 = Domain.create(
|
||||
cls.apiclient,
|
||||
cls.services["acl"]["domain11"],
|
||||
parentdomainid=cls.domain_1.id
|
||||
)
|
||||
cls.domain_2 = Domain.create(
|
||||
cls.apiclient,
|
||||
cls.services["acl"]["domain2"]
|
||||
)
|
||||
cls._cleanup = [
|
||||
cls.domain_11,
|
||||
cls.domain_1,
|
||||
cls.domain_2
|
||||
]
|
||||
return
|
||||
|
||||
@classmethod
|
||||
def tearDownClass(cls):
|
||||
try:
|
||||
cls.apiclient = super(
|
||||
TestCreateDomainsVpcOffering,
|
||||
cls).getClsTestClient().getApiClient()
|
||||
# Clean up, terminate the created templates
|
||||
cleanup_resources(cls.apiclient, cls._cleanup)
|
||||
|
||||
except Exception as e:
|
||||
raise
|
||||
|
||||
@attr(
|
||||
tags=[
|
||||
"advanced",
|
||||
"basic",
|
||||
"eip",
|
||||
"sg",
|
||||
"advancedns",
|
||||
"smoke"],
|
||||
required_hardware="false")
|
||||
def test_01_create_vpc_offering(self):
|
||||
"""Test to create vpc offering
|
||||
|
||||
# Validate the following:
|
||||
# 1. createVPCOfferings should return valid info for new offering
|
||||
# 2. The Cloud Database contains the valid information
|
||||
"""
|
||||
offering_data_domainid = "{0},{1}".format(self.domain_11.id, self.domain_2.id)
|
||||
offering_data = self.localservices["vpc_offering"]
|
||||
cmd = createVPCOffering.createVPCOfferingCmd()
|
||||
cmd.name = "-".join([offering_data["name"], random_gen()])
|
||||
cmd.displaytext = offering_data["displaytext"]
|
||||
cmd.supportedServices = offering_data["supportedservices"]
|
||||
cmd.domainid = offering_data_domainid
|
||||
if "serviceProviderList" in offering_data:
|
||||
for service, provider in offering_data["serviceProviderList"].items():
|
||||
providers = provider
|
||||
if isinstance(provider, str):
|
||||
providers = [provider]
|
||||
|
||||
for provider_item in providers:
|
||||
cmd.serviceproviderlist.append({
|
||||
'service': service,
|
||||
'provider': provider_item
|
||||
})
|
||||
|
||||
vpc_offering = VpcOffering(self.apiclient.createVPCOffering(cmd).__dict__)
|
||||
self.cleanup.append(vpc_offering)
|
||||
|
||||
self.debug("Created Vpc offering with ID: %s" % vpc_offering.id)
|
||||
|
||||
cmd = listVPCOfferings.listVPCOfferingsCmd()
|
||||
cmd.id = vpc_offering.id
|
||||
list_vpc_response = self.apiclient.listVPCOfferings(cmd)
|
||||
self.assertEqual(
|
||||
isinstance(list_vpc_response, list),
|
||||
True,
|
||||
"Check list response returns a valid list"
|
||||
)
|
||||
self.assertNotEqual(
|
||||
len(list_vpc_response),
|
||||
0,
|
||||
"Check Vpc offering is created"
|
||||
)
|
||||
vpc_response = list_vpc_response[0]
|
||||
|
||||
self.assertEqual(
|
||||
vpc_response.id,
|
||||
vpc_offering.id,
|
||||
"Check server id in createVPCOffering"
|
||||
)
|
||||
self.assertEqual(
|
||||
vpc_response.displaytext,
|
||||
self.localservices["vpc_offering"]["displaytext"],
|
||||
"Check server displaytext in createVPCOffering"
|
||||
)
|
||||
self.assertItemsEqual(
|
||||
vpc_response.domainid.split(","),
|
||||
offering_data_domainid.split(","),
|
||||
"Check domainid in createVPCOffering"
|
||||
)
|
||||
return
|
||||
|
||||
class TestDomainsVpcOfferings(cloudstackTestCase):
|
||||
|
||||
def setUp(self):
|
||||
self.apiclient = self.testClient.getApiClient()
|
||||
self.dbclient = self.testClient.getDbConnection()
|
||||
self.cleanup = []
|
||||
|
||||
def tearDown(self):
|
||||
|
||||
try:
|
||||
#Clean up, terminate the created templates
|
||||
cleanup_resources(self.apiclient, self.cleanup)
|
||||
|
||||
except Exception as e:
|
||||
raise Exception("Warning: Exception during cleanup : %s" % e)
|
||||
return
|
||||
|
||||
@classmethod
|
||||
def setUpClass(cls):
|
||||
testClient = super(TestDomainsVpcOfferings, cls).getClsTestClient()
|
||||
cls.apiclient = testClient.getApiClient()
|
||||
cls.localservices = Services().services
|
||||
cls.services = testClient.getParsedTestDataConfig()
|
||||
# Create domains
|
||||
cls.domain_1 = Domain.create(
|
||||
cls.apiclient,
|
||||
cls.services["acl"]["domain1"]
|
||||
)
|
||||
cls.domain_11 = Domain.create(
|
||||
cls.apiclient,
|
||||
cls.services["acl"]["domain11"],
|
||||
parentdomainid=cls.domain_1.id
|
||||
)
|
||||
cls.domain_2 = Domain.create(
|
||||
cls.apiclient,
|
||||
cls.services["acl"]["domain2"]
|
||||
)
|
||||
cls.domain_3 = Domain.create(
|
||||
cls.apiclient,
|
||||
cls.services["acl"]["domain12"]
|
||||
)
|
||||
|
||||
cls.zone = get_zone(cls.apiclient, testClient.getZoneForTests())
|
||||
|
||||
cls.vpc_offering = VpcOffering.create(
|
||||
cls.apiclient,
|
||||
cls.services["vpc_offering"]
|
||||
)
|
||||
# Enable Vpc offering
|
||||
cls.vpc_offering.update(cls.apiclient, state='Enabled')
|
||||
cls._cleanup = [
|
||||
cls.vpc_offering,
|
||||
cls.domain_11,
|
||||
cls.domain_1,
|
||||
cls.domain_2,
|
||||
cls.domain_3
|
||||
]
|
||||
return
|
||||
|
||||
@classmethod
|
||||
def tearDownClass(cls):
|
||||
try:
|
||||
cls.apiclient = super(TestDomainsVpcOfferings, cls).getClsTestClient().getApiClient()
|
||||
cleanup_resources(cls.apiclient, cls._cleanup)
|
||||
except Exception as e:
|
||||
raise Exception("Warning: Exception during cleanup : %s" % e)
|
||||
return
|
||||
|
||||
@attr(tags=["advanced", "basic", "eip", "sg", "advancedns", "smoke"], required_hardware="false")
|
||||
def test_02_edit_vpc_offering(self):
|
||||
"""Test to update existing vpc offering"""
|
||||
|
||||
# 1. updateVPCOffering should return a valid information for the updated offering
|
||||
# 2. updateVPCOffering should fail while tring to add child domain but parent domain
|
||||
# is already present
|
||||
# 3. updateVPCOffering should be able to add new domain to the offering
|
||||
self.debug("Updating vpc offering with ID: %s" %
|
||||
self.vpc_offering.id)
|
||||
|
||||
offering_data_domainid = "{0},{1}".format(self.domain_1.id, self.domain_2.id)
|
||||
cmd = updateVPCOffering.updateVPCOfferingCmd()
|
||||
cmd.id = self.vpc_offering.id
|
||||
cmd.domainid = offering_data_domainid
|
||||
self.apiclient.updateVPCOffering(cmd)
|
||||
|
||||
cmd = listVPCOfferings.listVPCOfferingsCmd()
|
||||
cmd.id = self.vpc_offering.id
|
||||
list_vpc_response = self.apiclient.listVPCOfferings(cmd)
|
||||
self.assertEqual(
|
||||
isinstance(list_vpc_response, list),
|
||||
True,
|
||||
"Check list response returns a valid list"
|
||||
)
|
||||
|
||||
self.assertNotEqual(
|
||||
len(list_vpc_response),
|
||||
0,
|
||||
"Check Vpc offering is updated"
|
||||
)
|
||||
self.assertItemsEqual(
|
||||
list_vpc_response[0].domainid.split(","),
|
||||
offering_data_domainid.split(","),
|
||||
"Check domainid in createVPCOffering"
|
||||
)
|
||||
|
||||
cmd = updateVPCOffering.updateVPCOfferingCmd()
|
||||
# Add parameters for API call
|
||||
cmd.id = self.vpc_offering.id
|
||||
cmd.domainid = self.domain_11.id
|
||||
try:
|
||||
self.apiclient.updateVPCOffering(cmd)
|
||||
self.fail("Child domain added to offering when parent domain already exist. Must be an error.")
|
||||
except Exception as e:
|
||||
self.debug("Child domain check %s" % e)
|
||||
|
||||
@attr(
|
||||
tags=[
|
||||
"advanced",
|
||||
"basic",
|
||||
"eip",
|
||||
"sg",
|
||||
"advancedns",
|
||||
"smoke"],
|
||||
required_hardware="false")
|
||||
def test_03_create_vpc_domain_vpc_offering(self):
|
||||
"""Test to creating vpc for an existing domain specified vpc offering"""
|
||||
|
||||
# Validate the following:
|
||||
# 1. Vpc creation should fail for the user from a different domain
|
||||
# 2. Vpc creation should work for users from domains for which offering is specified
|
||||
self.debug("Deploying VM using vpc offering with ID: %s" %
|
||||
self.vpc_offering.id)
|
||||
|
||||
self.invalid_account = Account.create(
|
||||
self.apiclient,
|
||||
self.services["account"],
|
||||
domainid=self.domain_3.id
|
||||
)
|
||||
self.cleanup.append(self.invalid_account)
|
||||
|
||||
try:
|
||||
VPC.create(
|
||||
apiclient=self.apiclient,
|
||||
services=self.services["vpc"],
|
||||
account=self.invalid_account.name,
|
||||
domainid=self.invalid_account.domainid,
|
||||
zoneid=self.zone.id,
|
||||
vpcofferingid=self.vpc_offering.id
|
||||
)
|
||||
self.fail("Vpc created for a user from domain which has not been specified for service offering. Must be an error.")
|
||||
except CloudstackAPIException:
|
||||
self.debug("Vpc creation for invalid user check")
|
||||
|
||||
self.valid_account_1 = Account.create(
|
||||
self.apiclient,
|
||||
self.services["account"],
|
||||
domainid=self.domain_1.id
|
||||
)
|
||||
self.cleanup.append(self.valid_account_1)
|
||||
VPC.create(
|
||||
apiclient=self.apiclient,
|
||||
services=self.services["vpc"],
|
||||
account=self.valid_account_1.name,
|
||||
domainid=self.valid_account_1.domainid,
|
||||
zoneid=self.zone.id,
|
||||
vpcofferingid=self.vpc_offering.id
|
||||
)
|
||||
self.debug("Vpc created for first subdomain %s" % self.valid_account_1.domainid)
|
||||
|
||||
self.valid_account_2 = Account.create(
|
||||
self.apiclient,
|
||||
self.services["account2"],
|
||||
domainid=self.domain_2.id
|
||||
)
|
||||
self.cleanup.append(self.valid_account_2)
|
||||
VPC.create(
|
||||
apiclient=self.apiclient,
|
||||
services=self.services["vpc"],
|
||||
account=self.valid_account_2.name,
|
||||
domainid=self.valid_account_2.domainid,
|
||||
zoneid=self.zone.id,
|
||||
vpcofferingid=self.vpc_offering.id
|
||||
)
|
||||
self.debug("Vpc created for second subdomain %s" % self.valid_account_2.domainid)
|
||||
|
||||
self.valid_account_3 = Account.create(
|
||||
self.apiclient,
|
||||
self.services["user"],
|
||||
domainid=self.domain_11.id
|
||||
)
|
||||
self.cleanup.append(self.valid_account_3)
|
||||
VPC.create(
|
||||
apiclient=self.apiclient,
|
||||
services=self.services["vpc"],
|
||||
account=self.valid_account_3.name,
|
||||
domainid=self.valid_account_3.domainid,
|
||||
zoneid=self.zone.id,
|
||||
vpcofferingid=self.vpc_offering.id
|
||||
)
|
||||
self.debug("Vpc created for first child subdomain %s" % self.valid_account_3.domainid)
|
||||
|
||||
return
|
||||
Loading…
Reference in New Issue