Add the flavor profile service client.
This patch adds the flavor profile service client to the Octavia tempest plugin. Change-Id: I461b069064e6329ea95ad26d697f11c74cc4dd5c
This commit is contained in:
parent
e05ba7e4f0
commit
fd90e15bd9
|
@ -17,6 +17,8 @@ from tempest import config
|
||||||
|
|
||||||
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
||||||
amphora_client)
|
amphora_client)
|
||||||
|
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
||||||
|
flavor_profile_client)
|
||||||
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
||||||
healthmonitor_client)
|
healthmonitor_client)
|
||||||
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
from octavia_tempest_plugin.services.load_balancer.v2 import (
|
||||||
|
@ -57,3 +59,5 @@ class ManagerV2(clients.Manager):
|
||||||
self.auth_provider, SERVICE_TYPE, CONF.identity.region)
|
self.auth_provider, SERVICE_TYPE, CONF.identity.region)
|
||||||
self.amphora_client = amphora_client.AmphoraClient(
|
self.amphora_client = amphora_client.AmphoraClient(
|
||||||
self.auth_provider, SERVICE_TYPE, CONF.identity.region)
|
self.auth_provider, SERVICE_TYPE, CONF.identity.region)
|
||||||
|
self.flavor_profile_client = flavor_profile_client.FlavorProfileClient(
|
||||||
|
self.auth_provider, SERVICE_TYPE, CONF.identity.region)
|
||||||
|
|
|
@ -0,0 +1,218 @@
|
||||||
|
# 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
|
||||||
|
|
||||||
|
Unset = base_client.Unset
|
||||||
|
|
||||||
|
|
||||||
|
class FlavorProfileClient(base_client.BaseLBaaSClient):
|
||||||
|
|
||||||
|
root_tag = 'flavorprofile'
|
||||||
|
list_root_tag = 'flavorprofiles'
|
||||||
|
|
||||||
|
def create_flavor_profile(self, name, provider_name, flavor_data,
|
||||||
|
return_object_only=True):
|
||||||
|
"""Create a flavor profile.
|
||||||
|
|
||||||
|
:param name: Human-readable name of the resource.
|
||||||
|
:param provider_name: The octavia provider name.
|
||||||
|
:param flavor_data: The JSON string containing the flavor metadata.
|
||||||
|
: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 flavor profile object.
|
||||||
|
"""
|
||||||
|
kwargs = {arg: value for arg, value in locals().items()
|
||||||
|
if arg != 'self' and value is not Unset}
|
||||||
|
return self._create_object(**kwargs)
|
||||||
|
|
||||||
|
def show_flavor_profile(self, flavorprofile_id, query_params=None,
|
||||||
|
return_object_only=True):
|
||||||
|
"""Get the flavor profile details.
|
||||||
|
|
||||||
|
:param flavorprofile_id: The flavor profile ID to query.
|
||||||
|
: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 flavor profile object.
|
||||||
|
"""
|
||||||
|
return self._show_object(obj_id=flavorprofile_id,
|
||||||
|
query_params=query_params,
|
||||||
|
return_object_only=return_object_only)
|
||||||
|
|
||||||
|
def list_flavor_profiles(self, query_params=None, return_object_only=True):
|
||||||
|
"""Get a list of flavor profile objects.
|
||||||
|
|
||||||
|
: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 profile objects.
|
||||||
|
"""
|
||||||
|
return self._list_objects(query_params=query_params,
|
||||||
|
return_object_only=return_object_only)
|
||||||
|
|
||||||
|
def update_flavor_profile(
|
||||||
|
self, flavorprofile_id, name=Unset, provider_name=Unset,
|
||||||
|
flavor_data=Unset, return_object_only=True):
|
||||||
|
"""Update a flavor profile.
|
||||||
|
|
||||||
|
:param flavorprofile_id: The flavor profile ID to update.
|
||||||
|
:param name: Human-readable name of the resource.
|
||||||
|
:param provider_name: The octavia provider name.
|
||||||
|
:param flavor_data: The JSON string containing the flavor metadata.
|
||||||
|
: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 flavor profile object.
|
||||||
|
"""
|
||||||
|
kwargs = {arg: value for arg, value in locals().items()
|
||||||
|
if arg != 'self' and value is not Unset}
|
||||||
|
kwargs['obj_id'] = kwargs.pop('flavorprofile_id')
|
||||||
|
return self._update_object(**kwargs)
|
||||||
|
|
||||||
|
def delete_flavor_profile(self, flavorprofile_id, ignore_errors=False):
|
||||||
|
"""Delete a flavor profile.
|
||||||
|
|
||||||
|
:param flavorprofile_id: The flavor profile ID to delete.
|
||||||
|
:param ignore_errors: True if errors should be ignored.
|
||||||
|
: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: None if ignore_errors is True, the response status code
|
||||||
|
if not.
|
||||||
|
"""
|
||||||
|
return self._delete_obj(obj_id=flavorprofile_id,
|
||||||
|
ignore_errors=ignore_errors)
|
Loading…
Reference in New Issue