Merge "Add nsxv3 router tempest test"
This commit is contained in:
commit
69d6936815
74
vmware_nsx_tempest/tests/nsxv3/api/test_nsx_routers.py
Normal file
74
vmware_nsx_tempest/tests/nsxv3/api/test_nsx_routers.py
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
# Copyright 2016 VMware Inc
|
||||||
|
# All Rights Reserved
|
||||||
|
# Licensed 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.
|
||||||
|
|
||||||
|
from tempest.api.network import base_routers as base
|
||||||
|
from tempest.common.utils import data_utils
|
||||||
|
from tempest import config
|
||||||
|
from tempest import test
|
||||||
|
|
||||||
|
from vmware_nsx_tempest.services import nsxv3_client
|
||||||
|
|
||||||
|
CONF = config.CONF
|
||||||
|
|
||||||
|
|
||||||
|
class NSXv3RoutersTest(base.BaseRouterTest):
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def skip_checks(cls):
|
||||||
|
super(NSXv3RoutersTest, cls).skip_checks()
|
||||||
|
if not test.is_extension_enabled('router', 'network'):
|
||||||
|
msg = "router extension not enabled."
|
||||||
|
raise cls.skipException(msg)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resource_setup(cls):
|
||||||
|
super(NSXv3RoutersTest, cls).resource_setup()
|
||||||
|
cls.nsx = nsxv3_client.NSXV3Client(CONF.nsxv3.nsx_manager,
|
||||||
|
CONF.nsxv3.nsx_user,
|
||||||
|
CONF.nsxv3.nsx_password)
|
||||||
|
|
||||||
|
@test.attr(type='nsxv3')
|
||||||
|
@test.idempotent_id('0e9938bc-d2a3-4a9a-a4f9-7a93ee8bb344')
|
||||||
|
def test_create_update_delete_nsx_router(self):
|
||||||
|
# Create a router
|
||||||
|
name = data_utils.rand_name('router-')
|
||||||
|
router = self.create_router(name, admin_state_up=True)
|
||||||
|
self.addCleanup(self._delete_router, router['id'])
|
||||||
|
nsx_router = self.nsx.get_logical_router(router['name'],
|
||||||
|
router['id'])
|
||||||
|
self.assertEqual(router['name'], name)
|
||||||
|
self.assertEqual(router['admin_state_up'], True)
|
||||||
|
self.assertIsNotNone(nsx_router)
|
||||||
|
# Update the name of router and verify if it is updated on both
|
||||||
|
# neutron and nsx backend
|
||||||
|
updated_name = 'updated ' + name
|
||||||
|
update_body = self.client.update_router(router['id'],
|
||||||
|
name=updated_name)
|
||||||
|
updated_router = update_body['router']
|
||||||
|
nsx_router = self.nsx.get_logical_router(updated_router['name'],
|
||||||
|
updated_router['id'])
|
||||||
|
self.assertEqual(updated_router['name'], updated_name)
|
||||||
|
self.assertIsNotNone(nsx_router)
|
||||||
|
# Delete the router and verify it is deleted on nsx backend
|
||||||
|
self.client.delete_router(updated_router['id'])
|
||||||
|
nsx_router = self.nsx.get_logical_router(updated_router['name'],
|
||||||
|
updated_router['id'])
|
||||||
|
self.assertIsNone(nsx_router)
|
||||||
|
|
||||||
|
def _delete_router(self, router_id):
|
||||||
|
# Delete the router in case the test exits with any exception
|
||||||
|
list_body = self.client.list_routers()
|
||||||
|
for router in list_body['router']:
|
||||||
|
if router['id'] == router_id:
|
||||||
|
self.client.delete_router(router_id)
|
Loading…
x
Reference in New Issue
Block a user