Merge "Remove neutron OO wrappers"

This commit is contained in:
Jenkins 2016-06-15 18:43:59 +00:00 committed by Gerrit Code Review
commit 777a307b3c
6 changed files with 154 additions and 340 deletions

View File

@ -30,7 +30,6 @@ from tempest import config
from tempest import exceptions from tempest import exceptions
from tempest.lib.common.utils import test_utils from tempest.lib.common.utils import test_utils
from tempest.lib import exceptions as lib_exc from tempest.lib import exceptions as lib_exc
from tempest.scenario import network_resources
import tempest.test import tempest.test
CONF = config.CONF CONF = config.CONF
@ -705,12 +704,12 @@ class NetworkScenarioTest(ScenarioTest):
tenant_id = networks_client.tenant_id tenant_id = networks_client.tenant_id
name = data_utils.rand_name(namestart) name = data_utils.rand_name(namestart)
result = networks_client.create_network(name=name, tenant_id=tenant_id) result = networks_client.create_network(name=name, tenant_id=tenant_id)
network = network_resources.DeletableNetwork( network = result['network']
networks_client=networks_client, routers_client=routers_client,
**result['network']) self.assertEqual(network['name'], name)
self.assertEqual(network.name, name)
self.addCleanup(test_utils.call_and_ignore_notfound_exc, self.addCleanup(test_utils.call_and_ignore_notfound_exc,
network.delete) self.networks_client.delete_network,
network['id'])
return network return network
def _list_networks(self, *args, **kwargs): def _list_networks(self, *args, **kwargs):
@ -780,13 +779,13 @@ class NetworkScenarioTest(ScenarioTest):
# blocks until an unallocated block is found. # blocks until an unallocated block is found.
for subnet_cidr in tenant_cidr.subnet(num_bits): for subnet_cidr in tenant_cidr.subnet(num_bits):
str_cidr = str(subnet_cidr) str_cidr = str(subnet_cidr)
if cidr_in_use(str_cidr, tenant_id=network.tenant_id): if cidr_in_use(str_cidr, tenant_id=network['tenant_id']):
continue continue
subnet = dict( subnet = dict(
name=data_utils.rand_name(namestart), name=data_utils.rand_name(namestart),
network_id=network.id, network_id=network['id'],
tenant_id=network.tenant_id, tenant_id=network['tenant_id'],
cidr=str_cidr, cidr=str_cidr,
ip_version=ip_version, ip_version=ip_version,
**kwargs **kwargs
@ -799,11 +798,13 @@ class NetworkScenarioTest(ScenarioTest):
if not is_overlapping_cidr: if not is_overlapping_cidr:
raise raise
self.assertIsNotNone(result, 'Unable to allocate tenant network') self.assertIsNotNone(result, 'Unable to allocate tenant network')
subnet = network_resources.DeletableSubnet(
subnets_client=subnets_client, subnet = result['subnet']
routers_client=routers_client, **result['subnet']) self.assertEqual(subnet['cidr'], str_cidr)
self.assertEqual(subnet.cidr, str_cidr)
self.addCleanup(test_utils.call_and_ignore_notfound_exc, subnet.delete) self.addCleanup(test_utils.call_and_ignore_notfound_exc,
subnets_client.delete_subnet, subnet['id'])
return subnet return subnet
def _create_port(self, network_id, client=None, namestart='port-quotatest', def _create_port(self, network_id, client=None, namestart='port-quotatest',
@ -816,9 +817,9 @@ class NetworkScenarioTest(ScenarioTest):
network_id=network_id, network_id=network_id,
**kwargs) **kwargs)
self.assertIsNotNone(result, 'Unable to allocate port') self.assertIsNotNone(result, 'Unable to allocate port')
port = network_resources.DeletablePort(ports_client=client, port = result['port']
**result['port']) self.addCleanup(test_utils.call_and_ignore_notfound_exc,
self.addCleanup(test_utils.call_and_ignore_notfound_exc, port.delete) client.delete_port, port['id'])
return port return port
def _get_server_port_id_and_ip4(self, server, ip_addr=None): def _get_server_port_id_and_ip4(self, server, ip_addr=None):
@ -853,7 +854,7 @@ class NetworkScenarioTest(ScenarioTest):
net = self._list_networks(name=network_name) net = self._list_networks(name=network_name)
self.assertNotEqual(len(net), 0, self.assertNotEqual(len(net), 0,
"Unable to get network by name: %s" % network_name) "Unable to get network by name: %s" % network_name)
return network_resources.AttributeDict(net[0]) return net[0]
def create_floating_ip(self, thing, external_network_id=None, def create_floating_ip(self, thing, external_network_id=None,
port_id=None, client=None): port_id=None, client=None):
@ -872,44 +873,51 @@ class NetworkScenarioTest(ScenarioTest):
tenant_id=thing['tenant_id'], tenant_id=thing['tenant_id'],
fixed_ip_address=ip4 fixed_ip_address=ip4
) )
floating_ip = network_resources.DeletableFloatingIp( floating_ip = result['floatingip']
client=client,
**result['floatingip'])
self.addCleanup(test_utils.call_and_ignore_notfound_exc, self.addCleanup(test_utils.call_and_ignore_notfound_exc,
floating_ip.delete) self.floating_ips_client.delete_floatingip,
floating_ip['id'])
return floating_ip return floating_ip
def _associate_floating_ip(self, floating_ip, server): def _associate_floating_ip(self, floating_ip, server):
port_id, _ = self._get_server_port_id_and_ip4(server) port_id, _ = self._get_server_port_id_and_ip4(server)
floating_ip.update(port_id=port_id) kwargs = dict(port_id=port_id)
self.assertEqual(port_id, floating_ip.port_id) floating_ip = self.floating_ips_client.update_floatingip(
floating_ip['id'], **kwargs)['floatingip']
self.assertEqual(port_id, floating_ip['port_id'])
return floating_ip return floating_ip
def _disassociate_floating_ip(self, floating_ip): def _disassociate_floating_ip(self, floating_ip):
""":param floating_ip: type DeletableFloatingIp""" """:param floating_ip: floating_ips_client.create_floatingip"""
floating_ip.update(port_id=None) kwargs = dict(port_id=None)
self.assertIsNone(floating_ip.port_id) floating_ip = self.floating_ips_client.update_floatingip(
floating_ip['id'], **kwargs)['floatingip']
self.assertIsNone(floating_ip['port_id'])
return floating_ip return floating_ip
def check_floating_ip_status(self, floating_ip, status): def check_floating_ip_status(self, floating_ip, status):
"""Verifies floatingip reaches the given status """Verifies floatingip reaches the given status
:param floating_ip: network_resources.DeletableFloatingIp floating :param dict floating_ip: floating IP dict to check status
IP to check status
:param status: target status :param status: target status
:raises: AssertionError if status doesn't match :raises: AssertionError if status doesn't match
""" """
floatingip_id = floating_ip['id']
def refresh(): def refresh():
floating_ip.refresh() result = (self.floating_ips_client.
return status == floating_ip.status show_floatingip(floatingip_id)['floatingip'])
return status == result['status']
tempest.test.call_until_true(refresh, tempest.test.call_until_true(refresh,
CONF.network.build_timeout, CONF.network.build_timeout,
CONF.network.build_interval) CONF.network.build_interval)
self.assertEqual(status, floating_ip.status, floating_ip = self.floating_ips_client.show_floatingip(
floatingip_id)['floatingip']
self.assertEqual(status, floating_ip['status'],
message="FloatingIP: {fp} is at status: {cst}. " message="FloatingIP: {fp} is at status: {cst}. "
"failed to reach status: {st}" "failed to reach status: {st}"
.format(fp=floating_ip, cst=floating_ip.status, .format(fp=floating_ip, cst=floating_ip['status'],
st=status)) st=status))
LOG.info("FloatingIP: {fp} is at status: {st}" LOG.info("FloatingIP: {fp} is at status: {st}"
.format(fp=floating_ip, st=status)) .format(fp=floating_ip, st=status))
@ -982,8 +990,8 @@ class NetworkScenarioTest(ScenarioTest):
secgroup=secgroup, secgroup=secgroup,
security_groups_client=security_groups_client) security_groups_client=security_groups_client)
for rule in rules: for rule in rules:
self.assertEqual(tenant_id, rule.tenant_id) self.assertEqual(tenant_id, rule['tenant_id'])
self.assertEqual(secgroup.id, rule.security_group_id) self.assertEqual(secgroup['id'], rule['security_group_id'])
return secgroup return secgroup
def _create_empty_security_group(self, client=None, tenant_id=None, def _create_empty_security_group(self, client=None, tenant_id=None,
@ -995,7 +1003,7 @@ class NetworkScenarioTest(ScenarioTest):
- IPv6 egress to any - IPv6 egress to any
:param tenant_id: secgroup will be created in this tenant :param tenant_id: secgroup will be created in this tenant
:returns: DeletableSecurityGroup -- containing the secgroup created :returns: the created security group
""" """
if client is None: if client is None:
client = self.security_groups_client client = self.security_groups_client
@ -1007,15 +1015,14 @@ class NetworkScenarioTest(ScenarioTest):
description=sg_desc) description=sg_desc)
sg_dict['tenant_id'] = tenant_id sg_dict['tenant_id'] = tenant_id
result = client.create_security_group(**sg_dict) result = client.create_security_group(**sg_dict)
secgroup = network_resources.DeletableSecurityGroup(
client=client, routers_client=self.routers_client, secgroup = result['security_group']
**result['security_group'] self.assertEqual(secgroup['name'], sg_name)
) self.assertEqual(tenant_id, secgroup['tenant_id'])
self.assertEqual(secgroup.name, sg_name) self.assertEqual(secgroup['description'], sg_desc)
self.assertEqual(tenant_id, secgroup.tenant_id)
self.assertEqual(secgroup.description, sg_desc)
self.addCleanup(test_utils.call_and_ignore_notfound_exc, self.addCleanup(test_utils.call_and_ignore_notfound_exc,
secgroup.delete) client.delete_security_group, secgroup['id'])
return secgroup return secgroup
def _default_security_group(self, client=None, tenant_id=None): def _default_security_group(self, client=None, tenant_id=None):
@ -1033,8 +1040,7 @@ class NetworkScenarioTest(ScenarioTest):
] ]
msg = "No default security group for tenant %s." % (tenant_id) msg = "No default security group for tenant %s." % (tenant_id)
self.assertTrue(len(sgs) > 0, msg) self.assertTrue(len(sgs) > 0, msg)
return network_resources.DeletableSecurityGroup(client=client, return sgs[0]
**sgs[0])
def _create_security_group_rule(self, secgroup=None, def _create_security_group_rule(self, secgroup=None,
sec_group_rules_client=None, sec_group_rules_client=None,
@ -1045,7 +1051,7 @@ class NetworkScenarioTest(ScenarioTest):
Create a rule in a secgroup. if secgroup not defined will search for Create a rule in a secgroup. if secgroup not defined will search for
default secgroup in tenant_id. default secgroup in tenant_id.
:param secgroup: type DeletableSecurityGroup. :param secgroup: the security group.
:param tenant_id: if secgroup not passed -- the tenant in which to :param tenant_id: if secgroup not passed -- the tenant in which to
search for default secgroup search for default secgroup
:param kwargs: a dictionary containing rule parameters: :param kwargs: a dictionary containing rule parameters:
@ -1067,17 +1073,15 @@ class NetworkScenarioTest(ScenarioTest):
secgroup = self._default_security_group( secgroup = self._default_security_group(
client=security_groups_client, tenant_id=tenant_id) client=security_groups_client, tenant_id=tenant_id)
ruleset = dict(security_group_id=secgroup.id, ruleset = dict(security_group_id=secgroup['id'],
tenant_id=secgroup.tenant_id) tenant_id=secgroup['tenant_id'])
ruleset.update(kwargs) ruleset.update(kwargs)
sg_rule = sec_group_rules_client.create_security_group_rule(**ruleset) sg_rule = sec_group_rules_client.create_security_group_rule(**ruleset)
sg_rule = network_resources.DeletableSecurityGroupRule( sg_rule = sg_rule['security_group_rule']
client=sec_group_rules_client,
**sg_rule['security_group_rule'] self.assertEqual(secgroup['tenant_id'], sg_rule['tenant_id'])
) self.assertEqual(secgroup['id'], sg_rule['security_group_id'])
self.assertEqual(secgroup.tenant_id, sg_rule.tenant_id)
self.assertEqual(secgroup.id, sg_rule.security_group_id)
return sg_rule return sg_rule
@ -1131,7 +1135,7 @@ class NetworkScenarioTest(ScenarioTest):
if msg not in ex._error_string: if msg not in ex._error_string:
raise ex raise ex
else: else:
self.assertEqual(r_direction, sg_rule.direction) self.assertEqual(r_direction, sg_rule['direction'])
rules.append(sg_rule) rules.append(sg_rule)
return rules return rules
@ -1153,10 +1157,11 @@ class NetworkScenarioTest(ScenarioTest):
network_id = CONF.network.public_network_id network_id = CONF.network.public_network_id
if router_id: if router_id:
body = client.show_router(router_id) body = client.show_router(router_id)
return network_resources.AttributeDict(**body['router']) return body['router']
elif network_id: elif network_id:
router = self._create_router(client, tenant_id) router = self._create_router(client, tenant_id)
router.set_gateway(network_id) kwargs = {'external_gateway_info': dict(network_id=network_id)}
router = client.update_router(router['id'], **kwargs)['router']
return router return router
else: else:
raise Exception("Neither of 'public_router_id' or " raise Exception("Neither of 'public_router_id' or "
@ -1172,15 +1177,18 @@ class NetworkScenarioTest(ScenarioTest):
result = client.create_router(name=name, result = client.create_router(name=name,
admin_state_up=True, admin_state_up=True,
tenant_id=tenant_id) tenant_id=tenant_id)
router = network_resources.DeletableRouter(routers_client=client, router = result['router']
**result['router']) self.assertEqual(router['name'], name)
self.assertEqual(router.name, name) self.addCleanup(test_utils.call_and_ignore_notfound_exc,
self.addCleanup(test_utils.call_and_ignore_notfound_exc, router.delete) client.delete_router,
router['id'])
return router return router
def _update_router_admin_state(self, router, admin_state_up): def _update_router_admin_state(self, router, admin_state_up):
router.update(admin_state_up=admin_state_up) kwargs = dict(admin_state_up=admin_state_up)
self.assertEqual(admin_state_up, router.admin_state_up) router = self.routers_client.update_router(
router['id'], **kwargs)['router']
self.assertEqual(admin_state_up, router['admin_state_up'])
def create_networks(self, networks_client=None, def create_networks(self, networks_client=None,
routers_client=None, subnets_client=None, routers_client=None, subnets_client=None,
@ -1213,7 +1221,6 @@ class NetworkScenarioTest(ScenarioTest):
tenant_id=tenant_id) tenant_id=tenant_id)
router = self._get_router(client=routers_client, router = self._get_router(client=routers_client,
tenant_id=tenant_id) tenant_id=tenant_id)
subnet_kwargs = dict(network=network, subnet_kwargs = dict(network=network,
subnets_client=subnets_client, subnets_client=subnets_client,
routers_client=routers_client) routers_client=routers_client)
@ -1221,7 +1228,17 @@ class NetworkScenarioTest(ScenarioTest):
if dns_nameservers is not None: if dns_nameservers is not None:
subnet_kwargs['dns_nameservers'] = dns_nameservers subnet_kwargs['dns_nameservers'] = dns_nameservers
subnet = self._create_subnet(**subnet_kwargs) subnet = self._create_subnet(**subnet_kwargs)
subnet.add_to_router(router.id) if not routers_client:
routers_client = self.routers_client
router_id = router['id']
routers_client.add_router_interface(router_id,
subnet_id=subnet['id'])
# save a cleanup job to remove this association between
# router and subnet
self.addCleanup(test_utils.call_and_ignore_notfound_exc,
routers_client.remove_router_interface, router_id,
subnet_id=subnet['id'])
return network, subnet, router return network, subnet, router

View File

@ -1,220 +0,0 @@
# Copyright 2013 Hewlett-Packard Development Company, L.P.
# 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.
import abc
import time
import six
from tempest import exceptions
from tempest.lib.common.utils import misc
class AttributeDict(dict):
"""Provide attribute access (dict.key) to dictionary values."""
def __getattr__(self, name):
"""Allow attribute access for all keys in the dict."""
if name in self:
return self[name]
return super(AttributeDict, self).__getattribute__(name)
@six.add_metaclass(abc.ABCMeta)
class DeletableResource(AttributeDict):
"""Support deletion of neutron resources (networks, subnets)
via a delete() method, as is supported by keystone and nova resources.
"""
def __init__(self, *args, **kwargs):
self.client = kwargs.pop('client', None)
self.networks_client = kwargs.pop('networks_client', None)
self.routers_client = kwargs.pop('routers_client', None)
self.subnets_client = kwargs.pop('subnets_client', None)
self.ports_client = kwargs.pop('ports_client', None)
super(DeletableResource, self).__init__(*args, **kwargs)
def __str__(self):
return '<%s id="%s" name="%s">' % (self.__class__.__name__,
self.id, self.name)
@abc.abstractmethod
def delete(self):
return
@abc.abstractmethod
def refresh(self):
return
def __hash__(self):
return hash(self.id)
def wait_for_status(self, status):
if not hasattr(self, 'status'):
return
def helper_get():
self.refresh()
return self
return self.wait_for_resource_status(helper_get, status)
def wait_for_resource_status(self, fetch, status):
"""Waits for a network resource to reach a status
@param fetch: the callable to be used to query the resource status
@type fetch: callable that takes no parameters and returns the resource
@param status: the status that the resource has to reach
@type status: String
"""
interval = self.build_interval
timeout = self.build_timeout
start_time = time.time()
while time.time() - start_time <= timeout:
resource = fetch()
if resource['status'] == status:
return
time.sleep(interval)
# At this point, the wait has timed out
message = 'Resource %s' % (str(resource))
message += ' failed to reach status %s' % status
message += ' (current: %s)' % resource['status']
message += ' within the required time %s' % timeout
caller = misc.find_test_caller()
if caller:
message = '(%s) %s' % (caller, message)
raise exceptions.TimeoutException(message)
class DeletableNetwork(DeletableResource):
def delete(self):
self.networks_client.delete_network(self.id)
class DeletableSubnet(DeletableResource):
def __init__(self, *args, **kwargs):
super(DeletableSubnet, self).__init__(*args, **kwargs)
self._router_ids = set()
def update(self, *args, **kwargs):
result = self.subnets_client.update_subnet(self.id,
*args,
**kwargs)
return super(DeletableSubnet, self).update(**result['subnet'])
def add_to_router(self, router_id):
self._router_ids.add(router_id)
self.routers_client.add_router_interface(router_id,
subnet_id=self.id)
def delete(self):
for router_id in self._router_ids.copy():
self.routers_client.remove_router_interface(router_id,
subnet_id=self.id)
self._router_ids.remove(router_id)
self.subnets_client.delete_subnet(self.id)
class DeletableRouter(DeletableResource):
def set_gateway(self, network_id):
return self.update(external_gateway_info=dict(network_id=network_id))
def unset_gateway(self):
return self.update(external_gateway_info=dict())
def update(self, *args, **kwargs):
result = self.routers_client.update_router(self.id,
*args,
**kwargs)
return super(DeletableRouter, self).update(**result['router'])
def delete(self):
self.unset_gateway()
self.routers_client.delete_router(self.id)
class DeletableFloatingIp(DeletableResource):
def refresh(self, *args, **kwargs):
result = self.client.show_floatingip(self.id,
*args,
**kwargs)
super(DeletableFloatingIp, self).update(**result['floatingip'])
def update(self, *args, **kwargs):
result = self.client.update_floatingip(self.id,
*args,
**kwargs)
super(DeletableFloatingIp, self).update(**result['floatingip'])
def __repr__(self):
return '<%s addr="%s">' % (self.__class__.__name__,
self.floating_ip_address)
def __str__(self):
return '<"FloatingIP" addr="%s" id="%s">' % (self.floating_ip_address,
self.id)
def delete(self):
self.client.delete_floatingip(self.id)
class DeletablePort(DeletableResource):
def delete(self):
self.ports_client.delete_port(self.id)
class DeletableSecurityGroup(DeletableResource):
def delete(self):
self.client.delete_security_group(self.id)
class DeletableSecurityGroupRule(DeletableResource):
def __repr__(self):
return '<%s id="%s">' % (self.__class__.__name__, self.id)
def delete(self):
self.client.delete_security_group_rule(self.id)
class DeletablePool(DeletableResource):
def delete(self):
self.client.delete_pool(self.id)
class DeletableMember(DeletableResource):
def delete(self):
self.client.delete_member(self.id)
class DeletableVip(DeletableResource):
def delete(self):
self.client.delete_vip(self.id)
def refresh(self):
result = self.client.show_vip(self.id)
super(DeletableVip, self).update(**result['vip'])

View File

@ -61,7 +61,7 @@ class TestNetworkAdvancedServerOps(manager.NetworkScenarioTest):
server_name = data_utils.rand_name('server-smoke') server_name = data_utils.rand_name('server-smoke')
server = self.create_server( server = self.create_server(
name=server_name, name=server_name,
networks=[{'uuid': network.id}], networks=[{'uuid': network['id']}],
key_name=keypair['name'], key_name=keypair['name'],
security_groups=security_groups, security_groups=security_groups,
wait_until='ACTIVE') wait_until='ACTIVE')
@ -81,7 +81,7 @@ class TestNetworkAdvancedServerOps(manager.NetworkScenarioTest):
server, username, private_key, server, username, private_key,
should_connect=should_connect, should_connect=should_connect,
servers_for_debug=[server]) servers_for_debug=[server])
floating_ip_addr = floating_ip.floating_ip_address floating_ip_addr = floating_ip['floating_ip_address']
# Check FloatingIP status before checking the connectivity # Check FloatingIP status before checking the connectivity
self.check_floating_ip_status(floating_ip, 'ACTIVE') self.check_floating_ip_status(floating_ip, 'ACTIVE')
self.check_public_network_connectivity(floating_ip_addr, username, self.check_public_network_connectivity(floating_ip_addr, username,

View File

@ -25,7 +25,6 @@ from tempest import config
from tempest import exceptions from tempest import exceptions
from tempest.lib.common.utils import test_utils from tempest.lib.common.utils import test_utils
from tempest.scenario import manager from tempest.scenario import manager
from tempest.scenario import network_resources
from tempest import test from tempest import test
CONF = config.CONF CONF = config.CONF
@ -114,7 +113,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
self.port_id = None self.port_id = None
if boot_with_port: if boot_with_port:
# create a port on the network and boot with that # create a port on the network and boot with that
self.port_id = self._create_port(self.network['id']).id self.port_id = self._create_port(self.network['id'])['id']
self.ports.append({'port': self.port_id}) self.ports.append({'port': self.port_id})
name = data_utils.rand_name('server-smoke') name = data_utils.rand_name('server-smoke')
@ -133,30 +132,30 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
seen_nets = self._list_networks() seen_nets = self._list_networks()
seen_names = [n['name'] for n in seen_nets] seen_names = [n['name'] for n in seen_nets]
seen_ids = [n['id'] for n in seen_nets] seen_ids = [n['id'] for n in seen_nets]
self.assertIn(self.network.name, seen_names) self.assertIn(self.network['name'], seen_names)
self.assertIn(self.network.id, seen_ids) self.assertIn(self.network['id'], seen_ids)
if self.subnet: if self.subnet:
seen_subnets = self._list_subnets() seen_subnets = self._list_subnets()
seen_net_ids = [n['network_id'] for n in seen_subnets] seen_net_ids = [n['network_id'] for n in seen_subnets]
seen_subnet_ids = [n['id'] for n in seen_subnets] seen_subnet_ids = [n['id'] for n in seen_subnets]
self.assertIn(self.network.id, seen_net_ids) self.assertIn(self.network['id'], seen_net_ids)
self.assertIn(self.subnet.id, seen_subnet_ids) self.assertIn(self.subnet['id'], seen_subnet_ids)
if self.router: if self.router:
seen_routers = self._list_routers() seen_routers = self._list_routers()
seen_router_ids = [n['id'] for n in seen_routers] seen_router_ids = [n['id'] for n in seen_routers]
seen_router_names = [n['name'] for n in seen_routers] seen_router_names = [n['name'] for n in seen_routers]
self.assertIn(self.router.name, self.assertIn(self.router['name'],
seen_router_names) seen_router_names)
self.assertIn(self.router.id, self.assertIn(self.router['id'],
seen_router_ids) seen_router_ids)
def _create_server(self, name, network, port_id=None): def _create_server(self, name, network, port_id=None):
keypair = self.create_keypair() keypair = self.create_keypair()
self.keypairs[keypair['name']] = keypair self.keypairs[keypair['name']] = keypair
security_groups = [{'name': self.security_group['name']}] security_groups = [{'name': self.security_group['name']}]
network = {'uuid': network.id} network = {'uuid': network['id']}
if port_id is not None: if port_id is not None:
network['port'] = port_id network['port'] = port_id
@ -198,7 +197,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
""" """
ssh_login = CONF.validation.image_ssh_user ssh_login = CONF.validation.image_ssh_user
floating_ip, server = self.floating_ip_tuple floating_ip, server = self.floating_ip_tuple
ip_address = floating_ip.floating_ip_address ip_address = floating_ip['floating_ip_address']
private_key = None private_key = None
floatingip_status = 'DOWN' floatingip_status = 'DOWN'
if should_connect: if should_connect:
@ -239,7 +238,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
def _hotplug_server(self): def _hotplug_server(self):
old_floating_ip, server = self.floating_ip_tuple old_floating_ip, server = self.floating_ip_tuple
ip_address = old_floating_ip.floating_ip_address ip_address = old_floating_ip['floating_ip_address']
private_key = self._get_server_key(server) private_key = self._get_server_key(server)
ssh_client = self.get_remote_client( ssh_client = self.get_remote_client(
ip_address, private_key=private_key) ip_address, private_key=private_key)
@ -250,7 +249,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
old_port = port_list[0] old_port = port_list[0]
interface = self.interface_client.create_interface( interface = self.interface_client.create_interface(
server_id=server['id'], server_id=server['id'],
net_id=self.new_net.id)['interfaceAttachment'] net_id=self.new_net['id'])['interfaceAttachment']
self.addCleanup(self.ports_client.wait_for_resource_deletion, self.addCleanup(self.ports_client.wait_for_resource_deletion,
interface['port_id']) interface['port_id'])
self.addCleanup(test_utils.call_and_ignore_notfound_exc, self.addCleanup(test_utils.call_and_ignore_notfound_exc,
@ -270,9 +269,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
"Old port: %s. Number of new ports: %d" % ( "Old port: %s. Number of new ports: %d" % (
CONF.network.build_timeout, old_port, CONF.network.build_timeout, old_port,
len(self.new_port_list))) len(self.new_port_list)))
new_port = network_resources.DeletablePort( new_port = self.new_port_list[0]
ports_client=self.ports_client,
**self.new_port_list[0])
def check_new_nic(): def check_new_nic():
new_nic_list = self._get_server_nics(ssh_client) new_nic_list = self._get_server_nics(ssh_client)
@ -287,7 +284,8 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
num, new_nic = self.diff_list[0] num, new_nic = self.diff_list[0]
ssh_client.assign_static_ip(nic=new_nic, ssh_client.assign_static_ip(nic=new_nic,
addr=new_port.fixed_ips[0]['ip_address']) addr=new_port['fixed_ips'][0][
'ip_address'])
ssh_client.set_nic_state(nic=new_nic) ssh_client.set_nic_state(nic=new_nic)
def _get_server_nics(self, ssh_client): def _get_server_nics(self, ssh_client):
@ -307,7 +305,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
# get all network ports in the new network # get all network ports in the new network
internal_ips = (p['fixed_ips'][0]['ip_address'] for p in internal_ips = (p['fixed_ips'][0]['ip_address'] for p in
self._list_ports(tenant_id=server['tenant_id'], self._list_ports(tenant_id=server['tenant_id'],
network_id=network.id) network_id=network['id'])
if p['device_owner'].startswith('network')) if p['device_owner'].startswith('network'))
self._check_server_connectivity(floating_ip, self._check_server_connectivity(floating_ip,
@ -335,7 +333,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
def _check_server_connectivity(self, floating_ip, address_list, def _check_server_connectivity(self, floating_ip, address_list,
should_connect=True): should_connect=True):
ip_address = floating_ip.floating_ip_address ip_address = floating_ip['floating_ip_address']
private_key = self._get_server_key(self.floating_ip_tuple.server) private_key = self._get_server_key(self.floating_ip_tuple.server)
ssh_source = self.get_remote_client( ssh_source = self.get_remote_client(
ip_address, private_key=private_key) ip_address, private_key=private_key)
@ -451,7 +449,13 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
self._create_server(name, self.new_net) self._create_server(name, self.new_net)
self._check_network_internal_connectivity(network=self.new_net, self._check_network_internal_connectivity(network=self.new_net,
should_connect=False) should_connect=False)
self.new_subnet.add_to_router(self.router.id) router_id = self.router['id']
self.routers_client.add_router_interface(
router_id, subnet_id=self.new_subnet['id'])
self.addCleanup(test_utils.call_and_ignore_notfound_exc,
self.routers_client.remove_router_interface,
router_id, subnet_id=self.new_subnet['id'])
self._check_network_internal_connectivity(network=self.new_net, self._check_network_internal_connectivity(network=self.new_net,
should_connect=True) should_connect=True)
@ -553,7 +557,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
self.check_public_network_connectivity(should_connect=True) self.check_public_network_connectivity(should_connect=True)
floating_ip, server = self.floating_ip_tuple floating_ip, server = self.floating_ip_tuple
ip_address = floating_ip.floating_ip_address ip_address = floating_ip['floating_ip_address']
private_key = self._get_server_key(server) private_key = self._get_server_key(server)
ssh_client = self.get_remote_client( ssh_client = self.get_remote_client(
ip_address, private_key=private_key) ip_address, private_key=private_key)
@ -568,9 +572,11 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
act_serv=servers, act_serv=servers,
trgt_serv=dns_servers)) trgt_serv=dns_servers))
self.subnet.update(dns_nameservers=[alt_dns_server]) self.subnet = self.subnets_client.update_subnet(
self.subnet['id'], dns_nameservers=[alt_dns_server])['subnet']
# asserts that Neutron DB has updated the nameservers # asserts that Neutron DB has updated the nameservers
self.assertEqual([alt_dns_server], self.subnet.dns_nameservers, self.assertEqual([alt_dns_server], self.subnet['dns_nameservers'],
"Failed to update subnet's nameservers") "Failed to update subnet's nameservers")
def check_new_dns_server(): def check_new_dns_server():
@ -695,7 +701,8 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
# NOTE(kevinbenton): we have to use the admin credentials to check # NOTE(kevinbenton): we have to use the admin credentials to check
# for the distributed flag because self.router only has a project view. # for the distributed flag because self.router only has a project view.
admin = self.admin_manager.routers_client.show_router(self.router.id) admin = self.admin_manager.routers_client.show_router(
self.router['id'])
if admin['router'].get('distributed', False): if admin['router'].get('distributed', False):
msg = "Rescheduling test does not apply to distributed routers." msg = "Rescheduling test does not apply to distributed routers."
raise self.skipException(msg) raise self.skipException(msg)
@ -704,16 +711,16 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
# remove resource from agents # remove resource from agents
hosting_agents = set(a["id"] for a in hosting_agents = set(a["id"] for a in
list_hosts(self.router.id)['agents']) list_hosts(self.router['id'])['agents'])
no_migration = agent_list_alive == hosting_agents no_migration = agent_list_alive == hosting_agents
LOG.info("Router will be assigned to {mig} hosting agent". LOG.info("Router will be assigned to {mig} hosting agent".
format(mig="the same" if no_migration else "a new")) format(mig="the same" if no_migration else "a new"))
for hosting_agent in hosting_agents: for hosting_agent in hosting_agents:
unschedule_router(hosting_agent, self.router.id) unschedule_router(hosting_agent, self.router['id'])
self.assertNotIn(hosting_agent, self.assertNotIn(hosting_agent,
[a["id"] for a in [a["id"] for a in
list_hosts(self.router.id)['agents']], list_hosts(self.router['id'])['agents']],
'unscheduling router failed') 'unscheduling router failed')
# verify resource is un-functional # verify resource is un-functional
@ -730,7 +737,7 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
router_id=self.router['id']) router_id=self.router['id'])
self.assertEqual( self.assertEqual(
target_agent, target_agent,
list_hosts(self.router.id)['agents'][0]['id'], list_hosts(self.router['id'])['agents'][0]['id'],
"Router failed to reschedule. Hosting agent doesn't match " "Router failed to reschedule. Hosting agent doesn't match "
"target agent") "target agent")
@ -776,12 +783,12 @@ class TestNetworkBasicOps(manager.NetworkScenarioTest):
network_id=self.new_net["id"]) network_id=self.new_net["id"])
spoof_port = new_ports[0] spoof_port = new_ports[0]
private_key = self._get_server_key(server) private_key = self._get_server_key(server)
ssh_client = self.get_remote_client(fip.floating_ip_address, ssh_client = self.get_remote_client(fip['floating_ip_address'],
private_key=private_key) private_key=private_key)
spoof_nic = ssh_client.get_nic_name_by_mac(spoof_port["mac_address"]) spoof_nic = ssh_client.get_nic_name_by_mac(spoof_port["mac_address"])
name = data_utils.rand_name('peer') name = data_utils.rand_name('peer')
peer = self._create_server(name, self.new_net) peer = self._create_server(name, self.new_net)
peer_address = peer['addresses'][self.new_net.name][0]['addr'] peer_address = peer['addresses'][self.new_net['name']][0]['addr']
self._check_remote_connectivity(ssh_client, dest=peer_address, self._check_remote_connectivity(ssh_client, dest=peer_address,
nic=spoof_nic, should_succeed=True) nic=spoof_nic, should_succeed=True)
ssh_client.set_mac_address(spoof_nic, spoof_mac) ssh_client.set_mac_address(spoof_nic, spoof_mac)

