Browse Source
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>pull/11192/head
committed by
GitHub
17 changed files with 553 additions and 68 deletions
@ -0,0 +1,27 @@ |
|||||
|
from fastapi import Depends, FastAPI, HTTPException |
||||
|
|
||||
|
app = FastAPI() |
||||
|
|
||||
|
|
||||
|
class InternalError(Exception): |
||||
|
pass |
||||
|
|
||||
|
|
||||
|
def get_username(): |
||||
|
try: |
||||
|
yield "Rick" |
||||
|
except InternalError: |
||||
|
print("Oops, we didn't raise again, Britney 😱") |
||||
|
|
||||
|
|
||||
|
@app.get("/items/{item_id}") |
||||
|
def get_item(item_id: str, username: str = Depends(get_username)): |
||||
|
if item_id == "portal-gun": |
||||
|
raise InternalError( |
||||
|
f"The portal gun is too dangerous to be owned by {username}" |
||||
|
) |
||||
|
if item_id != "plumbus": |
||||
|
raise HTTPException( |
||||
|
status_code=404, detail="Item not found, there's only a plumbus here" |
||||
|
) |
||||
|
return item_id |
@ -0,0 +1,28 @@ |
|||||
|
from fastapi import Depends, FastAPI, HTTPException |
||||
|
from typing_extensions import Annotated |
||||
|
|
||||
|
app = FastAPI() |
||||
|
|
||||
|
|
||||
|
class InternalError(Exception): |
||||
|
pass |
||||
|
|
||||
|
|
||||
|
def get_username(): |
||||
|
try: |
||||
|
yield "Rick" |
||||
|
except InternalError: |
||||
|
print("Oops, we didn't raise again, Britney 😱") |
||||
|
|
||||
|
|
||||
|
@app.get("/items/{item_id}") |
||||
|
def get_item(item_id: str, username: Annotated[str, Depends(get_username)]): |
||||
|
if item_id == "portal-gun": |
||||
|
raise InternalError( |
||||
|
f"The portal gun is too dangerous to be owned by {username}" |
||||
|
) |
||||
|
if item_id != "plumbus": |
||||
|
raise HTTPException( |
||||
|
status_code=404, detail="Item not found, there's only a plumbus here" |
||||
|
) |
||||
|
return item_id |
@ -0,0 +1,29 @@ |
|||||
|
from typing import Annotated |
||||
|
|
||||
|
from fastapi import Depends, FastAPI, HTTPException |
||||
|
|
||||
|
app = FastAPI() |
||||
|
|
||||
|
|
||||
|
class InternalError(Exception): |
||||
|
pass |
||||
|
|
||||
|
|
||||
|
def get_username(): |
||||
|
try: |
||||
|
yield "Rick" |
||||
|
except InternalError: |
||||
|
print("Oops, we didn't raise again, Britney 😱") |
||||
|
|
||||
|
|
||||
|
@app.get("/items/{item_id}") |
||||
|
def get_item(item_id: str, username: Annotated[str, Depends(get_username)]): |
||||
|
if item_id == "portal-gun": |
||||
|
raise InternalError( |
||||
|
f"The portal gun is too dangerous to be owned by {username}" |
||||
|
) |
||||
|
if item_id != "plumbus": |
||||
|
raise HTTPException( |
||||
|
status_code=404, detail="Item not found, there's only a plumbus here" |
||||
|
) |
||||
|
return item_id |
@ -0,0 +1,28 @@ |
|||||
|
from fastapi import Depends, FastAPI, HTTPException |
||||
|
|
||||
|
app = FastAPI() |
||||
|
|
||||
|
|
||||
|
class InternalError(Exception): |
||||
|
pass |
||||
|
|
||||
|
|
||||
|
def get_username(): |
||||
|
try: |
||||
|
yield "Rick" |
||||
|
except InternalError: |
||||
|
print("We don't swallow the internal error here, we raise again 😎") |
||||
|
raise |
||||
|
|
||||
|
|
||||
|
@app.get("/items/{item_id}") |
||||
|
def get_item(item_id: str, username: str = Depends(get_username)): |
||||
|
if item_id == "portal-gun": |
||||
|
raise InternalError( |
||||
|
f"The portal gun is too dangerous to be owned by {username}" |
||||
|
) |
||||
|
if item_id != "plumbus": |
||||
|
raise HTTPException( |
||||
|
status_code=404, detail="Item not found, there's only a plumbus here" |
||||
|
) |
||||
|
return item_id |
@ -0,0 +1,29 @@ |
|||||
|
from fastapi import Depends, FastAPI, HTTPException |
||||
|
from typing_extensions import Annotated |
||||
|
|
||||
|
app = FastAPI() |
||||
|
|
||||
|
|
||||
|
class InternalError(Exception): |
||||
|
pass |
||||
|
|
||||
|
|
||||
|
def get_username(): |
||||
|
try: |
||||
|
yield "Rick" |
||||
|
except InternalError: |
||||
|
print("We don't swallow the internal error here, we raise again 😎") |
||||
|
raise |
||||
|
|
||||
|
|
||||
|
@app.get("/items/{item_id}") |
||||
|
def get_item(item_id: str, username: Annotated[str, Depends(get_username)]): |
||||
|
if item_id == "portal-gun": |
||||
|
raise InternalError( |
||||
|
f"The portal gun is too dangerous to be owned by {username}" |
||||
|
) |
||||
|
if item_id != "plumbus": |
||||
|
raise HTTPException( |
||||
|
status_code=404, detail="Item not found, there's only a plumbus here" |
||||
|
) |
||||
|
return item_id |
@ -0,0 +1,30 @@ |
|||||
|
from typing import Annotated |
||||
|
|
||||
|
from fastapi import Depends, FastAPI, HTTPException |
||||
|
|
||||
|
app = FastAPI() |
||||
|
|
||||
|
|
||||
|
class InternalError(Exception): |
||||
|
pass |
||||
|
|
||||
|
|
||||
|
def get_username(): |
||||
|
try: |
||||
|
yield "Rick" |
||||
|
except InternalError: |
||||
|
print("We don't swallow the internal error here, we raise again 😎") |
||||
|
raise |
||||
|
|
||||
|
|
||||
|
@app.get("/items/{item_id}") |
||||
|
def get_item(item_id: str, username: Annotated[str, Depends(get_username)]): |
||||
|
if item_id == "portal-gun": |
||||
|
raise InternalError( |
||||
|
f"The portal gun is too dangerous to be owned by {username}" |
||||
|
) |
||||
|
if item_id != "plumbus": |
||||
|
raise HTTPException( |
||||
|
status_code=404, detail="Item not found, there's only a plumbus here" |
||||
|
) |
||||
|
return item_id |
@ -1,23 +1,33 @@ |
|||||
|
import pytest |
||||
from fastapi.testclient import TestClient |
from fastapi.testclient import TestClient |
||||
|
|
||||
from docs_src.dependencies.tutorial008b_an import app |
from ...utils import needs_py39 |
||||
|
|
||||
client = TestClient(app) |
|
||||
|
|
||||
|
@pytest.fixture(name="client") |
||||
|
def get_client(): |
||||
|
from docs_src.dependencies.tutorial008b_an_py39 import app |
||||
|
|
||||
def test_get_no_item(): |
client = TestClient(app) |
||||
|
return client |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_get_no_item(client: TestClient): |
||||
response = client.get("/items/foo") |
response = client.get("/items/foo") |
||||
assert response.status_code == 404, response.text |
assert response.status_code == 404, response.text |
||||
assert response.json() == {"detail": "Item not found"} |
assert response.json() == {"detail": "Item not found"} |
||||
|
|
||||
|
|
||||
def test_owner_error(): |
@needs_py39 |
||||
|
def test_owner_error(client: TestClient): |
||||
response = client.get("/items/plumbus") |
response = client.get("/items/plumbus") |
||||
assert response.status_code == 400, response.text |
assert response.status_code == 400, response.text |
||||
assert response.json() == {"detail": "Owner error: Rick"} |
assert response.json() == {"detail": "Owner error: Rick"} |
||||
|
|
||||
|
|
||||
def test_get_item(): |
@needs_py39 |
||||
|
def test_get_item(client: TestClient): |
||||
response = client.get("/items/portal-gun") |
response = client.get("/items/portal-gun") |
||||
assert response.status_code == 200, response.text |
assert response.status_code == 200, response.text |
||||
assert response.json() == {"description": "Gun to create portals", "owner": "Rick"} |
assert response.json() == {"description": "Gun to create portals", "owner": "Rick"} |
||||
|
@ -0,0 +1,38 @@ |
|||||
|
import pytest |
||||
|
from fastapi.exceptions import FastAPIError |
||||
|
from fastapi.testclient import TestClient |
||||
|
|
||||
|
|
||||
|
@pytest.fixture(name="client") |
||||
|
def get_client(): |
||||
|
from docs_src.dependencies.tutorial008c import app |
||||
|
|
||||
|
client = TestClient(app) |
||||
|
return client |
||||
|
|
||||
|
|
||||
|
def test_get_no_item(client: TestClient): |
||||
|
response = client.get("/items/foo") |
||||
|
assert response.status_code == 404, response.text |
||||
|
assert response.json() == {"detail": "Item not found, there's only a plumbus here"} |
||||
|
|
||||
|
|
||||
|
def test_get(client: TestClient): |
||||
|
response = client.get("/items/plumbus") |
||||
|
assert response.status_code == 200, response.text |
||||
|
assert response.json() == "plumbus" |
||||
|
|
||||
|
|
||||
|
def test_fastapi_error(client: TestClient): |
||||
|
with pytest.raises(FastAPIError) as exc_info: |
||||
|
client.get("/items/portal-gun") |
||||
|
assert "No response object was returned" in exc_info.value.args[0] |
||||
|
|
||||
|
|
||||
|
def test_internal_server_error(): |
||||
|
from docs_src.dependencies.tutorial008c import app |
||||
|
|
||||
|
client = TestClient(app, raise_server_exceptions=False) |
||||
|
response = client.get("/items/portal-gun") |
||||
|
assert response.status_code == 500, response.text |
||||
|
assert response.text == "Internal Server Error" |
@ -0,0 +1,38 @@ |
|||||
|
import pytest |
||||
|
from fastapi.exceptions import FastAPIError |
||||
|
from fastapi.testclient import TestClient |
||||
|
|
||||
|
|
||||
|
@pytest.fixture(name="client") |
||||
|
def get_client(): |
||||
|
from docs_src.dependencies.tutorial008c_an import app |
||||
|
|
||||
|
client = TestClient(app) |
||||
|
return client |
||||
|
|
||||
|
|
||||
|
def test_get_no_item(client: TestClient): |
||||
|
response = client.get("/items/foo") |
||||
|
assert response.status_code == 404, response.text |
||||
|
assert response.json() == {"detail": "Item not found, there's only a plumbus here"} |
||||
|
|
||||
|
|
||||
|
def test_get(client: TestClient): |
||||
|
response = client.get("/items/plumbus") |
||||
|
assert response.status_code == 200, response.text |
||||
|
assert response.json() == "plumbus" |
||||
|
|
||||
|
|
||||
|
def test_fastapi_error(client: TestClient): |
||||
|
with pytest.raises(FastAPIError) as exc_info: |
||||
|
client.get("/items/portal-gun") |
||||
|
assert "No response object was returned" in exc_info.value.args[0] |
||||
|
|
||||
|
|
||||
|
def test_internal_server_error(): |
||||
|
from docs_src.dependencies.tutorial008c_an import app |
||||
|
|
||||
|
client = TestClient(app, raise_server_exceptions=False) |
||||
|
response = client.get("/items/portal-gun") |
||||
|
assert response.status_code == 500, response.text |
||||
|
assert response.text == "Internal Server Error" |
@ -0,0 +1,44 @@ |
|||||
|
import pytest |
||||
|
from fastapi.exceptions import FastAPIError |
||||
|
from fastapi.testclient import TestClient |
||||
|
|
||||
|
from ...utils import needs_py39 |
||||
|
|
||||
|
|
||||
|
@pytest.fixture(name="client") |
||||
|
def get_client(): |
||||
|
from docs_src.dependencies.tutorial008c_an_py39 import app |
||||
|
|
||||
|
client = TestClient(app) |
||||
|
return client |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_get_no_item(client: TestClient): |
||||
|
response = client.get("/items/foo") |
||||
|
assert response.status_code == 404, response.text |
||||
|
assert response.json() == {"detail": "Item not found, there's only a plumbus here"} |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_get(client: TestClient): |
||||
|
response = client.get("/items/plumbus") |
||||
|
assert response.status_code == 200, response.text |
||||
|
assert response.json() == "plumbus" |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_fastapi_error(client: TestClient): |
||||
|
with pytest.raises(FastAPIError) as exc_info: |
||||
|
client.get("/items/portal-gun") |
||||
|
assert "No response object was returned" in exc_info.value.args[0] |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_internal_server_error(): |
||||
|
from docs_src.dependencies.tutorial008c_an_py39 import app |
||||
|
|
||||
|
client = TestClient(app, raise_server_exceptions=False) |
||||
|
response = client.get("/items/portal-gun") |
||||
|
assert response.status_code == 500, response.text |
||||
|
assert response.text == "Internal Server Error" |
@ -0,0 +1,41 @@ |
|||||
|
import pytest |
||||
|
from fastapi.testclient import TestClient |
||||
|
|
||||
|
|
||||
|
@pytest.fixture(name="client") |
||||
|
def get_client(): |
||||
|
from docs_src.dependencies.tutorial008d import app |
||||
|
|
||||
|
client = TestClient(app) |
||||
|
return client |
||||
|
|
||||
|
|
||||
|
def test_get_no_item(client: TestClient): |
||||
|
response = client.get("/items/foo") |
||||
|
assert response.status_code == 404, response.text |
||||
|
assert response.json() == {"detail": "Item not found, there's only a plumbus here"} |
||||
|
|
||||
|
|
||||
|
def test_get(client: TestClient): |
||||
|
response = client.get("/items/plumbus") |
||||
|
assert response.status_code == 200, response.text |
||||
|
assert response.json() == "plumbus" |
||||
|
|
||||
|
|
||||
|
def test_internal_error(client: TestClient): |
||||
|
from docs_src.dependencies.tutorial008d import InternalError |
||||
|
|
||||
|
with pytest.raises(InternalError) as exc_info: |
||||
|
client.get("/items/portal-gun") |
||||
|
assert ( |
||||
|
exc_info.value.args[0] == "The portal gun is too dangerous to be owned by Rick" |
||||
|
) |
||||
|
|
||||
|
|
||||
|
def test_internal_server_error(): |
||||
|
from docs_src.dependencies.tutorial008d import app |
||||
|
|
||||
|
client = TestClient(app, raise_server_exceptions=False) |
||||
|
response = client.get("/items/portal-gun") |
||||
|
assert response.status_code == 500, response.text |
||||
|
assert response.text == "Internal Server Error" |
@ -0,0 +1,41 @@ |
|||||
|
import pytest |
||||
|
from fastapi.testclient import TestClient |
||||
|
|
||||
|
|
||||
|
@pytest.fixture(name="client") |
||||
|
def get_client(): |
||||
|
from docs_src.dependencies.tutorial008d_an import app |
||||
|
|
||||
|
client = TestClient(app) |
||||
|
return client |
||||
|
|
||||
|
|
||||
|
def test_get_no_item(client: TestClient): |
||||
|
response = client.get("/items/foo") |
||||
|
assert response.status_code == 404, response.text |
||||
|
assert response.json() == {"detail": "Item not found, there's only a plumbus here"} |
||||
|
|
||||
|
|
||||
|
def test_get(client: TestClient): |
||||
|
response = client.get("/items/plumbus") |
||||
|
assert response.status_code == 200, response.text |
||||
|
assert response.json() == "plumbus" |
||||
|
|
||||
|
|
||||
|
def test_internal_error(client: TestClient): |
||||
|
from docs_src.dependencies.tutorial008d_an import InternalError |
||||
|
|
||||
|
with pytest.raises(InternalError) as exc_info: |
||||
|
client.get("/items/portal-gun") |
||||
|
assert ( |
||||
|
exc_info.value.args[0] == "The portal gun is too dangerous to be owned by Rick" |
||||
|
) |
||||
|
|
||||
|
|
||||
|
def test_internal_server_error(): |
||||
|
from docs_src.dependencies.tutorial008d_an import app |
||||
|
|
||||
|
client = TestClient(app, raise_server_exceptions=False) |
||||
|
response = client.get("/items/portal-gun") |
||||
|
assert response.status_code == 500, response.text |
||||
|
assert response.text == "Internal Server Error" |
@ -0,0 +1,47 @@ |
|||||
|
import pytest |
||||
|
from fastapi.testclient import TestClient |
||||
|
|
||||
|
from ...utils import needs_py39 |
||||
|
|
||||
|
|
||||
|
@pytest.fixture(name="client") |
||||
|
def get_client(): |
||||
|
from docs_src.dependencies.tutorial008d_an_py39 import app |
||||
|
|
||||
|
client = TestClient(app) |
||||
|
return client |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_get_no_item(client: TestClient): |
||||
|
response = client.get("/items/foo") |
||||
|
assert response.status_code == 404, response.text |
||||
|
assert response.json() == {"detail": "Item not found, there's only a plumbus here"} |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_get(client: TestClient): |
||||
|
response = client.get("/items/plumbus") |
||||
|
assert response.status_code == 200, response.text |
||||
|
assert response.json() == "plumbus" |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_internal_error(client: TestClient): |
||||
|
from docs_src.dependencies.tutorial008d_an_py39 import InternalError |
||||
|
|
||||
|
with pytest.raises(InternalError) as exc_info: |
||||
|
client.get("/items/portal-gun") |
||||
|
assert ( |
||||
|
exc_info.value.args[0] == "The portal gun is too dangerous to be owned by Rick" |
||||
|
) |
||||
|
|
||||
|
|
||||
|
@needs_py39 |
||||
|
def test_internal_server_error(): |
||||
|
from docs_src.dependencies.tutorial008d_an_py39 import app |
||||
|
|
||||
|
client = TestClient(app, raise_server_exceptions=False) |
||||
|
response = client.get("/items/portal-gun") |
||||
|
assert response.status_code == 500, response.text |
||||
|
assert response.text == "Internal Server Error" |
Loading…
Reference in new issue