Home / File/ test_security_api_key_query_description.py — fastapi Source File

test_security_api_key_query_description.py — fastapi Source File

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

File python FastAPI Applications 5 imports 5 functions 1 classes

Entity Profile

Dependency Diagram

graph LR
  976ab196_f33b_271e_81d9_a463ce9ff3df["test_security_api_key_query_description.py"]
  534f6e44_61b8_3c38_8b89_6934a6df9802["__init__.py"]
  976ab196_f33b_271e_81d9_a463ce9ff3df --> 534f6e44_61b8_3c38_8b89_6934a6df9802
  35c4ea20_c454_5afd_6cda_f0818bbcc650["__init__.py"]
  976ab196_f33b_271e_81d9_a463ce9ff3df --> 35c4ea20_c454_5afd_6cda_f0818bbcc650
  a7c04dee_ee23_5891_b185_47ff6bed036d["testclient.py"]
  976ab196_f33b_271e_81d9_a463ce9ff3df --> a7c04dee_ee23_5891_b185_47ff6bed036d
  a7f4e7b0_9725_db90_5cbc_7ca8211b323a["inline_snapshot"]
  976ab196_f33b_271e_81d9_a463ce9ff3df --> a7f4e7b0_9725_db90_5cbc_7ca8211b323a
  6913fbd4_39df_d14b_44bb_522e99b65b90["pydantic"]
  976ab196_f33b_271e_81d9_a463ce9ff3df --> 6913fbd4_39df_d14b_44bb_522e99b65b90
  style 976ab196_f33b_271e_81d9_a463ce9ff3df fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

from fastapi import Depends, FastAPI, Security
from fastapi.security import APIKeyQuery
from fastapi.testclient import TestClient
from inline_snapshot import snapshot
from pydantic import BaseModel

app = FastAPI()

api_key = APIKeyQuery(name="key", description="API Key Query")


class User(BaseModel):
    username: str


def get_current_user(oauth_header: str = Security(api_key)):
    user = User(username=oauth_header)
    return user


@app.get("/users/me")
def read_current_user(current_user: User = Depends(get_current_user)):
    return current_user


client = TestClient(app)


def test_security_api_key():
    response = client.get("/users/me?key=secret")
    assert response.status_code == 200, response.text
    assert response.json() == {"username": "secret"}


def test_security_api_key_no_key():
    response = client.get("/users/me")
    assert response.status_code == 401, response.text
    assert response.json() == {"detail": "Not authenticated"}
    assert response.headers["WWW-Authenticate"] == "APIKey"


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": {
                "/users/me": {
                    "get": {
                        "responses": {
                            "200": {
                                "description": "Successful Response",
                                "content": {"application/json": {"schema": {}}},
                            }
                        },
                        "summary": "Read Current User",
                        "operationId": "read_current_user_users_me_get",
                        "security": [{"APIKeyQuery": []}],
                    }
                }
            },
            "components": {
                "securitySchemes": {
                    "APIKeyQuery": {
                        "type": "apiKey",
                        "name": "key",
                        "in": "query",
                        "description": "API Key Query",
                    }
                }
            },
        }
    )

Domain

Subdomains

Classes

Dependencies

Frequently Asked Questions

What does test_security_api_key_query_description.py do?
test_security_api_key_query_description.py is a source file in the fastapi codebase, written in python. It belongs to the FastAPI domain, Applications subdomain.
What functions are defined in test_security_api_key_query_description.py?
test_security_api_key_query_description.py defines 5 function(s): get_current_user, read_current_user, test_openapi_schema, test_security_api_key, test_security_api_key_no_key.
What does test_security_api_key_query_description.py depend on?
test_security_api_key_query_description.py imports 5 module(s): __init__.py, __init__.py, inline_snapshot, pydantic, testclient.py.
Where is test_security_api_key_query_description.py in the architecture?
test_security_api_key_query_description.py is located at tests/test_security_api_key_query_description.py (domain: FastAPI, subdomain: Applications, directory: tests).

Analyze Your Own Codebase

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

Try Supermodel Free