
neutronclient func test is broken due to missing fully support of keystone v3 API. It seems keystone v2 API has been disbaled recently and this triggers the test failures. There are two causes. The one is because tempest.lib.cli.base supports only keystone v2 auth info. There is an on-going review in tempest, but until the next tempest release we need a workaround. The workaround is to pass keystone v3 related arguments in neutron() method. 'flags' argument allows us to pass extra auth info to the CLI. The other reason is because HTTPClient (the legacy python binding class) supports only keystone v2 API. keystone v3 API is provided via SessionClient. I believe it is not a good idea to keep the two types of python binding classes in future. It looks like a time to drop HTTPClient. As a start, this commit drops HTTPClient func tests. Note that SessionClient supports keystone v2 as well. Closes-Bug: #1721553 Related-Bug: #1719687 Change-Id: I6f843e1412400bb1dfb4fc2352fc5cc4c3b837a4
96 lines
3.8 KiB
Python
96 lines
3.8 KiB
Python
# 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.
|
|
|
|
import os
|
|
|
|
import os_client_config
|
|
from tempest.lib.cli import base
|
|
|
|
|
|
def credentials(cloud='devstack-admin'):
|
|
"""Retrieves credentials to run functional tests
|
|
|
|
Credentials are either read via os-client-config from the environment
|
|
or from a config file ('clouds.yaml'). Environment variables override
|
|
those from the config file.
|
|
|
|
devstack produces a clouds.yaml with two named clouds - one named
|
|
'devstack' which has user privs and one named 'devstack-admin' which
|
|
has admin privs. This function will default to getting the devstack-admin
|
|
cloud as that is the current expected behavior.
|
|
"""
|
|
return get_cloud_config(cloud=cloud).get_auth_args()
|
|
|
|
|
|
def get_cloud_config(cloud='devstack-admin'):
|
|
return os_client_config.OpenStackConfig().get_one_cloud(cloud=cloud)
|
|
|
|
|
|
class ClientTestBase(base.ClientTestBase):
|
|
"""This is a first pass at a simple read only python-neutronclient test.
|
|
|
|
This only exercises client commands that are read only.
|
|
This should test commands:
|
|
* as a regular user
|
|
* as an admin user
|
|
* with and without optional parameters
|
|
* initially just check return codes, and later test command outputs
|
|
|
|
"""
|
|
|
|
def _get_clients_from_os_cloud_config(self, cloud='devstack-admin'):
|
|
creds = credentials(cloud)
|
|
cli_dir = os.environ.get(
|
|
'OS_NEUTRONCLIENT_EXEC_DIR',
|
|
os.path.join(os.path.abspath('.'), '.tox/functional/bin'))
|
|
|
|
return base.CLIClient(
|
|
username=creds['username'],
|
|
password=creds['password'],
|
|
tenant_name=creds['project_name'],
|
|
uri=creds['auth_url'],
|
|
cli_dir=cli_dir)
|
|
|
|
def _get_clients(self):
|
|
return self._get_clients_from_os_cloud_config()
|
|
|
|
def neutron(self, *args, **kwargs):
|
|
# Workaround until tempest.lib.cli.base provdes fully
|
|
# keystone v3 support. It assumes the default domain.
|
|
# TODO(amotoki): Once a new tempest with a fix for bug 1719687
|
|
# is released, this should be claen up.
|
|
kwargs['flags'] = ' '.join([kwargs.get('flags', ''),
|
|
'--os-project-domain-id default',
|
|
'--os-user-domain-id default'])
|
|
return self.clients.neutron(*args,
|
|
**kwargs)
|
|
|
|
def neutron_non_admin(self, *args, **kwargs):
|
|
if not hasattr(self, '_non_admin_clients'):
|
|
self._non_admin_clients = self._get_clients_from_os_cloud_config(
|
|
cloud='devstack')
|
|
# Workaround until tempest.lib.cli.base provdes fully
|
|
# keystone v3 support. It assumes the default domain.
|
|
# TODO(amotoki): Once a new tempest with a fix for bug 1719687
|
|
# is released, this should be claen up.
|
|
kwargs['flags'] = ' '.join([kwargs.get('flags', ''),
|
|
'--os-project-domain-id default',
|
|
'--os-user-domain-id default'])
|
|
return self._non_admin_clients.neutron(*args, **kwargs)
|
|
|
|
def is_extension_enabled(self, extension_alias):
|
|
extensions = self.parser.listing(self.neutron('ext-list'))
|
|
for extension in extensions:
|
|
if extension_alias in extension['alias']:
|
|
return True
|
|
return False
|