2544c180c8
Change-Id: I4615ab43c1a8e9b347f4f9c066eb9f0d63a4989a
251 lines
10 KiB
Python
251 lines
10 KiB
Python
# Copyright (c) 2019 Red Hat, 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 __future__ import absolute_import
|
|
|
|
import netaddr
|
|
import testtools
|
|
|
|
import tobiko
|
|
from tobiko import config
|
|
from tobiko.openstack import keystone
|
|
from tobiko.openstack import neutron
|
|
from tobiko.openstack import nova
|
|
from tobiko.openstack import stacks
|
|
from tobiko.openstack import tests
|
|
|
|
|
|
CONF = config.CONF
|
|
|
|
|
|
@keystone.skip_unless_has_keystone_credentials()
|
|
class NeutronApiTest(testtools.TestCase):
|
|
"""Tests network creation"""
|
|
|
|
#: Stack of resources with a network with a gateway router
|
|
stack = tobiko.required_setup_fixture(stacks.NetworkStackFixture)
|
|
|
|
def test_find_network_with_id(self):
|
|
network = neutron.find_network(id=self.stack.network_id)
|
|
self.assertEqual(self.stack.network_id, network['id'])
|
|
|
|
def test_find_floating_network(self):
|
|
floating_network = CONF.tobiko.neutron.floating_network
|
|
if not floating_network:
|
|
tobiko.skip_test('floating_network not configured')
|
|
network = neutron.find_network(name=floating_network)
|
|
self.assertIn(floating_network, [network['name'], network['id']])
|
|
self.assertEqual(self.stack.gateway_network_id, network['id'])
|
|
|
|
def test_list_networks(self):
|
|
networks = neutron.list_networks()
|
|
network_ids = {n['id'] for n in networks}
|
|
self.assertIn(self.stack.network_id, network_ids)
|
|
|
|
def test_list_subnets(self):
|
|
subnets = neutron.list_subnets()
|
|
subnets_ids = {s['id'] for s in subnets}
|
|
if self.stack.has_ipv4:
|
|
self.assertIn(self.stack.ipv4_subnet_id, subnets_ids)
|
|
if self.stack.has_ipv6:
|
|
self.assertIn(self.stack.ipv6_subnet_id, subnets_ids)
|
|
|
|
def test_list_subnet_cidrs(self):
|
|
subnets_cidrs = neutron.list_subnet_cidrs()
|
|
if self.stack.has_ipv4:
|
|
cidr = netaddr.IPNetwork(self.stack.ipv4_subnet_details['cidr'])
|
|
self.assertIn(cidr, subnets_cidrs)
|
|
if self.stack.has_ipv6:
|
|
cidr = netaddr.IPNetwork(self.stack.ipv6_subnet_details['cidr'])
|
|
self.assertIn(cidr, subnets_cidrs)
|
|
|
|
def test_get_network(self):
|
|
network = neutron.get_network(self.stack.network_id)
|
|
self.assertEqual(self.stack.network_id, network['id'])
|
|
self.assertEqual(self.stack.port_security_enabled,
|
|
network['port_security_enabled'])
|
|
if self.stack.has_ipv4:
|
|
self.assertIn(self.stack.ipv4_subnet_id, network['subnets'])
|
|
else:
|
|
self.assertNotIn(self.stack.ipv4_subnet_id, network['subnets'])
|
|
if self.stack.has_ipv6:
|
|
self.assertIn(self.stack.ipv6_subnet_id, network['subnets'])
|
|
else:
|
|
self.assertNotIn(self.stack.ipv6_subnet_id, network['subnets'])
|
|
|
|
def test_create_network(self):
|
|
network = neutron.create_network(name=self.id())
|
|
self.addCleanup(neutron.delete_network, network['id'])
|
|
self.assertIsInstance(network['id'], str)
|
|
self.assertNotEqual('', network['id'])
|
|
self.assertEqual(self.id(), network['name'])
|
|
observed = neutron.get_network(network['id'])
|
|
self.assertEqual(network['id'], observed['id'])
|
|
|
|
def test_delete_network(self):
|
|
network = neutron.create_network(name=self.id())
|
|
neutron.delete_network(network['id'])
|
|
self.assertRaises(neutron.NoSuchNetwork, neutron.get_network,
|
|
network['id'])
|
|
|
|
def test_get_router(self):
|
|
if not self.stack.has_gateway:
|
|
tobiko.skip_test(f"Stack {self.stack.stack_name} has no gateway "
|
|
"router")
|
|
router = neutron.get_router(self.stack.gateway_id)
|
|
self.assertEqual(self.stack.gateway_id, router['id'])
|
|
|
|
def test_get_ipv4_subnet(self):
|
|
if not self.stack.has_ipv4:
|
|
tobiko.skip_test(
|
|
"Stack {self.stack.stack_name} has no IPv4 subnet")
|
|
subnet = neutron.get_subnet(self.stack.ipv4_subnet_id)
|
|
self.assertEqual(self.stack.ipv4_subnet_id, subnet['id'])
|
|
self.assertEqual(self.stack.ipv4_subnet_details, subnet)
|
|
|
|
def test_get_ipv6_subnet(self):
|
|
if not self.stack.has_ipv6:
|
|
tobiko.skip_test(
|
|
"Stack {self.stack.stack_name} has no IPv6 subnet")
|
|
subnet = neutron.get_subnet(self.stack.ipv6_subnet_id)
|
|
self.assertEqual(self.stack.ipv6_subnet_id, subnet['id'])
|
|
self.assertEqual(self.stack.ipv6_subnet_details, subnet)
|
|
|
|
def test_find_agents_with_binary(self):
|
|
agent = neutron.list_agents().first
|
|
agents = neutron.list_agents(binary=agent['binary'])
|
|
self.assertIn(agent['id'], {a['id'] for a in agents})
|
|
|
|
|
|
@keystone.skip_unless_has_keystone_credentials()
|
|
class PortTest(testtools.TestCase):
|
|
|
|
#: Stack of resources with a network with a gateway router
|
|
stack = tobiko.required_setup_fixture(stacks.CirrosServerStackFixture)
|
|
|
|
def test_list_port_addresses(self, ip_version=None):
|
|
port = neutron.find_port(device_id=self.stack.server_id)
|
|
port_addresses = neutron.list_port_ip_addresses(
|
|
port=port,
|
|
ip_version=ip_version)
|
|
server_addresses = nova.list_server_ip_addresses(
|
|
server=self.stack.server_details,
|
|
ip_version=ip_version,
|
|
address_type='fixed')
|
|
self.assertEqual(set(server_addresses), set(port_addresses))
|
|
if ip_version:
|
|
self.assertEqual(
|
|
port_addresses.with_attributes(version=ip_version),
|
|
port_addresses)
|
|
|
|
def test_list_port_addresses_with_ipv4(self):
|
|
self.test_list_port_addresses(ip_version=4)
|
|
|
|
def test_list_port_addresses_with_ipv6(self):
|
|
self.test_list_port_addresses(ip_version=6)
|
|
|
|
def test_find_port_address_with_ip_version(self):
|
|
port = neutron.find_port(device_id=self.stack.server_id)
|
|
server_addresses = nova.list_server_ip_addresses(
|
|
server=self.stack.server_details,
|
|
address_type='fixed')
|
|
for server_address in server_addresses:
|
|
port_address = neutron.find_port_ip_address(
|
|
port=port,
|
|
ip_version=server_address.version,
|
|
unique=True)
|
|
self.assertEqual(server_address, port_address)
|
|
|
|
def test_find_port_address_with_subnet_id(self):
|
|
port = neutron.find_port(device_id=self.stack.server_id)
|
|
for subnet in neutron.list_subnets(network_id=port['network_id']):
|
|
port_address = neutron.find_port_ip_address(
|
|
port=port, subnet_id=subnet['id'], unique=True)
|
|
cidr = netaddr.IPNetwork(subnet['cidr'])
|
|
self.assertIn(port_address, cidr)
|
|
|
|
|
|
@keystone.skip_unless_has_keystone_credentials()
|
|
class FloatingIpTest(testtools.TestCase):
|
|
|
|
server = tobiko.required_fixture(stacks.CirrosServerStackFixture)
|
|
|
|
def test_list_floating_ip(self):
|
|
port_id = self.server.port_id
|
|
floating_ips = neutron.list_floating_ips()
|
|
floating_ip = floating_ips.with_items(port_id=port_id).unique
|
|
self.assertEqual(floating_ip['floating_ip_address'],
|
|
self.server.floating_ip_address)
|
|
|
|
def test_list_floating_ip_with_port_id(self):
|
|
port_id = self.server.port_id
|
|
floating_ip = neutron.list_floating_ips(port_id=port_id).unique
|
|
self.assertEqual(floating_ip['floating_ip_address'],
|
|
self.server.floating_ip_address)
|
|
|
|
def test_list_floating_ip_with_floating_ip_address(self):
|
|
floating_ip_address = self.server.floating_ip_address
|
|
floating_ip = neutron.list_floating_ips(
|
|
floating_ip_address=floating_ip_address).unique
|
|
self.assertEqual(floating_ip['port_id'],
|
|
self.server.port_id)
|
|
|
|
def test_find_floating_ip_with_port_id(self):
|
|
port_id = self.server.port_id
|
|
floating_ip = neutron.find_floating_ip(port_id=port_id, unique=True)
|
|
self.assertEqual(floating_ip['floating_ip_address'],
|
|
self.server.floating_ip_address)
|
|
|
|
|
|
@keystone.skip_unless_has_keystone_credentials()
|
|
class AgentTest(testtools.TestCase):
|
|
|
|
def test_skip_if_missing_agents(self, count=1, should_skip=False,
|
|
**params):
|
|
if should_skip:
|
|
expected_exeption = self.skipException
|
|
else:
|
|
expected_exeption = self.failureException
|
|
|
|
@neutron.skip_if_missing_networking_agents(count=count, **params)
|
|
def method():
|
|
raise self.fail('Not skipped')
|
|
|
|
exception = self.assertRaises(expected_exeption, method)
|
|
if should_skip:
|
|
agents = neutron.list_agents(**params)
|
|
message = "missing {!r} agent(s)".format(count - len(agents))
|
|
if params:
|
|
message += " with {!s}".format(
|
|
','.join('{!s}={!r}'.format(k, v)
|
|
for k, v in params.items()))
|
|
self.assertEqual(message, str(exception))
|
|
else:
|
|
self.assertEqual('Not skipped', str(exception))
|
|
|
|
def test_skip_if_missing_agents_with_no_agents(self):
|
|
self.test_skip_if_missing_agents(binary='never-never-land',
|
|
should_skip=True)
|
|
|
|
def test_skip_if_missing_agents_with_big_count(self):
|
|
self.test_skip_if_missing_agents(count=1000000,
|
|
should_skip=True)
|
|
|
|
def test_neutron_agents_are_alive(self):
|
|
agents = tests.test_neutron_agents_are_alive()
|
|
# check has agents and they are all alive
|
|
self.assertNotEqual([], agents)
|
|
self.assertNotEqual([], agents.with_items(alive=True))
|