
This migrates the above files from tempest. This includes tempest commits: * versions.py: I70294329870de46b2c4c8775a1d7920bee403954 * versions_client.py: I70294329870de46b2c4c8775a1d7920bee403954 to see the commit history for these files refer to the above Change-Ids in the tempest repository Partially implements blueprint migrate-service-clients-to-tempest-lib Change-Id: I41ec60e12a155ee80f3a1825405bdd6e1ec82425
56 lines
2.2 KiB
Python
56 lines
2.2 KiB
Python
# Copyright (c) 2015 Hewlett-Packard Development Company, L.P.
|
|
#
|
|
# 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 oslo_serialization import jsonutils as json
|
|
from six.moves import urllib
|
|
|
|
from tempest_lib.api_schema.response.compute.v2_1 import versions as schema
|
|
from tempest_lib.common import rest_client
|
|
|
|
|
|
class VersionsClient(rest_client.RestClient):
|
|
|
|
def _get_base_version_url(self):
|
|
# NOTE: The URL which is gotten from keystone's catalog contains
|
|
# API version and project-id like "v2/{project-id}", but we need
|
|
# to access the URL which doesn't contain them for getting API
|
|
# versions. For that, here should use raw_request() instead of
|
|
# get().
|
|
endpoint = self.base_url
|
|
url = urllib.parse.urlparse(endpoint)
|
|
return '%s://%s/' % (url.scheme, url.netloc)
|
|
|
|
def list_versions(self):
|
|
version_url = self._get_base_version_url()
|
|
resp, body = self.raw_request(version_url, 'GET')
|
|
body = json.loads(body)
|
|
self.validate_response(schema.list_versions, resp, body)
|
|
return rest_client.ResponseBody(resp, body)
|
|
|
|
def get_version_by_url(self, version_url):
|
|
"""Get the version document by url.
|
|
|
|
This gets the version document for a url, useful in testing
|
|
the contents of things like /v2/ or /v2.1/ in Nova. That
|
|
controller needs authenticated access, so we have to get
|
|
ourselves a token before making the request.
|
|
|
|
"""
|
|
# we need a token for this request
|
|
resp, body = self.raw_request(version_url, 'GET',
|
|
{'X-Auth-Token': self.token})
|
|
body = json.loads(body)
|
|
self.validate_response(schema.get_one_version, resp, body)
|
|
return rest_client.ResponseBody(resp, body)
|