Add the provider flavor capabilities service client.
This patch adds the provider flavor capabilities service client to the Octavia tempest plugin. Change-Id: Iea179ac6393c62d7cda4e43dff174a708e31d55c
This commit is contained in:
parent
c9414e8419
commit
37c9302688
|
@ -17,6 +17,8 @@ from tempest import config
|
|||
|
||||
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
||||
amphora_client)
|
||||
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
||||
flavor_capabilities_client)
|
||||
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
||||
flavor_client)
|
||||
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
||||
|
@ -69,3 +71,6 @@ class ManagerV2(clients.Manager):
|
|||
self.auth_provider, SERVICE_TYPE, CONF.identity.region)
|
||||
self.provider_client = provider_client.ProviderClient(
|
||||
self.auth_provider, SERVICE_TYPE, CONF.identity.region)
|
||||
self.flavor_capabilities_client = (
|
||||
flavor_capabilities_client.FlavorCapabilitiesClient(
|
||||
self.auth_provider, SERVICE_TYPE, CONF.identity.region))
|
||||
|
|
|
@ -0,0 +1,76 @@
|
|||
# Copyright 2019 Rackspace US Inc. 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.
|
||||
#
|
||||
|
||||
from octavia_tempest_plugin.services.load_balancer.v2 import base_client
|
||||
from octavia_tempest_plugin.services.load_balancer.v2 import provider_client
|
||||
|
||||
Unset = base_client.Unset
|
||||
|
||||
|
||||
class FlavorCapabilitiesClient(base_client.BaseLBaaSClient):
|
||||
|
||||
list_root_tag = 'flavor_capabilities'
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
super(FlavorCapabilitiesClient, self).__init__(*args, **kwargs)
|
||||
providers_list_root_tag = provider_client.ProviderClient.list_root_tag
|
||||
# /v2.0/lbaas/providers/<PROVIDER_UUID>/flavor_capabilities
|
||||
self.uri = "{provider_base_uri}/{parent}/{object}".format(
|
||||
provider_base_uri=self.base_uri.format(
|
||||
object=providers_list_root_tag),
|
||||
parent="{parent}",
|
||||
object=self.list_root_tag
|
||||
)
|
||||
|
||||
def list_flavor_capabilities(self, provider, query_params=None,
|
||||
return_object_only=True):
|
||||
"""Get a list of provider flavor capability objects.
|
||||
|
||||
:param provider: The provider to query for flavor capabilities.
|
||||
:param query_params: The optional query parameters to append to the
|
||||
request. Ex. fields=id&fields=name
|
||||
:param return_object_only: If True, the response returns the object
|
||||
inside the root tag. False returns the full
|
||||
response from the API.
|
||||
:raises AssertionError: if the expected_code isn't a valid http success
|
||||
response code
|
||||
:raises BadRequest: If a 400 response code is received
|
||||
:raises Conflict: If a 409 response code is received
|
||||
:raises Forbidden: If a 403 response code is received
|
||||
:raises Gone: If a 410 response code is received
|
||||
:raises InvalidContentType: If a 415 response code is received
|
||||
:raises InvalidHTTPResponseBody: The response body wasn't valid JSON
|
||||
:raises InvalidHttpSuccessCode: if the read code isn't an expected
|
||||
http success code
|
||||
:raises NotFound: If a 404 response code is received
|
||||
:raises NotImplemented: If a 501 response code is received
|
||||
:raises OverLimit: If a 413 response code is received and over_limit is
|
||||
not in the response body
|
||||
:raises RateLimitExceeded: If a 413 response code is received and
|
||||
over_limit is in the response body
|
||||
:raises ServerFault: If a 500 response code is received
|
||||
:raises Unauthorized: If a 401 response code is received
|
||||
:raises UnexpectedContentType: If the content-type of the response
|
||||
isn't an expect type
|
||||
:raises UnexpectedResponseCode: If a response code above 400 is
|
||||
received and it doesn't fall into any
|
||||
of the handled checks
|
||||
:raises UnprocessableEntity: If a 422 response code is received and
|
||||
couldn't be parsed
|
||||
:returns: A list of flavor capability objects.
|
||||
"""
|
||||
return self._list_objects(parent_id=provider,
|
||||
query_params=query_params,
|
||||
return_object_only=return_object_only)
|
Loading…
Reference in New Issue