1
from typing import Optional
3
from fastapi import Depends, FastAPI, Security
4
from fastapi.security import APIKeyCookie
5
from fastapi.testclient import TestClient
6
from pydantic import BaseModel
10
api_key = APIKeyCookie(name="key", auto_error=False)
17
def get_current_user(oauth_header: Optional[str] = Security(api_key)):
18
if oauth_header is None:
20
user = User(username=oauth_header)
25
def read_current_user(current_user: User = Depends(get_current_user)):
26
if current_user is None:
27
return {"msg": "Create an account first"}
32
def test_security_api_key():
33
client = TestClient(app, cookies={"key": "secret"})
34
response = client.get("/users/me")
35
assert response.status_code == 200, response.text
36
assert response.json() == {"username": "secret"}
39
def test_security_api_key_no_key():
40
client = TestClient(app)
41
response = client.get("/users/me")
42
assert response.status_code == 200, response.text
43
assert response.json() == {"msg": "Create an account first"}
46
def test_openapi_schema():
47
client = TestClient(app)
48
response = client.get("/openapi.json")
49
assert response.status_code == 200, response.text
50
assert response.json() == {
52
"info": {"title": "FastAPI", "version": "0.1.0"},
58
"description": "Successful Response",
59
"content": {"application/json": {"schema": {}}},
62
"summary": "Read Current User",
63
"operationId": "read_current_user_users_me_get",
64
"security": [{"APIKeyCookie": []}],
70
"APIKeyCookie": {"type": "apiKey", "name": "key", "in": "cookie"}