summaryrefslogtreecommitdiff
path: root/venv/lib/python3.11/site-packages/httpx/_transports/mock.py
diff options
context:
space:
mode:
Diffstat (limited to 'venv/lib/python3.11/site-packages/httpx/_transports/mock.py')
-rw-r--r--venv/lib/python3.11/site-packages/httpx/_transports/mock.py40
1 files changed, 40 insertions, 0 deletions
diff --git a/venv/lib/python3.11/site-packages/httpx/_transports/mock.py b/venv/lib/python3.11/site-packages/httpx/_transports/mock.py
new file mode 100644
index 0000000..5abea83
--- /dev/null
+++ b/venv/lib/python3.11/site-packages/httpx/_transports/mock.py
@@ -0,0 +1,40 @@
+from __future__ import annotations
+
+import typing
+
+from .._models import Request, Response
+from .base import AsyncBaseTransport, BaseTransport
+
+SyncHandler = typing.Callable[[Request], Response]
+AsyncHandler = typing.Callable[[Request], typing.Coroutine[None, None, Response]]
+
+
+class MockTransport(AsyncBaseTransport, BaseTransport):
+ def __init__(self, handler: SyncHandler | AsyncHandler) -> None:
+ self.handler = handler
+
+ def handle_request(
+ self,
+ request: Request,
+ ) -> Response:
+ request.read()
+ response = self.handler(request)
+ if not isinstance(response, Response): # pragma: no cover
+ raise TypeError("Cannot use an async handler in a sync Client")
+ return response
+
+ async def handle_async_request(
+ self,
+ request: Request,
+ ) -> Response:
+ await request.aread()
+ response = self.handler(request)
+
+ # Allow handler to *optionally* be an `async` function.
+ # If it is, then the `response` variable need to be awaited to actually
+ # return the result.
+
+ if not isinstance(response, Response):
+ response = await response
+
+ return response