3 # jose.lausuch@ericsson.com
4 # valentin.boucher@orange.com
5 # All rights reserved. This program and the accompanying materials
6 # are made available under the terms of the Apache License, Version 2.0
7 # which accompanies this distribution, and is available at
8 # http://www.apache.org/licenses/LICENSE-2.0
17 from cinderclient import client as cinderclient
18 import functest.utils.functest_logger as ft_logger
19 import functest.utils.functest_utils as ft_utils
20 from glanceclient import client as glanceclient
21 from keystoneclient.v2_0 import client as keystoneclient
22 from neutronclient.v2_0 import client as neutronclient
23 from novaclient import client as novaclient
25 logger = ft_logger.Logger("openstack_utils").getLogger()
28 # *********************************************
30 # *********************************************
31 def check_credentials():
33 Check if the OpenStack credentials (openrc) are sourced
35 env_vars = ['OS_AUTH_URL', 'OS_USERNAME', 'OS_PASSWORD', 'OS_TENANT_NAME']
36 return all(map(lambda v: v in os.environ and os.environ[v], env_vars))
39 def get_credentials(service):
40 """Returns a creds dictionary filled with the following keys:
42 * password/api_key (depending on the service)
43 * tenant_name/project_id (depending on the service)
45 :param service: a string indicating the name of the service
46 requesting the credentials.
50 # Check that the env vars exists:
51 envvars = ('OS_USERNAME', 'OS_PASSWORD', 'OS_AUTH_URL', 'OS_TENANT_NAME')
52 for envvar in envvars:
53 if os.getenv(envvar) is None:
54 logger.error("'%s' is not exported as an env variable." % envvar)
57 # Unfortunately, each of the OpenStack client will request slightly
58 # different entries in their credentials dict.
59 if service.lower() in ("nova", "cinder"):
64 tenant = "tenant_name"
66 # The most common way to pass these info to the script is to do it through
67 # environment variables.
69 "username": os.environ.get("OS_USERNAME"),
70 password: os.environ.get("OS_PASSWORD"),
71 "auth_url": os.environ.get("OS_AUTH_URL"),
72 tenant: os.environ.get("OS_TENANT_NAME")
74 if os.getenv('OS_ENDPOINT_TYPE') is not None:
76 "endpoint_type": os.environ.get("OS_ENDPOINT_TYPE")
78 if os.getenv('OS_REGION_NAME') is not None:
80 "region_name": os.environ.get("OS_REGION_NAME")
82 cacert = os.environ.get("OS_CACERT")
83 if cacert is not None:
84 # each openstack client uses differnt kwargs for this
85 creds.update({"cacert": cacert,
87 "https_ca_cert": cacert,
88 "https_cacert": cacert,
90 creds.update({"insecure": "True", "https_insecure": "True"})
91 if not os.path.isfile(cacert):
92 logger.info("WARNING: The 'OS_CACERT' environment variable is "
93 "set to %s but the file does not exist." % cacert)
97 def source_credentials(rc_file):
98 pipe = subprocess.Popen(". %s; env" % rc_file, stdout=subprocess.PIPE,
100 output = pipe.communicate()[0]
101 env = dict((line.split("=", 1) for line in output.splitlines()))
102 os.environ.update(env)
106 def get_credentials_for_rally():
107 creds = get_credentials("keystone")
108 admin_keys = ['username', 'tenant_name', 'password']
109 endpoint_types = [('internalURL', 'internal'),
110 ('publicURL', 'public'), ('adminURL', 'admin')]
111 if 'endpoint_type' in creds.keys():
112 for k, v in endpoint_types:
113 if creds['endpoint_type'] == k:
114 creds['endpoint_type'] = v
115 rally_conf = {"type": "ExistingCloud", "admin": {}}
117 if key in admin_keys:
118 rally_conf['admin'][key] = creds[key]
120 rally_conf[key] = creds[key]
124 # *********************************************
126 # *********************************************
127 def get_keystone_client():
128 creds_keystone = get_credentials("keystone")
129 return keystoneclient.Client(**creds_keystone)
132 def get_nova_client():
133 creds_nova = get_credentials("nova")
134 return novaclient.Client('2', **creds_nova)
137 def get_cinder_client():
138 creds_cinder = get_credentials("cinder")
139 creds_cinder.update({
140 "service_type": "volume"
142 return cinderclient.Client('2', **creds_cinder)
145 def get_neutron_client():
146 creds_neutron = get_credentials("neutron")
147 return neutronclient.Client(**creds_neutron)
150 def get_glance_client():
151 keystone_client = get_keystone_client()
152 glance_endpoint_type = 'publicURL'
153 os_endpoint_type = os.getenv('OS_ENDPOINT_TYPE')
154 if os_endpoint_type is not None:
155 glance_endpoint_type = os_endpoint_type
156 glance_endpoint = keystone_client.service_catalog.url_for(
157 service_type='image', endpoint_type=glance_endpoint_type)
158 return glanceclient.Client(1, glance_endpoint,
159 token=keystone_client.auth_token)
161 # *********************************************
163 # *********************************************
166 def get_instances(nova_client):
168 instances = nova_client.servers.list(search_opts={'all_tenants': 1})
171 logger.error("Error [get_instances(nova_client)]: %s" % e)
175 def get_instance_status(nova_client, instance):
177 instance = nova_client.servers.get(instance.id)
178 return instance.status
180 logger.error("Error [get_instance_status(nova_client)]: %s" % e)
184 def get_instance_by_name(nova_client, instance_name):
186 instance = nova_client.servers.find(name=instance_name)
189 logger.error("Error [get_instance_by_name(nova_client, '%s')]: %s"
190 % (instance_name, e))
194 def get_flavor_id(nova_client, flavor_name):
195 flavors = nova_client.flavors.list(detailed=True)
198 if f.name == flavor_name:
204 def get_flavor_id_by_ram_range(nova_client, min_ram, max_ram):
205 flavors = nova_client.flavors.list(detailed=True)
208 if min_ram <= f.ram and f.ram <= max_ram:
214 def get_floating_ips(nova_client):
216 floating_ips = nova_client.floating_ips.list()
219 logger.error("Error [get_floating_ips(nova_client)]: %s" % e)
223 def get_hypervisors(nova_client):
226 hypervisors = nova_client.hypervisors.list()
227 for hypervisor in hypervisors:
228 if hypervisor.state == "up":
229 nodes.append(hypervisor.hypervisor_hostname)
232 logger.error("Error [get_hypervisors(nova_client)]: %s" % e)
236 def create_flavor(nova_client, flavor_name, ram, disk, vcpus):
238 flavor = nova_client.flavors.create(flavor_name, ram, vcpus, disk)
240 extra_specs = ft_utils.get_functest_config(
241 'general.flavor_extra_specs')
242 flavor.update(extra_specs)
244 # flavor extra specs are not configured, therefore skip the update
248 logger.error("Error [create_flavor(nova_client, '%s', '%s', '%s', "
249 "'%s')]: %s" % (flavor_name, ram, disk, vcpus, e))
254 def create_instance(flavor_name,
257 instance_name="functest-vm",
263 nova_client = get_nova_client()
265 flavor = nova_client.flavors.find(name=flavor_name)
267 flavors = nova_client.flavors.list()
268 logger.error("Error: Flavor '%s' not found. Available flavors are: "
269 "\n%s" % (flavor_name, flavors))
271 if fixed_ip is not None:
272 nics = {"net-id": network_id, "v4-fixed-ip": fixed_ip}
274 nics = {"net-id": network_id}
276 instance = nova_client.servers.create(
281 availability_zone=av_zone,
285 instance = nova_client.servers.create(
290 config_drive=confdrive,
292 availability_zone=av_zone,
298 def create_instance_and_wait_for_active(flavor_name,
308 VM_BOOT_TIMEOUT = 180
309 nova_client = get_nova_client()
310 instance = create_instance(flavor_name,
319 count = VM_BOOT_TIMEOUT / SLEEP
320 for n in range(count, -1, -1):
321 status = get_instance_status(nova_client, instance)
322 if status.lower() == "active":
324 elif status.lower() == "error":
325 logger.error("The instance %s went to ERROR status."
329 logger.error("Timeout booting the instance %s." % instance_name)
333 def create_floating_ip(neutron_client):
334 extnet_id = get_external_net_id(neutron_client)
335 props = {'floating_network_id': extnet_id}
337 ip_json = neutron_client.create_floatingip({'floatingip': props})
338 fip_addr = ip_json['floatingip']['floating_ip_address']
339 fip_id = ip_json['floatingip']['id']
341 logger.error("Error [create_floating_ip(neutron_client)]: %s" % e)
343 return {'fip_addr': fip_addr, 'fip_id': fip_id}
346 def add_floating_ip(nova_client, server_id, floatingip_id):
348 nova_client.servers.add_floating_ip(server_id, floatingip_id)
351 logger.error("Error [add_floating_ip(nova_client, '%s', '%s')]: %s"
352 % (server_id, floatingip_id, e))
356 def delete_instance(nova_client, instance_id):
358 nova_client.servers.force_delete(instance_id)
361 logger.error("Error [delete_instance(nova_client, '%s')]: %s"
366 def delete_floating_ip(nova_client, floatingip_id):
368 nova_client.floating_ips.delete(floatingip_id)
371 logger.error("Error [delete_floating_ip(nova_client, '%s')]:"
372 % (floatingip_id, e))
376 # *********************************************
378 # *********************************************
379 def get_network_list(neutron_client):
380 network_list = neutron_client.list_networks()['networks']
381 if len(network_list) == 0:
387 def get_router_list(neutron_client):
388 router_list = neutron_client.list_routers()['routers']
389 if len(router_list) == 0:
395 def get_port_list(neutron_client):
396 port_list = neutron_client.list_ports()['ports']
397 if len(port_list) == 0:
403 def get_network_id(neutron_client, network_name):
404 networks = neutron_client.list_networks()['networks']
407 if n['name'] == network_name:
413 def get_subnet_id(neutron_client, subnet_name):
414 subnets = neutron_client.list_subnets()['subnets']
417 if s['name'] == subnet_name:
423 def get_router_id(neutron_client, router_name):
424 routers = neutron_client.list_routers()['routers']
427 if r['name'] == router_name:
433 def get_private_net(neutron_client):
434 # Checks if there is an existing shared private network
435 networks = neutron_client.list_networks()['networks']
436 if len(networks) == 0:
439 if (net['router:external'] is False) and (net['shared'] is True):
444 def get_external_net(neutron_client):
445 for network in neutron_client.list_networks()['networks']:
446 if network['router:external']:
447 return network['name']
451 def get_external_net_id(neutron_client):
452 for network in neutron_client.list_networks()['networks']:
453 if network['router:external']:
458 def check_neutron_net(neutron_client, net_name):
459 for network in neutron_client.list_networks()['networks']:
460 if network['name'] == net_name:
461 for subnet in network['subnets']:
466 def create_neutron_net(neutron_client, name):
467 json_body = {'network': {'name': name,
468 'admin_state_up': True}}
470 network = neutron_client.create_network(body=json_body)
471 network_dict = network['network']
472 return network_dict['id']
474 logger.error("Error [create_neutron_net(neutron_client, '%s')]: %s"
479 def create_neutron_subnet(neutron_client, name, cidr, net_id):
480 json_body = {'subnets': [{'name': name, 'cidr': cidr,
481 'ip_version': 4, 'network_id': net_id}]}
483 subnet = neutron_client.create_subnet(body=json_body)
484 return subnet['subnets'][0]['id']
486 logger.error("Error [create_neutron_subnet(neutron_client, '%s', "
487 "'%s', '%s')]: %s" % (name, cidr, net_id, e))
491 def create_neutron_router(neutron_client, name):
492 json_body = {'router': {'name': name, 'admin_state_up': True}}
494 router = neutron_client.create_router(json_body)
495 return router['router']['id']
497 logger.error("Error [create_neutron_router(neutron_client, '%s')]: %s"
502 def create_neutron_port(neutron_client, name, network_id, ip):
503 json_body = {'port': {
504 'admin_state_up': True,
506 'network_id': network_id,
507 'fixed_ips': [{"ip_address": ip}]
510 port = neutron_client.create_port(body=json_body)
511 return port['port']['id']
513 logger.error("Error [create_neutron_port(neutron_client, '%s', '%s', "
514 "'%s')]: %s" % (name, network_id, ip, e))
518 def update_neutron_net(neutron_client, network_id, shared=False):
519 json_body = {'network': {'shared': shared}}
521 neutron_client.update_network(network_id, body=json_body)
524 logger.error("Error [update_neutron_net(neutron_client, '%s', '%s')]: "
525 "%s" % (network_id, str(shared), e))
529 def update_neutron_port(neutron_client, port_id, device_owner):
530 json_body = {'port': {
531 'device_owner': device_owner,
534 port = neutron_client.update_port(port=port_id,
536 return port['port']['id']
538 logger.error("Error [update_neutron_port(neutron_client, '%s', '%s')]:"
539 " %s" % (port_id, device_owner, e))
543 def add_interface_router(neutron_client, router_id, subnet_id):
544 json_body = {"subnet_id": subnet_id}
546 neutron_client.add_interface_router(router=router_id, body=json_body)
549 logger.error("Error [add_interface_router(neutron_client, '%s', "
550 "'%s')]: %s" % (router_id, subnet_id, e))
554 def add_gateway_router(neutron_client, router_id):
555 ext_net_id = get_external_net_id(neutron_client)
556 router_dict = {'network_id': ext_net_id}
558 neutron_client.add_gateway_router(router_id, router_dict)
561 logger.error("Error [add_gateway_router(neutron_client, '%s')]: %s"
566 def delete_neutron_net(neutron_client, network_id):
568 neutron_client.delete_network(network_id)
571 logger.error("Error [delete_neutron_net(neutron_client, '%s')]: %s"
576 def delete_neutron_subnet(neutron_client, subnet_id):
578 neutron_client.delete_subnet(subnet_id)
581 logger.error("Error [delete_neutron_subnet(neutron_client, '%s')]: %s"
586 def delete_neutron_router(neutron_client, router_id):
588 neutron_client.delete_router(router=router_id)
591 logger.error("Error [delete_neutron_router(neutron_client, '%s')]: %s"
596 def delete_neutron_port(neutron_client, port_id):
598 neutron_client.delete_port(port_id)
601 logger.error("Error [delete_neutron_port(neutron_client, '%s')]: %s"
606 def remove_interface_router(neutron_client, router_id, subnet_id):
607 json_body = {"subnet_id": subnet_id}
609 neutron_client.remove_interface_router(router=router_id,
613 logger.error("Error [remove_interface_router(neutron_client, '%s', "
614 "'%s')]: %s" % (router_id, subnet_id, e))
618 def remove_gateway_router(neutron_client, router_id):
620 neutron_client.remove_gateway_router(router_id)
623 logger.error("Error [remove_gateway_router(neutron_client, '%s')]: %s"
628 def create_network_full(neutron_client,
634 # Check if the network already exists
635 network_id = get_network_id(neutron_client, net_name)
636 subnet_id = get_subnet_id(neutron_client, subnet_name)
637 router_id = get_router_id(neutron_client, router_name)
639 if network_id != '' and subnet_id != '' and router_id != '':
640 logger.info("A network with name '%s' already exists..." % net_name)
642 neutron_client.format = 'json'
643 logger.info('Creating neutron network %s...' % net_name)
644 network_id = create_neutron_net(neutron_client, net_name)
649 logger.debug("Network '%s' created successfully" % network_id)
650 logger.debug('Creating Subnet....')
651 subnet_id = create_neutron_subnet(neutron_client, subnet_name,
656 logger.debug("Subnet '%s' created successfully" % subnet_id)
657 logger.debug('Creating Router...')
658 router_id = create_neutron_router(neutron_client, router_name)
663 logger.debug("Router '%s' created successfully" % router_id)
664 logger.debug('Adding router to subnet...')
666 if not add_interface_router(neutron_client, router_id, subnet_id):
669 logger.debug("Interface added successfully.")
671 logger.debug('Adding gateway to router...')
672 if not add_gateway_router(neutron_client, router_id):
675 logger.debug("Gateway added successfully.")
677 network_dic = {'net_id': network_id,
678 'subnet_id': subnet_id,
679 'router_id': router_id}
683 def create_shared_network_full(net_name, subnt_name, router_name, subnet_cidr):
684 neutron_client = get_neutron_client()
686 network_dic = create_network_full(neutron_client,
692 if not update_neutron_net(neutron_client,
693 network_dic['net_id'],
695 logger.error("Failed to update network %s..." % net_name)
698 logger.debug("Network '%s' is available..." % net_name)
700 logger.error("Network %s creation failed" % net_name)
705 def create_bgpvpn(neutron_client, **kwargs):
706 # route_distinguishers
708 json_body = {"bgpvpn": kwargs}
709 return neutron_client.create_bgpvpn(json_body)
712 def create_network_association(neutron_client, bgpvpn_id, neutron_network_id):
713 json_body = {"network_association": {"network_id": neutron_network_id}}
714 return neutron_client.create_network_association(bgpvpn_id, json_body)
717 def create_router_association(neutron_client, bgpvpn_id, router_id):
718 json_body = {"router_association": {"router_id": router_id}}
719 return neutron_client.create_router_association(bgpvpn_id, json_body)
722 def update_bgpvpn(neutron_client, bgpvpn_id, **kwargs):
723 json_body = {"bgpvpn": kwargs}
724 return neutron_client.update_bgpvpn(bgpvpn_id, json_body)
727 def delete_bgpvpn(neutron_client, bgpvpn_id):
728 return neutron_client.delete_bgpvpn(bgpvpn_id)
730 # *********************************************
732 # *********************************************
735 def get_security_groups(neutron_client):
737 security_groups = neutron_client.list_security_groups()[
739 return security_groups
741 logger.error("Error [get_security_groups(neutron_client)]: %s" % e)
745 def get_security_group_id(neutron_client, sg_name):
746 security_groups = get_security_groups(neutron_client)
748 for sg in security_groups:
749 if sg['name'] == sg_name:
755 def create_security_group(neutron_client, sg_name, sg_description):
756 json_body = {'security_group': {'name': sg_name,
757 'description': sg_description}}
759 secgroup = neutron_client.create_security_group(json_body)
760 return secgroup['security_group']
762 logger.error("Error [create_security_group(neutron_client, '%s', "
763 "'%s')]: %s" % (sg_name, sg_description, e))
767 def create_secgroup_rule(neutron_client, sg_id, direction, protocol,
768 port_range_min=None, port_range_max=None):
769 if port_range_min is None and port_range_max is None:
770 json_body = {'security_group_rule': {'direction': direction,
771 'security_group_id': sg_id,
772 'protocol': protocol}}
773 elif port_range_min is not None and port_range_max is not None:
774 json_body = {'security_group_rule': {'direction': direction,
775 'security_group_id': sg_id,
776 'port_range_min': port_range_min,
777 'port_range_max': port_range_max,
778 'protocol': protocol}}
780 logger.error("Error [create_secgroup_rule(neutron_client, '%s', '%s', "
781 "'%s', '%s', '%s', '%s')]:" % (neutron_client,
786 " Invalid values for port_range_min, port_range_max")
789 neutron_client.create_security_group_rule(json_body)
792 logger.error("Error [create_secgroup_rule(neutron_client, '%s', '%s', "
793 "'%s', '%s', '%s', '%s')]: %s" % (neutron_client,
802 def create_security_group_full(neutron_client,
803 sg_name, sg_description):
804 sg_id = get_security_group_id(neutron_client, sg_name)
806 logger.info("Using existing security group '%s'..." % sg_name)
808 logger.info("Creating security group '%s'..." % sg_name)
809 SECGROUP = create_security_group(neutron_client,
813 logger.error("Failed to create the security group...")
816 sg_id = SECGROUP['id']
818 logger.debug("Security group '%s' with ID=%s created successfully."
819 % (SECGROUP['name'], sg_id))
821 logger.debug("Adding ICMP rules in security group '%s'..."
823 if not create_secgroup_rule(neutron_client, sg_id,
825 logger.error("Failed to create the security group rule...")
828 logger.debug("Adding SSH rules in security group '%s'..."
830 if not create_secgroup_rule(
831 neutron_client, sg_id, 'ingress', 'tcp', '22', '22'):
832 logger.error("Failed to create the security group rule...")
835 if not create_secgroup_rule(
836 neutron_client, sg_id, 'egress', 'tcp', '22', '22'):
837 logger.error("Failed to create the security group rule...")
842 def add_secgroup_to_instance(nova_client, instance_id, secgroup_id):
844 nova_client.servers.add_security_group(instance_id, secgroup_id)
847 logger.error("Error [add_secgroup_to_instance(nova_client, '%s', "
848 "'%s')]: %s" % (instance_id, secgroup_id, e))
852 def update_sg_quota(neutron_client, tenant_id, sg_quota, sg_rule_quota):
853 json_body = {"quota": {
854 "security_group": sg_quota,
855 "security_group_rule": sg_rule_quota
859 neutron_client.update_quota(tenant_id=tenant_id,
863 logger.error("Error [update_sg_quota(neutron_client, '%s', '%s', "
864 "'%s')]: %s" % (tenant_id, sg_quota, sg_rule_quota, e))
868 def delete_security_group(neutron_client, secgroup_id):
870 neutron_client.delete_security_group(secgroup_id)
873 logger.error("Error [delete_security_group(neutron_client, '%s')]: %s"
878 # *********************************************
880 # *********************************************
881 def get_images(nova_client):
883 images = nova_client.images.list()
886 logger.error("Error [get_images]: %s" % e)
890 def get_image_id(glance_client, image_name):
891 images = glance_client.images.list()
894 if i.name == image_name:
900 def create_glance_image(glance_client, image_name, file_path, disk="qcow2",
901 container="bare", public=True):
902 if not os.path.isfile(file_path):
903 logger.error("Error: file %s does not exist." % file_path)
906 image_id = get_image_id(glance_client, image_name)
909 logger.info("Image %s already exists." % image_name)
912 logger.info("Creating image '%s' from '%s'..." % (image_name,
915 properties = ft_utils.get_functest_config(
916 'general.image_properties')
918 # image properties are not configured
919 # therefore don't add any properties
921 with open(file_path) as fimage:
922 image = glance_client.images.create(name=image_name,
925 container_format=container,
926 properties=properties,
931 logger.error("Error [create_glance_image(glance_client, '%s', '%s', "
932 "'%s')]: %s" % (image_name, file_path, str(public), e))
936 def get_or_create_image(name, path, format):
938 glance_client = get_glance_client()
940 image_id = get_image_id(glance_client, name)
942 logger.info("Using existing image '%s'..." % name)
945 logger.info("Creating image '%s' from '%s'..." % (name, path))
946 image_id = create_glance_image(glance_client, name, path, format)
948 logger.error("Failed to create a Glance image...")
950 logger.debug("Image '%s' with ID=%s created successfully."
953 return image_exists, image_id
956 def delete_glance_image(nova_client, image_id):
958 nova_client.images.delete(image_id)
961 logger.error("Error [delete_glance_image(nova_client, '%s')]: %s"
966 # *********************************************
968 # *********************************************
969 def get_volumes(cinder_client):
971 volumes = cinder_client.volumes.list(search_opts={'all_tenants': 1})
974 logger.error("Error [get_volumes(cinder_client)]: %s" % e)
978 def list_volume_types(cinder_client, public=True, private=True):
980 volume_types = cinder_client.volume_types.list()
982 volume_types = [vt for vt in volume_types if not vt.is_public]
984 volume_types = [vt for vt in volume_types if vt.is_public]
987 logger.error("Error [list_volume_types(cinder_client)]: %s" % e)
991 def create_volume_type(cinder_client, name):
993 volume_type = cinder_client.volume_types.create(name)
996 logger.error("Error [create_volume_type(cinder_client, '%s')]: %s"
1001 def update_cinder_quota(cinder_client, tenant_id, vols_quota,
1002 snapshots_quota, gigabytes_quota):
1003 quotas_values = {"volumes": vols_quota,
1004 "snapshots": snapshots_quota,
1005 "gigabytes": gigabytes_quota}
1008 cinder_client.quotas.update(tenant_id, **quotas_values)
1010 except Exception, e:
1011 logger.error("Error [update_cinder_quota(cinder_client, '%s', '%s', "
1012 "'%s' '%s')]: %s" % (tenant_id, vols_quota,
1013 snapshots_quota, gigabytes_quota, e))
1017 def delete_volume(cinder_client, volume_id, forced=False):
1021 cinder_client.volumes.detach(volume_id)
1023 logger.error(sys.exc_info()[0])
1024 cinder_client.volumes.force_delete(volume_id)
1026 cinder_client.volumes.delete(volume_id)
1028 except Exception, e:
1029 logger.error("Error [delete_volume(cinder_client, '%s', '%s')]: %s"
1030 % (volume_id, str(forced), e))
1034 def delete_volume_type(cinder_client, volume_type):
1036 cinder_client.volume_types.delete(volume_type)
1038 except Exception, e:
1039 logger.error("Error [delete_volume_type(cinder_client, '%s')]: %s"
1044 # *********************************************
1046 # *********************************************
1047 def get_tenants(keystone_client):
1049 tenants = keystone_client.tenants.list()
1051 except Exception, e:
1052 logger.error("Error [get_tenants(keystone_client)]: %s" % e)
1056 def get_users(keystone_client):
1058 users = keystone_client.users.list()
1060 except Exception, e:
1061 logger.error("Error [get_users(keystone_client)]: %s" % e)
1065 def get_tenant_id(keystone_client, tenant_name):
1066 tenants = keystone_client.tenants.list()
1069 if t.name == tenant_name:
1075 def get_user_id(keystone_client, user_name):
1076 users = keystone_client.users.list()
1079 if u.name == user_name:
1085 def get_role_id(keystone_client, role_name):
1086 roles = keystone_client.roles.list()
1089 if r.name == role_name:
1095 def create_tenant(keystone_client, tenant_name, tenant_description):
1097 tenant = keystone_client.tenants.create(tenant_name,
1101 except Exception, e:
1102 logger.error("Error [create_tenant(keystone_client, '%s', '%s')]: %s"
1103 % (tenant_name, tenant_description, e))
1107 def create_user(keystone_client, user_name, user_password,
1108 user_email, tenant_id):
1110 user = keystone_client.users.create(user_name, user_password,
1111 user_email, tenant_id,
1114 except Exception, e:
1115 logger.error("Error [create_user(keystone_client, '%s', '%s', '%s'"
1116 "'%s')]: %s" % (user_name, user_password,
1117 user_email, tenant_id, e))
1121 def add_role_user(keystone_client, user_id, role_id, tenant_id):
1123 keystone_client.roles.add_user_role(user_id, role_id, tenant_id)
1125 except Exception, e:
1126 logger.error("Error [add_role_user(keystone_client, '%s', '%s'"
1127 "'%s')]: %s " % (user_id, role_id, tenant_id, e))
1131 def delete_tenant(keystone_client, tenant_id):
1133 keystone_client.tenants.delete(tenant_id)
1135 except Exception, e:
1136 logger.error("Error [delete_tenant(keystone_client, '%s')]: %s"
1141 def delete_user(keystone_client, user_id):
1143 keystone_client.users.delete(user_id)
1145 except Exception, e:
1146 logger.error("Error [delete_user(keystone_client, '%s')]: %s"