2022-08-10 12:17:15 +00:00
|
|
|
import abc
|
|
|
|
import os
|
|
|
|
import json as json_parser
|
|
|
|
import requests
|
|
|
|
|
|
|
|
|
|
|
|
class RequestsBase(metaclass=abc.ABCMeta):
|
|
|
|
@staticmethod
|
|
|
|
@abc.abstractmethod
|
|
|
|
def get(url, params=None, **kwargs):
|
|
|
|
r"""Sends a GET request.
|
|
|
|
|
|
|
|
:param url: URL for the new :class:`Request` object.
|
|
|
|
:param params: (optional) Dictionary, list of tuples or bytes to send
|
|
|
|
in the query string for the :class:`Request`.
|
|
|
|
:param \*\*kwargs: Optional arguments that ``request`` takes.
|
|
|
|
:return: :class:`Response <Response>` object
|
|
|
|
:rtype: requests.Response
|
|
|
|
"""
|
2022-08-24 11:54:46 +00:00
|
|
|
data: dict = json_parser.loads(os.environ.get("REQUESTS_GET_RESPONSE", "{}"))
|
2022-08-10 12:17:15 +00:00
|
|
|
response_data: dict = data.get(url, {})
|
|
|
|
|
|
|
|
response = requests.Response()
|
|
|
|
response.url = url
|
2022-08-24 11:54:46 +00:00
|
|
|
response.status_code = response_data.get("status", 200)
|
|
|
|
response.encoding = response_data.get("encoding", "UTF-8")
|
|
|
|
response._content = bytes(response_data.get("content", ""), response.encoding)
|
2022-08-10 12:17:15 +00:00
|
|
|
print(url)
|
|
|
|
return response
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
@abc.abstractmethod
|
|
|
|
def options(url, **kwargs):
|
|
|
|
r"""Sends an OPTIONS request.
|
|
|
|
|
|
|
|
:param url: URL for the new :class:`Request` object.
|
|
|
|
:param \*\*kwargs: Optional arguments that ``request`` takes.
|
|
|
|
:return: :class:`Response <Response>` object
|
|
|
|
:rtype: requests.Response
|
|
|
|
"""
|
2022-08-24 11:54:46 +00:00
|
|
|
data: dict = json_parser.loads(
|
|
|
|
os.environ.get("REQUESTS_OPTIONS_RESPONSE", "{}")
|
|
|
|
)
|
2022-08-10 12:17:15 +00:00
|
|
|
response_data: dict = data.get(url, {})
|
|
|
|
|
|
|
|
response = requests.Response()
|
|
|
|
response.url = url
|
2022-08-24 11:54:46 +00:00
|
|
|
response.status_code = response_data.get("status", 200)
|
|
|
|
response.encoding = response_data.get("encoding", "UTF-8")
|
|
|
|
response._content = bytes(response_data.get("content", ""), response.encoding)
|
2022-08-10 12:17:15 +00:00
|
|
|
print(url)
|
|
|
|
return response
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
@abc.abstractmethod
|
|
|
|
def head(url, **kwargs):
|
|
|
|
r"""Sends a HEAD request.
|
|
|
|
|
|
|
|
:param url: URL for the new :class:`Request` object.
|
|
|
|
:param \*\*kwargs: Optional arguments that ``request`` takes. If
|
|
|
|
`allow_redirects` is not provided, it will be set to `False` (as
|
|
|
|
opposed to the default :meth:`request` behavior).
|
|
|
|
:return: :class:`Response <Response>` object
|
|
|
|
:rtype: requests.Response
|
|
|
|
"""
|
2022-08-24 11:54:46 +00:00
|
|
|
data: dict = json_parser.loads(os.environ.get("REQUESTS_HEAD_RESPONSE", "{}"))
|
2022-08-10 12:17:15 +00:00
|
|
|
response_data: dict = data.get(url, {})
|
|
|
|
|
|
|
|
response = requests.Response()
|
|
|
|
response.url = url
|
2022-08-24 11:54:46 +00:00
|
|
|
response.status_code = response_data.get("status", 200)
|
|
|
|
response.encoding = response_data.get("encoding", "UTF-8")
|
|
|
|
response._content = bytes(response_data.get("content", ""), response.encoding)
|
2022-08-10 12:17:15 +00:00
|
|
|
print(url)
|
|
|
|
return response
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
@abc.abstractmethod
|
|
|
|
def post(url, data=None, json=None, **kwargs):
|
|
|
|
r"""Sends a POST request.
|
|
|
|
|
|
|
|
:param url: URL for the new :class:`Request` object.
|
|
|
|
:param data: (optional) Dictionary, list of tuples, bytes, or file-like
|
|
|
|
object to send in the body of the :class:`Request`.
|
|
|
|
:param json: (optional) json data to send in the body of the :class:`Request`.
|
|
|
|
:param \*\*kwargs: Optional arguments that ``request`` takes.
|
|
|
|
:return: :class:`Response <Response>` object
|
|
|
|
:rtype: requests.Response
|
|
|
|
"""
|
2022-08-24 11:54:46 +00:00
|
|
|
data: dict = json_parser.loads(os.environ.get("REQUESTS_POST_RESPONSE", "{}"))
|
2022-08-10 12:17:15 +00:00
|
|
|
response_data: dict = data.get(url, {})
|
|
|
|
|
|
|
|
response = requests.Response()
|
|
|
|
response.url = url
|
2022-08-24 11:54:46 +00:00
|
|
|
response.status_code = response_data.get("status", 200)
|
|
|
|
response.encoding = response_data.get("encoding", "UTF-8")
|
|
|
|
response._content = bytes(response_data.get("content", ""), response.encoding)
|
2022-08-10 12:17:15 +00:00
|
|
|
print(url)
|
|
|
|
return response
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
@abc.abstractmethod
|
|
|
|
def put(url, data=None, **kwargs):
|
|
|
|
r"""Sends a PUT request.
|
|
|
|
|
|
|
|
:param url: URL for the new :class:`Request` object.
|
|
|
|
:param data: (optional) Dictionary, list of tuples, bytes, or file-like
|
|
|
|
object to send in the body of the :class:`Request`.
|
|
|
|
:param json: (optional) json data to send in the body of the :class:`Request`.
|
|
|
|
:param \*\*kwargs: Optional arguments that ``request`` takes.
|
|
|
|
:return: :class:`Response <Response>` object
|
|
|
|
:rtype: requests.Response
|
|
|
|
"""
|
2022-08-24 11:54:46 +00:00
|
|
|
data: dict = json_parser.loads(os.environ.get("REQUESTS_PUT_RESPONSE", "{}"))
|
2022-08-10 12:17:15 +00:00
|
|
|
response_data: dict = data.get(url, {})
|
|
|
|
|
|
|
|
response = requests.Response()
|
|
|
|
response.url = url
|
2022-08-24 11:54:46 +00:00
|
|
|
response.status_code = response_data.get("status", 200)
|
|
|
|
response.encoding = response_data.get("encoding", "UTF-8")
|
|
|
|
response._content = bytes(response_data.get("content", ""), response.encoding)
|
2022-08-10 12:17:15 +00:00
|
|
|
print(url)
|
|
|
|
return response
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
@abc.abstractmethod
|
|
|
|
def patch(url, data=None, **kwargs):
|
|
|
|
r"""Sends a PATCH request.
|
|
|
|
|
|
|
|
:param url: URL for the new :class:`Request` object.
|
|
|
|
:param data: (optional) Dictionary, list of tuples, bytes, or file-like
|
|
|
|
object to send in the body of the :class:`Request`.
|
|
|
|
:param json: (optional) json data to send in the body of the :class:`Request`.
|
|
|
|
:param \*\*kwargs: Optional arguments that ``request`` takes.
|
|
|
|
:return: :class:`Response <Response>` object
|
|
|
|
:rtype: requests.Response
|
|
|
|
"""
|
2022-08-24 11:54:46 +00:00
|
|
|
data: dict = json_parser.loads(os.environ.get("REQUESTS_PATCH_RESPONSE", "{}"))
|
2022-08-10 12:17:15 +00:00
|
|
|
response_data: dict = data.get(url, {})
|
|
|
|
|
|
|
|
response = requests.Response()
|
|
|
|
response.url = url
|
2022-08-24 11:54:46 +00:00
|
|
|
response.status_code = response_data.get("status", 200)
|
|
|
|
response.encoding = response_data.get("encoding", "UTF-8")
|
|
|
|
response._content = bytes(response_data.get("content", ""), response.encoding)
|
2022-08-10 12:17:15 +00:00
|
|
|
print(url)
|
|
|
|
return response
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
@abc.abstractmethod
|
|
|
|
def delete(url, **kwargs):
|
|
|
|
r"""Sends a DELETE request.
|
|
|
|
|
|
|
|
:param url: URL for the new :class:`Request` object.
|
|
|
|
:param \*\*kwargs: Optional arguments that ``request`` takes.
|
|
|
|
:return: :class:`Response <Response>` object
|
|
|
|
:rtype: requests.Response
|
|
|
|
"""
|
2022-08-24 11:54:46 +00:00
|
|
|
data: dict = json_parser.loads(os.environ.get("REQUESTS_DELETE_RESPONSE", "{}"))
|
2022-08-10 12:17:15 +00:00
|
|
|
response_data: dict = data.get(url, {})
|
|
|
|
|
|
|
|
response = requests.Response()
|
|
|
|
response.url = url
|
2022-08-24 11:54:46 +00:00
|
|
|
response.status_code = response_data.get("status", 200)
|
|
|
|
response.encoding = response_data.get("encoding", "UTF-8")
|
|
|
|
response._content = bytes(response_data.get("content", ""), response.encoding)
|
2022-08-10 12:17:15 +00:00
|
|
|
print(url)
|
|
|
|
return response
|