3 # Copyright (c) 2018 Orange and others.
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
10 """Verify the connection to OpenStack Services"""
15 import os_client_config
17 from xtesting.core import testcase
19 from functest.utils import env
20 from functest.utils import functest_utils
23 class ConnectionCheck(testcase.TestCase):
24 """Perform simplest queries"""
25 __logger = logging.getLogger(__name__)
28 "get_network_extensions", "list_aggregates", "list_domains",
29 "list_endpoints", "list_floating_ip_pools", "list_floating_ips",
30 "list_hypervisors", "list_keypairs", "list_networks", "list_ports",
31 "list_role_assignments", "list_roles", "list_routers", "list_servers",
32 "list_services", "list_subnets"]
34 def __init__(self, **kwargs):
35 if "case_name" not in kwargs:
36 kwargs["case_name"] = 'connection_check'
37 super(ConnectionCheck, self).__init__(**kwargs)
39 cloud_config = os_client_config.get_config()
40 self.cloud = shade.OpenStackCloud(cloud_config=cloud_config)
41 except Exception: # pylint: disable=broad-except
44 def run(self, **kwargs):
45 # pylint: disable=protected-access
46 """Run all read operations to check connections"""
47 status = testcase.TestCase.EX_RUN_ERROR
50 self.start_time = time.time()
51 if env.get('PUBLIC_ENDPOINT_ONLY').lower() == 'true':
52 self.__logger.warning(
53 "Listing services is skipped "
54 "because the admin endpoints are unreachable")
55 self.func_list.remove("list_services")
56 for func in self.func_list:
58 "%s: %s", func, getattr(self.cloud, func)())
59 data = self.cloud._network_client.get("/service-providers.json")
61 "list_service_providers: %s",
62 self.cloud._get_and_munchify('service_providers', data))
63 functest_utils.get_openstack_version(self.cloud)
65 status = testcase.TestCase.EX_OK
66 except Exception: # pylint: disable=broad-except
67 self.__logger.exception('Cannot run %s', self.case_name)
69 self.stop_time = time.time()