committed by
GitHub
2 changed files with 48 additions and 4 deletions
@ -0,0 +1,44 @@ |
|||
from fastapi import FastAPI, HTTPException |
|||
from fastapi.exceptions import RequestValidationError |
|||
from fastapi.testclient import TestClient |
|||
from starlette.responses import JSONResponse |
|||
|
|||
|
|||
def http_exception_handler(request, exception): |
|||
return JSONResponse({"exception": "http-exception"}) |
|||
|
|||
|
|||
def request_validation_exception_handler(request, exception): |
|||
return JSONResponse({"exception": "request-validation"}) |
|||
|
|||
|
|||
app = FastAPI( |
|||
exception_handlers={ |
|||
HTTPException: http_exception_handler, |
|||
RequestValidationError: request_validation_exception_handler, |
|||
} |
|||
) |
|||
|
|||
client = TestClient(app) |
|||
|
|||
|
|||
@app.get("/http-exception") |
|||
def route_with_http_exception(): |
|||
raise HTTPException(status_code=400) |
|||
|
|||
|
|||
@app.get("/request-validation/{param}/") |
|||
def route_with_request_validation_exception(param: int): |
|||
pass # pragma: no cover |
|||
|
|||
|
|||
def test_override_http_exception(): |
|||
response = client.get("/http-exception") |
|||
assert response.status_code == 200 |
|||
assert response.json() == {"exception": "http-exception"} |
|||
|
|||
|
|||
def test_override_request_validation_exception(): |
|||
response = client.get("/request-validation/invalid") |
|||
assert response.status_code == 200 |
|||
assert response.json() == {"exception": "request-validation"} |
Loading…
Reference in new issue