neutron-tempest-plugin/neutron_tempest_plugin/bgpvpn/base.py
Slawek Kaplonski a7bb1619d4 Add possibility to disable running stadium projects tests
This patch adds possibility to disable running of tests related to:
* networking-bgpvpn,
* neutron-fwaas,
* networking-sfc

which were moved to neutron-tempest-plugin repo recently.
This will be useful when tests will be run for one of
stable branches up to Stein, in which those tests are still
in project's repo.

Change-Id: I61dc252920154e7e0998eb2c7c1f026814796cdf
2019-07-18 14:26:08 +02:00

96 lines
3.5 KiB
Python

# Copyright (c) 2015 Ericsson.
# All Rights Reserved.
#
# 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 tempest.api.network.base as test
from tempest.common import utils
from tempest import config
from tempest.lib.common.utils import data_utils
from neutron_tempest_plugin.bgpvpn.services import bgpvpn_client
CONF = config.CONF
class BaseBgpvpnTest(test.BaseNetworkTest):
"""Base class for the Bgpvpn tests that use the Tempest Neutron REST client
"""
credentials = ['primary', 'admin', 'alt']
bgpvpn_client = None
bgpvpn_admin_client = None
bgpvpn_alt_client = None
@classmethod
def resource_cleanup(cls):
for bgpvpn in cls.bgpvpns:
cls.bgpvpn_admin_client.delete_bgpvpn(bgpvpn['id'])
super(BaseBgpvpnTest, cls).resource_cleanup()
@classmethod
def resource_setup(cls):
cls.route_distinguishers = []
cls.bgpvpns = []
cls.bgpvpn_client = bgpvpn_client.BgpvpnClient(
cls.os_primary.auth_provider,
CONF.network.catalog_type,
CONF.network.region or CONF.identity.region,
endpoint_type=CONF.network.endpoint_type,
build_interval=CONF.network.build_interval,
build_timeout=CONF.network.build_timeout,
**cls.os_primary.default_params)
cls.bgpvpn_admin_client = bgpvpn_client.BgpvpnClient(
cls.os_admin.auth_provider,
CONF.network.catalog_type,
CONF.network.region or CONF.identity.region,
endpoint_type=CONF.network.endpoint_type,
build_interval=CONF.network.build_interval,
build_timeout=CONF.network.build_timeout,
**cls.os_admin.default_params)
cls.bgpvpn_alt_client = bgpvpn_client.BgpvpnClient(
cls.os_alt.auth_provider,
CONF.network.catalog_type,
CONF.network.region or CONF.identity.region,
endpoint_type=CONF.network.endpoint_type,
build_interval=CONF.network.build_interval,
build_timeout=CONF.network.build_timeout,
**cls.os_alt.default_params)
super(BaseBgpvpnTest, cls).resource_setup()
@classmethod
def skip_checks(cls):
super(BaseBgpvpnTest, cls).skip_checks()
msg = None
if not utils.is_extension_enabled('bgpvpn', 'network'):
msg = "Bgpvpn extension not enabled."
elif not CONF.bgpvpn.run_bgpvpn_tests:
msg = ("Running of bgpvpn related tests is disabled in "
"plugin configuration.")
if msg:
raise cls.skipException(msg)
def create_bgpvpn(self, client, **kwargs):
if 'name' not in kwargs:
kwargs['name'] = data_utils.rand_name('test-bgpvpn-')
body = client.create_bgpvpn(**kwargs)
bgpvpn = body['bgpvpn']
self.bgpvpns.append(bgpvpn)
return bgpvpn
def delete_bgpvpn(self, client, bgpvpn):
client.delete_bgpvpn(bgpvpn['id'])
self.bgpvpns.remove(bgpvpn)