View File

@ -17,6 +17,7 @@ import functools
import six import six
from tempest import config from tempest import config
from tempest.lib.common.utils import test_utils
from tempest.scenario import manager from tempest.scenario import manager
from tempest import test from tempest import test
@ -82,8 +83,12 @@ class TestGettingAddress(manager.NetworkScenarioTest):
ip_version=4) ip_version=4)
router = self._get_router(tenant_id=self.tenant_id) router = self._get_router(tenant_id=self.tenant_id)
sub4.add_to_router(router_id=router['id']) self.routers_client.add_router_interface(router['id'],
self.addCleanup(sub4.delete) subnet_id=sub4['id'])
self.addCleanup(test_utils.call_and_ignore_notfound_exc,
self.routers_client.remove_router_interface,
router['id'], subnet_id=sub4['id'])
self.subnets_v6 = [] self.subnets_v6 = []
for _ in range(n_subnets6): for _ in range(n_subnets6):
@ -94,10 +99,14 @@ class TestGettingAddress(manager.NetworkScenarioTest):
ipv6_ra_mode=address6_mode, ipv6_ra_mode=address6_mode,
ipv6_address_mode=address6_mode) ipv6_address_mode=address6_mode)
sub6.add_to_router(router_id=router['id']) self.routers_client.add_router_interface(router['id'],
self.addCleanup(sub6.delete) subnet_id=sub6['id'])
self.subnets_v6.append(sub6)
self.addCleanup(test_utils.call_and_ignore_notfound_exc,
self.routers_client.remove_router_interface,
router['id'], subnet_id=sub6['id'])
self.subnets_v6.append(sub6)
return [self.network, self.network_v6] if dualnet else [self.network] return [self.network, self.network_v6] if dualnet else [self.network]
@staticmethod @staticmethod
@ -119,12 +128,12 @@ class TestGettingAddress(manager.NetworkScenarioTest):
srv = self.create_server( srv = self.create_server(
key_name=self.keypair['name'], key_name=self.keypair['name'],
security_groups=[{'name': self.sec_grp['name']}], security_groups=[{'name': self.sec_grp['name']}],
networks=[{'uuid': n.id} for n in networks], networks=[{'uuid': n['id']} for n in networks],
wait_until='ACTIVE') wait_until='ACTIVE')
fip = self.create_floating_ip(thing=srv) fip = self.create_floating_ip(thing=srv)
ips = self.define_server_ips(srv=srv) ips = self.define_server_ips(srv=srv)
ssh = self.get_remote_client( ssh = self.get_remote_client(
ip_address=fip.floating_ip_address, ip_address=fip['floating_ip_address'],
username=username) username=username)
return ssh, ips, srv["id"] return ssh, ips, srv["id"]
@ -139,7 +148,7 @@ class TestGettingAddress(manager.NetworkScenarioTest):
""" """
ports = [p["mac_address"] for p in ports = [p["mac_address"] for p in
self._list_ports(device_id=sid, self._list_ports(device_id=sid,
network_id=self.network_v6.id)] network_id=self.network_v6['id'])]
self.assertEqual(1, len(ports), self.assertEqual(1, len(ports),
message=("Multiple IPv6 ports found on network %s. " message=("Multiple IPv6 ports found on network %s. "
"ports: %s") "ports: %s")
@ -190,11 +199,11 @@ class TestGettingAddress(manager.NetworkScenarioTest):
self._check_connectivity(sshv4_1, self._check_connectivity(sshv4_1,
ips_from_api_2['6'][i]) ips_from_api_2['6'][i])
self._check_connectivity(sshv4_1, self._check_connectivity(sshv4_1,
self.subnets_v6[i].gateway_ip) self.subnets_v6[i]['gateway_ip'])
self._check_connectivity(sshv4_2, self._check_connectivity(sshv4_2,
ips_from_api_1['6'][i]) ips_from_api_1['6'][i])
self._check_connectivity(sshv4_2, self._check_connectivity(sshv4_2,
self.subnets_v6[i].gateway_ip) self.subnets_v6[i]['gateway_ip'])
def _check_connectivity(self, source, dest): def _check_connectivity(self, source, dest):
self.assertTrue( self.assertTrue(

View File

@ -227,22 +227,23 @@ class TestSecurityGroupsBasicOps(manager.NetworkScenarioTest):
seen_names = [n['name'] for n in seen_nets] seen_names = [n['name'] for n in seen_nets]
seen_ids = [n['id'] for n in seen_nets] seen_ids = [n['id'] for n in seen_nets]
self.assertIn(tenant.network.name, seen_names) self.assertIn(tenant.network['name'], seen_names)
self.assertIn(tenant.network.id, seen_ids) self.assertIn(tenant.network['id'], seen_ids)
seen_subnets = [(n['id'], n['cidr'], n['network_id']) seen_subnets = [(n['id'], n['cidr'], n['network_id'])
for n in self._list_subnets()] for n in self._list_subnets()]
mysubnet = (tenant.subnet.id, tenant.subnet.cidr, tenant.network.id) mysubnet = (tenant.subnet['id'], tenant.subnet['cidr'],
tenant.network['id'])
self.assertIn(mysubnet, seen_subnets) self.assertIn(mysubnet, seen_subnets)
seen_routers = self._list_routers() seen_routers = self._list_routers()
seen_router_ids = [n['id'] for n in seen_routers] seen_router_ids = [n['id'] for n in seen_routers]
seen_router_names = [n['name'] for n in seen_routers] seen_router_names = [n['name'] for n in seen_routers]
self.assertIn(tenant.router.name, seen_router_names) self.assertIn(tenant.router['name'], seen_router_names)
self.assertIn(tenant.router.id, seen_router_ids) self.assertIn(tenant.router['id'], seen_router_ids)
myport = (tenant.router.id, tenant.subnet.id) myport = (tenant.router['id'], tenant.subnet['id'])
router_ports = [(i['device_id'], i['fixed_ips'][0]['subnet_id']) for i router_ports = [(i['device_id'], i['fixed_ips'][0]['subnet_id']) for i
in self._list_ports() in self._list_ports()
if self._is_router_port(i)] if self._is_router_port(i)]
@ -270,7 +271,7 @@ class TestSecurityGroupsBasicOps(manager.NetworkScenarioTest):
kwargs["scheduler_hints"] = {'different_host': self.servers} kwargs["scheduler_hints"] = {'different_host': self.servers}
server = self.create_server( server = self.create_server(
name=name, name=name,
networks=[{'uuid': tenant.network.id}], networks=[{'uuid': tenant.network["id"]}],
key_name=tenant.keypair['name'], key_name=tenant.keypair['name'],
security_groups=security_groups_names, security_groups=security_groups_names,
wait_until='ACTIVE', wait_until='ACTIVE',
@ -353,10 +354,10 @@ class TestSecurityGroupsBasicOps(manager.NetworkScenarioTest):
def _get_server_ip(self, server, floating=False): def _get_server_ip(self, server, floating=False):
"""returns the ip (floating/internal) of a server""" """returns the ip (floating/internal) of a server"""
if floating: if floating:
server_ip = self.floating_ips[server['id']].floating_ip_address server_ip = self.floating_ips[server['id']]['floating_ip_address']
else: else:
server_ip = None server_ip = None
network_name = self.tenants[server['tenant_id']].network.name network_name = self.tenants[server['tenant_id']].network['name']
if network_name in server['addresses']: if network_name in server['addresses']:
server_ip = server['addresses'][network_name][0]['addr'] server_ip = server['addresses'][network_name][0]['addr']
return server_ip return server_ip
@ -364,7 +365,7 @@ class TestSecurityGroupsBasicOps(manager.NetworkScenarioTest):
def _connect_to_access_point(self, tenant): def _connect_to_access_point(self, tenant):
"""create ssh connection to tenant access point""" """create ssh connection to tenant access point"""
access_point_ssh = \ access_point_ssh = \
self.floating_ips[tenant.access_point['id']].floating_ip_address self.floating_ips[tenant.access_point['id']]['floating_ip_address']
private_key = tenant.keypair['private_key'] private_key = tenant.keypair['private_key']
access_point_ssh = self.get_remote_client( access_point_ssh = self.get_remote_client(
access_point_ssh, private_key=private_key) access_point_ssh, private_key=private_key)
@ -388,7 +389,7 @@ class TestSecurityGroupsBasicOps(manager.NetworkScenarioTest):
def _test_in_tenant_allow(self, tenant): def _test_in_tenant_allow(self, tenant):
ruleset = dict( ruleset = dict(
protocol='icmp', protocol='icmp',
remote_group_id=tenant.security_groups['default'].id, remote_group_id=tenant.security_groups['default']['id'],
direction='ingress' direction='ingress'
) )
self._create_security_group_rule( self._create_security_group_rule(
@ -464,7 +465,7 @@ class TestSecurityGroupsBasicOps(manager.NetworkScenarioTest):
for port in port_list if port['fixed_ips'] for port in port_list if port['fixed_ips']
] ]
server_ip = self._get_server_ip(tenant.access_point) server_ip = self._get_server_ip(tenant.access_point)
subnet_id = tenant.subnet.id subnet_id = tenant.subnet['id']
self.assertIn((subnet_id, server_ip, mac_addr), port_detail_list) self.assertIn((subnet_id, server_ip, mac_addr), port_detail_list)
@test.idempotent_id('e79f879e-debb-440c-a7e4-efeda05b6848') @test.idempotent_id('e79f879e-debb-440c-a7e4-efeda05b6848')
@ -545,7 +546,7 @@ class TestSecurityGroupsBasicOps(manager.NetworkScenarioTest):
# update port with new security group and check connectivity # update port with new security group and check connectivity
self.ports_client.update_port(port_id, security_groups=[ self.ports_client.update_port(port_id, security_groups=[
new_tenant.security_groups['new_sg'].id]) new_tenant.security_groups['new_sg']['id']])
self._check_connectivity( self._check_connectivity(
access_point=access_point_ssh, access_point=access_point_ssh,
ip=self._get_server_ip(server)) ip=self._get_server_ip(server))