blob: d1434dd77abee5224c2623d9db8e8dfaac57c1ba [file] [log] [blame]
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +02001import os
2import pytest
3import utils
4import random
5import time
6import logging
7
8from utils import os_client
9
10
11logger = logging.getLogger(__name__)
12
13
14@pytest.fixture(scope='session')
15def openstack_clients():
16 return os_client.OfficialClientManager(
17 username=os.environ['OS_USERNAME'],
18 password=os.environ['OS_PASSWORD'],
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030019 project_name=os.environ['OS_PROJECT_NAME'],
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020020 auth_url=os.environ['OS_AUTH_URL'],
21 cert=False,
22 domain=os.environ['OS_PROJECT_DOMAIN_NAME'],
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030023 )
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020024
25
26nodes = utils.get_pairs()
27
28
29@pytest.fixture(scope='session', params=list(nodes.values()),
30 ids=list(nodes.keys()))
31def pair(request):
32 return request.param
33
34
35@pytest.fixture(scope='session')
36def os_resources(openstack_clients):
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030037 logger.info("Setting up resources in admin project...")
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020038 os_actions = os_client.OSCliActions(openstack_clients)
39 os_resource = {}
40 config = utils.get_configuration()
Ievgeniia Zadorozhna5ed74e22022-07-26 16:56:23 +030041 image_name = config.get('image_name', 'cvp.ubuntu.2004')
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020042 flavor_name = config.get('flavor_name', 'spt-test')
43 flavor_ram = config.get('flavor_ram', 1536)
44 flavor_vcpus = config.get('flavor_vcpus', 1)
45 flavor_disk = config.get('flavor_disk', 3)
46
47 os_images_list = [image.id for image in
48 openstack_clients.image.images.list(
49 filters={'name': image_name})]
50
51 if os_images_list.__len__() == 0:
52 pytest.skip("No images with name {}. This name can be redefined "
53 "with 'image_name' env var ".format(image_name))
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020054 os_resource['image_id'] = str(os_images_list[0])
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030055 flavor_id = os_actions.get_flavor_id_by_name(flavor_name)
56 if flavor_id is None:
57 flavor_is_created = True
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020058 os_resource['flavor_id'] = os_actions.create_flavor(
59 flavor_name, flavor_ram, flavor_vcpus, flavor_disk).id
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020060 else:
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030061 flavor_is_created = False
62 logger.info("Flavor {} already exists".format(flavor_name))
63 os_resource['flavor_id'] = flavor_id
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020064
65 os_resource['sec_group'] = os_actions.create_sec_group()
66 os_resource['keypair'] = openstack_clients.compute.keypairs.create(
67 '{}-{}'.format('spt-key', random.randrange(100, 999))
68 )
69 os_resource['net1'] = os_actions.create_network_resources()
70 os_resource['ext_net'] = os_actions.get_external_network()
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030071 adm_project = os_actions.get_project_by_name("admin")
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020072 os_resource['router'] = os_actions.create_router(
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030073 os_resource['ext_net'], adm_project.id)
74 os_resource['net2'] = os_actions.create_network(adm_project.id)
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020075 os_resource['subnet2'] = os_actions.create_subnet(
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030076 os_resource['net2'], adm_project.id, '10.2.7.0/24')
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020077 for subnet in openstack_clients.network.list_subnets()['subnets']:
78 if subnet['network_id'] == os_resource['net1']['id']:
79 os_resource['subnet1'] = subnet['id']
80
81 openstack_clients.network.add_interface_router(
Ievgeniia Zadorozhnac67b86b2023-02-02 18:09:12 +030082 os_resource['router']['id'], {'subnet_id': os_resource['subnet1']})
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020083 openstack_clients.network.add_interface_router(
84 os_resource['router']['id'],
85 {'subnet_id': os_resource['subnet2']['id']})
86 yield os_resource
87
88 # cleanup created resources
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +030089 logger.info("Deleting routers, networks, SG, key pair, flavor in {}..."
90 "".format(adm_project.name))
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +020091 openstack_clients.network.remove_interface_router(
92 os_resource['router']['id'], {'subnet_id': os_resource['subnet1']})
93 openstack_clients.network.remove_interface_router(
94 os_resource['router']['id'],
95 {'subnet_id': os_resource['subnet2']['id']})
96 openstack_clients.network.remove_gateway_router(
97 os_resource['router']['id'])
98 time.sleep(5)
99 openstack_clients.network.delete_router(os_resource['router']['id'])
Ievgeniia Zadorozhnac67b86b2023-02-02 18:09:12 +0300100 time.sleep(10) # extended to 10 since fails at TF sometimes
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +0200101 openstack_clients.network.delete_network(os_resource['net1']['id'])
102 openstack_clients.network.delete_network(os_resource['net2']['id'])
103
Ievgeniia Zadorozhna2c6469d2022-08-10 17:21:10 +0300104 openstack_clients.network.delete_security_group(
105 os_resource['sec_group']['id'])
Ievgeniia Zadorozhna84023022021-12-30 13:00:41 +0200106 openstack_clients.compute.keypairs.delete(os_resource['keypair'].name)
107 if flavor_is_created:
108 openstack_clients.compute.flavors.delete(os_resource['flavor_id'])
109 if os_actions.create_fake_ext_net:
110 openstack_clients.network.delete_network(os_resource['ext_net']['id'])
Ievgeniia Zadorozhnaf22827b2022-07-20 13:30:32 +0300111
112
113@pytest.fixture(scope='session')
114def openstack_alt_clients(openstack_clients):
115 # create alt project with regular admin user
116 tmp_os_actions = os_client.OSCliActions(openstack_clients)
117 alt_project = tmp_os_actions.create_project()
118 tmp_os_actions.add_roles_to_user_in_project(alt_project.id)
119
120 # create a client using alt project with admin user in it
121 return os_client.OfficialClientManager(
122 username=os.environ['OS_USERNAME'],
123 password=os.environ['OS_PASSWORD'],
124 project_name=alt_project.name,
125 auth_url=os.environ['OS_AUTH_URL'],
126 cert=False,
127 domain=os.environ['OS_PROJECT_DOMAIN_NAME'],
128 )
129
130
131@pytest.fixture(scope='session')
132def os_resources_alt_project(openstack_alt_clients):
133 logger.info("Setting up resources in the project {}..."
134 "".format(openstack_alt_clients.project_name))
135 alt_os_actions = os_client.OSCliActions(openstack_alt_clients)
136 os_resource_alt_project = {}
137 config = utils.get_configuration()
138 image_name = config.get('image_name', 'Ubuntu-18.04')
139 flavor_name = config.get('flavor_name', 'spt-test')
140 flavor_ram = config.get('flavor_ram', 1536)
141 flavor_vcpus = config.get('flavor_vcpus', 1)
142 flavor_disk = config.get('flavor_disk', 3)
143 os_images_list = [image.id for image in
144 openstack_alt_clients.image.images.list(
145 filters={'name': image_name})]
146
147 if os_images_list.__len__() == 0:
148 pytest.skip("No images with name {}. This name can be redefined "
149 "with 'image_name' env var ".format(image_name))
150 os_resource_alt_project['image_id'] = str(os_images_list[0])
151
152 flavor_id = alt_os_actions.get_flavor_id_by_name(flavor_name)
153 if flavor_id is None:
154 flavor_is_created = True
155 os_resource_alt_project['flavor_id'] = alt_os_actions.create_flavor(
156 flavor_name, flavor_ram, flavor_vcpus, flavor_disk).id
157 else:
158 flavor_is_created = False
159 logger.info("Flavor {} already exists".format(flavor_name))
160 os_resource_alt_project['flavor_id'] = flavor_id
161
162 os_resource_alt_project['sec_group'] = alt_os_actions.create_sec_group()
163
164 alt_project = alt_os_actions.get_project_by_name(
165 openstack_alt_clients.project_name)
166 os_resource_alt_project['net1'] = alt_os_actions.create_network_resources(
167 project=alt_project.name, cidr='10.3.7.0/24')
168 os_resource_alt_project['ext_net'] = alt_os_actions.get_external_network()
169
170 os_resource_alt_project['router'] = alt_os_actions.create_router(
171 os_resource_alt_project['ext_net'], alt_project.id)
172
173 os_resource_alt_project['subnet1'] = \
174 openstack_alt_clients.network.show_network(
175 os_resource_alt_project['net1']['id'])['network']['subnets'][0]
176 openstack_alt_clients.network.add_interface_router(
177 os_resource_alt_project['router']['id'],
178 {'subnet_id': os_resource_alt_project['subnet1']})
179 yield os_resource_alt_project
180
181 # cleanup created resources
182 logger.info("Deleting routers, networks, SG, flavor in {} "
183 "project...".format(alt_project.name))
184
185 openstack_alt_clients.network.remove_interface_router(
186 os_resource_alt_project['router']['id'],
187 {'subnet_id': os_resource_alt_project['subnet1']})
188 openstack_alt_clients.network.remove_gateway_router(
189 os_resource_alt_project['router']['id'])
190 time.sleep(5)
191 openstack_alt_clients.network.delete_router(
192 os_resource_alt_project['router']['id'])
193 time.sleep(5)
194 openstack_alt_clients.network.delete_network(
195 os_resource_alt_project['net1']['id'])
196
197 openstack_alt_clients.network.delete_security_group(
198 os_resource_alt_project['sec_group']['id'])
199 if flavor_is_created:
200 openstack_alt_clients.compute.flavors.delete(
201 os_resource_alt_project['flavor_id'])
202 if alt_os_actions.create_fake_ext_net:
203 openstack_alt_clients.network.delete_network(
204 os_resource_alt_project['ext_net']['id'])
205
206 if alt_os_actions.is_project_empty(alt_project.id):
207 openstack_alt_clients.auth.projects.delete(alt_project.id)
208 logger.info("Deleted project {}".format(alt_project.name))
209 else:
210 logger.info("Project {} is not empty, skip deleting".format(
211 alt_project.name))