test_response_model_data_filter_no_inheritance.py — fastapi Source File
Architecture documentation for test_response_model_data_filter_no_inheritance.py, a python file in the fastapi codebase. 3 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR 6da5adae_3785_dd7d_f736_5bd185eecee6["test_response_model_data_filter_no_inheritance.py"] 534f6e44_61b8_3c38_8b89_6934a6df9802["__init__.py"] 6da5adae_3785_dd7d_f736_5bd185eecee6 --> 534f6e44_61b8_3c38_8b89_6934a6df9802 a7c04dee_ee23_5891_b185_47ff6bed036d["testclient.py"] 6da5adae_3785_dd7d_f736_5bd185eecee6 --> a7c04dee_ee23_5891_b185_47ff6bed036d 6913fbd4_39df_d14b_44bb_522e99b65b90["pydantic"] 6da5adae_3785_dd7d_f736_5bd185eecee6 --> 6913fbd4_39df_d14b_44bb_522e99b65b90 style 6da5adae_3785_dd7d_f736_5bd185eecee6 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
from fastapi import FastAPI
from fastapi.testclient import TestClient
from pydantic import BaseModel
app = FastAPI()
class UserCreate(BaseModel):
email: str
password: str
class UserDB(BaseModel):
email: str
hashed_password: str
class User(BaseModel):
email: str
class PetDB(BaseModel):
name: str
owner: UserDB
class PetOut(BaseModel):
name: str
owner: User
@app.post("/users/", response_model=User)
async def create_user(user: UserCreate):
return user
@app.get("/pets/{pet_id}", response_model=PetOut)
async def read_pet(pet_id: int):
user = UserDB(
email="johndoe@example.com",
hashed_password="secrethashed",
)
pet = PetDB(name="Nibbler", owner=user)
return pet
@app.get("/pets/", response_model=list[PetOut])
async def read_pets():
user = UserDB(
email="johndoe@example.com",
hashed_password="secrethashed",
)
pet1 = PetDB(name="Nibbler", owner=user)
pet2 = PetDB(name="Zoidberg", owner=user)
return [pet1, pet2]
client = TestClient(app)
def test_filter_top_level_model():
response = client.post(
"/users", json={"email": "johndoe@example.com", "password": "secret"}
)
assert response.json() == {"email": "johndoe@example.com"}
def test_filter_second_level_model():
response = client.get("/pets/1")
assert response.json() == {
"name": "Nibbler",
"owner": {"email": "johndoe@example.com"},
}
def test_list_of_models():
response = client.get("/pets/")
assert response.json() == [
{"name": "Nibbler", "owner": {"email": "johndoe@example.com"}},
{"name": "Zoidberg", "owner": {"email": "johndoe@example.com"}},
]
Domain
Subdomains
Functions
Classes
Dependencies
- __init__.py
- pydantic
- testclient.py
Source
Frequently Asked Questions
What does test_response_model_data_filter_no_inheritance.py do?
test_response_model_data_filter_no_inheritance.py is a source file in the fastapi codebase, written in python. It belongs to the FastAPI domain, Routing subdomain.
What functions are defined in test_response_model_data_filter_no_inheritance.py?
test_response_model_data_filter_no_inheritance.py defines 6 function(s): create_user, read_pet, read_pets, test_filter_second_level_model, test_filter_top_level_model, test_list_of_models.
What does test_response_model_data_filter_no_inheritance.py depend on?
test_response_model_data_filter_no_inheritance.py imports 3 module(s): __init__.py, pydantic, testclient.py.
Where is test_response_model_data_filter_no_inheritance.py in the architecture?
test_response_model_data_filter_no_inheritance.py is located at tests/test_response_model_data_filter_no_inheritance.py (domain: FastAPI, subdomain: Routing, directory: tests).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free