Coverage for tests / test_tutorial / test_security / test_tutorial002.py: 100%

23 statements  

« prev     ^ index     » next       coverage.py v7.13.3, created at 2026-02-12 18:15 +0000

1import importlib 1abdc

2 

3import pytest 1abdc

4from fastapi.testclient import TestClient 1abdc

5from inline_snapshot import snapshot 1abdc

6 

7from ...utils import needs_py310 1abdc

8 

9 

10@pytest.fixture( 1abdc

11 name="client", 

12 params=[ 

13 pytest.param("tutorial002_py310", marks=needs_py310), 

14 pytest.param("tutorial002_an_py310", marks=needs_py310), 

15 ], 

16) 

17def get_client(request: pytest.FixtureRequest): 1abdc

18 mod = importlib.import_module(f"docs_src.security.{request.param}") 1abc

19 client = TestClient(mod.app) 1abc

20 return client 1abc

21 

22 

23def test_no_token(client: TestClient): 1abdc

24 response = client.get("/users/me") 1efg

25 assert response.status_code == 401, response.text 1efg

26 assert response.json() == {"detail": "Not authenticated"} 1efg

27 assert response.headers["WWW-Authenticate"] == "Bearer" 1efg

28 

29 

30def test_token(client: TestClient): 1abdc

31 response = client.get("/users/me", headers={"Authorization": "Bearer testtoken"}) 1hij

32 assert response.status_code == 200, response.text 1hij

33 assert response.json() == { 1hij

34 "username": "testtokenfakedecoded", 

35 "email": "john@example.com", 

36 "full_name": "John Doe", 

37 "disabled": None, 

38 } 

39 

40 

41def test_openapi_schema(client: TestClient): 1abdc

42 response = client.get("/openapi.json") 1klm

43 assert response.status_code == 200, response.text 1klm

44 assert response.json() == snapshot( 1klm

45 { 

46 "openapi": "3.1.0", 

47 "info": {"title": "FastAPI", "version": "0.1.0"}, 

48 "paths": { 

49 "/users/me": { 

50 "get": { 

51 "responses": { 

52 "200": { 

53 "description": "Successful Response", 

54 "content": {"application/json": {"schema": {}}}, 

55 } 

56 }, 

57 "summary": "Read Users Me", 

58 "operationId": "read_users_me_users_me_get", 

59 "security": [{"OAuth2PasswordBearer": []}], 

60 } 

61 } 

62 }, 

63 "components": { 

64 "securitySchemes": { 

65 "OAuth2PasswordBearer": { 

66 "type": "oauth2", 

67 "flows": {"password": {"scopes": {}, "tokenUrl": "token"}}, 

68 } 

69 }, 

70 }, 

71 } 

72 )