blob: e0e40cba211fe6ee3e65dda2708dd1391fdb99e1 [file] [log] [blame]
Jay Pipesf4dad392012-06-05 16:03:58 -04001# vim: tabstop=4 shiftwidth=4 softtabstop=4
2
3# Copyright 2012 OpenStack, LLC
4# All Rights Reserved.
5#
6# Licensed under the Apache License, Version 2.0 (the "License"); you may
7# not use this file except in compliance with the License. You may obtain
8# a copy of the License at
9#
10# http://www.apache.org/licenses/LICENSE-2.0
11#
12# Unless required by applicable law or agreed to in writing, software
13# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
14# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
15# License for the specific language governing permissions and limitations
16# under the License.
17
Miguel Lavallecc939612013-02-22 17:27:20 -060018import netaddr
Jay Pipesf4dad392012-06-05 16:03:58 -040019
Matthew Treinish481466b2012-12-20 17:16:01 -050020from tempest import clients
Matthew Treinisha83a16e2012-12-07 13:44:02 -050021from tempest.common.utils.data_utils import rand_name
Miguel Lavallecc939612013-02-22 17:27:20 -060022from tempest import exceptions
Attila Fazekasdc216422013-01-29 15:12:14 +010023import tempest.test
Jay Pipesf4dad392012-06-05 16:03:58 -040024
25
Attila Fazekasdc216422013-01-29 15:12:14 +010026class BaseNetworkTest(tempest.test.BaseTestCase):
Jay Pipesf4dad392012-06-05 16:03:58 -040027
Miguel Lavallecc939612013-02-22 17:27:20 -060028 """
29 Base class for the Quantum tests that use the Tempest Quantum REST client
30
31 Per the Quantum API Guide, API v1.x was removed from the source code tree
32 (docs.openstack.org/api/openstack-network/2.0/content/Overview-d1e71.html)
33 Therefore, v2.x of the Quantum API is assumed. It is also assumed that the
34 following options are defined in the [network] section of etc/tempest.conf:
35
36 tenant_network_cidr with a block of cidr's from which smaller blocks
37 can be allocated for tenant networks
38
39 tenant_network_mask_bits with the mask bits to be used to partition the
40 block defined by tenant-network_cidr
41 """
42
Jay Pipesf4dad392012-06-05 16:03:58 -040043 @classmethod
44 def setUpClass(cls):
Matthew Treinish481466b2012-12-20 17:16:01 -050045 os = clients.Manager()
Miguel Lavallecc939612013-02-22 17:27:20 -060046 cls.network_cfg = os.config.network
47 if not cls.network_cfg.quantum_available:
Dan Smithd6c1f882013-02-26 15:50:11 -050048 raise cls.skipException("Quantum support is required")
Miguel Lavallecc939612013-02-22 17:27:20 -060049 cls.client = os.network_client
50 cls.networks = []
51 cls.subnets = []
Jay Pipesf4dad392012-06-05 16:03:58 -040052
53 @classmethod
54 def tearDownClass(cls):
Miguel Lavallecc939612013-02-22 17:27:20 -060055 for subnet in cls.subnets:
56 cls.client.delete_subnet(subnet['id'])
Jay Pipesf4dad392012-06-05 16:03:58 -040057 for network in cls.networks:
58 cls.client.delete_network(network['id'])
59
Miguel Lavallecc939612013-02-22 17:27:20 -060060 @classmethod
61 def create_network(cls, network_name=None):
Sean Daguef237ccb2013-01-04 15:19:14 -050062 """Wrapper utility that returns a test network."""
Miguel Lavallecc939612013-02-22 17:27:20 -060063 network_name = network_name or rand_name('test-network-')
Jay Pipesf4dad392012-06-05 16:03:58 -040064
Miguel Lavallecc939612013-02-22 17:27:20 -060065 resp, body = cls.client.create_network(network_name)
Jay Pipesf4dad392012-06-05 16:03:58 -040066 network = body['network']
Miguel Lavallecc939612013-02-22 17:27:20 -060067 cls.networks.append(network)
Jay Pipesf4dad392012-06-05 16:03:58 -040068 return network
Miguel Lavallecc939612013-02-22 17:27:20 -060069
70 @classmethod
71 def create_subnet(cls, network):
72 """Wrapper utility that returns a test subnet."""
73 cidr = netaddr.IPNetwork(cls.network_cfg.tenant_network_cidr)
74 mask_bits = cls.network_cfg.tenant_network_mask_bits
75 # Find a cidr that is not in use yet and create a subnet with it
76 for subnet_cidr in cidr.subnet(mask_bits):
77 try:
78 resp, body = cls.client.create_subnet(network['id'],
79 str(subnet_cidr))
80 break
81 except exceptions.BadRequest as e:
82 is_overlapping_cidr = 'overlaps with another subnet' in str(e)
83 if not is_overlapping_cidr:
84 raise
85 subnet = body['subnet']
86 cls.subnets.append(subnet)
87 return subnet