
This patch migrates rest_client module to tempest-lib from tempest. The latest Change-Ids of each file are the following when this migration: * common/http.py : I43703e2289212389c7841f44691ae7849ed1f505 * common/rest_client.py : Ie9105b5d01e7883213c1d3398cc5fe56782920d9 * common/utils/misc.py : I9a591eaa1cf4dabba58f06a64814611a05a51365 * exceptions.py : Ic8fc216377942619f11a2462b79d0597071ac294 * tests/base.py : I8f14cd2ca6afc38d3fe8ee758272071111022896 * tests/fake_auth_provider.py: Id12341de52204e2c428e10b4b758b700b0fbab09 * tests/fake_http.py : I8f14cd2ca6afc38d3fe8ee758272071111022896 * tests/test_rest_client.py : Ie9105b5d01e7883213c1d3398cc5fe56782920d9 NOTE: Some docstrings are changed to avoid H404 and H405. Change-Id: I879a02681c99376ae57458a0f7a04c8032dfebb2
75 lines
2.4 KiB
Python
75 lines
2.4 KiB
Python
# Copyright 2013 IBM Corp.
|
|
#
|
|
# 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 copy
|
|
|
|
import httplib2
|
|
|
|
|
|
class fake_httplib2(object):
|
|
|
|
def __init__(self, return_type=None, *args, **kwargs):
|
|
self.return_type = return_type
|
|
|
|
def request(self, uri, method="GET", body=None, headers=None,
|
|
redirections=5, connection_type=None):
|
|
if not self.return_type:
|
|
fake_headers = httplib2.Response(headers)
|
|
return_obj = {
|
|
'uri': uri,
|
|
'method': method,
|
|
'body': body,
|
|
'headers': headers
|
|
}
|
|
return (fake_headers, return_obj)
|
|
elif isinstance(self.return_type, int):
|
|
body = "fake_body"
|
|
header_info = {
|
|
'content-type': 'text/plain',
|
|
'status': str(self.return_type),
|
|
'content-length': len(body)
|
|
}
|
|
resp_header = httplib2.Response(header_info)
|
|
return (resp_header, body)
|
|
else:
|
|
msg = "unsupported return type %s" % self.return_type
|
|
raise TypeError(msg)
|
|
|
|
|
|
class fake_httplib(object):
|
|
def __init__(self, headers, body=None,
|
|
version=1.0, status=200, reason="Ok"):
|
|
"""fake_httplib for tests
|
|
|
|
:param headers: dict representing HTTP response headers
|
|
:param body: file-like object
|
|
:param version: HTTP Version
|
|
:param status: Response status code
|
|
:param reason: Status code related message.
|
|
"""
|
|
self.body = body
|
|
self.status = status
|
|
self.reason = reason
|
|
self.version = version
|
|
self.headers = headers
|
|
|
|
def getheaders(self):
|
|
return copy.deepcopy(self.headers).items()
|
|
|
|
def getheader(self, key, default):
|
|
return self.headers.get(key, default)
|
|
|
|
def read(self, amt):
|
|
return self.body.read(amt)
|