Home / File/ test_multi_query_errors.py — fastapi Source File

test_multi_query_errors.py — fastapi Source File

Architecture documentation for test_multi_query_errors.py, a python file in the fastapi codebase. 3 imports, 0 dependents.

File python FastAPI Responses 3 imports 4 functions

Entity Profile

Dependency Diagram

graph LR
  2736d454_5034_9b17_1eb8_a3a0fe5b4f9f["test_multi_query_errors.py"]
  534f6e44_61b8_3c38_8b89_6934a6df9802["__init__.py"]
  2736d454_5034_9b17_1eb8_a3a0fe5b4f9f --> 534f6e44_61b8_3c38_8b89_6934a6df9802
  a7c04dee_ee23_5891_b185_47ff6bed036d["testclient.py"]
  2736d454_5034_9b17_1eb8_a3a0fe5b4f9f --> a7c04dee_ee23_5891_b185_47ff6bed036d
  a7f4e7b0_9725_db90_5cbc_7ca8211b323a["inline_snapshot"]
  2736d454_5034_9b17_1eb8_a3a0fe5b4f9f --> a7f4e7b0_9725_db90_5cbc_7ca8211b323a
  style 2736d454_5034_9b17_1eb8_a3a0fe5b4f9f fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

from fastapi import FastAPI, Query
from fastapi.testclient import TestClient
from inline_snapshot import snapshot

app = FastAPI()


@app.get("/items/")
def read_items(q: list[int] = Query(default=None)):
    return {"q": q}


client = TestClient(app)


def test_multi_query():
    response = client.get("/items/?q=5&q=6")
    assert response.status_code == 200, response.text
    assert response.json() == {"q": [5, 6]}


def test_multi_query_incorrect():
    response = client.get("/items/?q=five&q=six")
    assert response.status_code == 422, response.text
    assert response.json() == {
        "detail": [
            {
                "type": "int_parsing",
                "loc": ["query", "q", 0],
                "msg": "Input should be a valid integer, unable to parse string as an integer",
                "input": "five",
            },
            {
                "type": "int_parsing",
                "loc": ["query", "q", 1],
                "msg": "Input should be a valid integer, unable to parse string as an integer",
                "input": "six",
            },
        ]
    }


def test_openapi_schema():
    response = client.get("/openapi.json")
    assert response.status_code == 200, response.text
    assert response.json() == snapshot(
        {
            "openapi": "3.1.0",
            "info": {"title": "FastAPI", "version": "0.1.0"},
            "paths": {
                "/items/": {
                    "get": {
                        "responses": {
                            "200": {
                                "description": "Successful Response",
                                "content": {"application/json": {"schema": {}}},
                            },
                            "422": {
                                "description": "Validation Error",
                                "content": {
// ... (63 more lines)

Domain

Subdomains

Dependencies

Frequently Asked Questions

What does test_multi_query_errors.py do?
test_multi_query_errors.py is a source file in the fastapi codebase, written in python. It belongs to the FastAPI domain, Responses subdomain.
What functions are defined in test_multi_query_errors.py?
test_multi_query_errors.py defines 4 function(s): read_items, test_multi_query, test_multi_query_incorrect, test_openapi_schema.
What does test_multi_query_errors.py depend on?
test_multi_query_errors.py imports 3 module(s): __init__.py, inline_snapshot, testclient.py.
Where is test_multi_query_errors.py in the architecture?
test_multi_query_errors.py is located at tests/test_multi_query_errors.py (domain: FastAPI, subdomain: Responses, directory: tests).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free