
This addresses failures for neutronclient's functional job of advanced services. VPNaaS is no longer maintained and thus it makes sense to stop gating against it. Hook and tests are kept for local development and in case things will resurrect back to life. This patch also makes extension functional tests conditional to the presence of the extension under test. Closes-bug: #1645819 Change-Id: I17ab8accaa943b9ac04893b5e131be0afe0f5429
82 lines
2.9 KiB
Python
82 lines
2.9 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):
|
|
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')
|
|
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
|