Coverage for docs_src/custom_request_and_route/tutorial003.py: 100%

26 statements  

« prev     ^ index     » next       coverage.py v7.6.1, created at 2025-12-04 08:29 +0000

1import time 1abcdefg

2from typing import Callable 1abcdefg

3 

4from fastapi import APIRouter, FastAPI, Request, Response 1abcdefg

5from fastapi.routing import APIRoute 1abcdefg

6 

7 

8class TimedRoute(APIRoute): 1abcdefg

9 def get_route_handler(self) -> Callable: 1abcdefg

10 original_route_handler = super().get_route_handler() 1abcdefg

11 

12 async def custom_route_handler(request: Request) -> Response: 1abcdefg

13 before = time.time() 1hijklmn

14 response: Response = await original_route_handler(request) 1hijklmn

15 duration = time.time() - before 1hijklmn

16 response.headers["X-Response-Time"] = str(duration) 1hijklmn

17 print(f"route duration: {duration}") 1hijklmn

18 print(f"route response: {response}") 1hijklmn

19 print(f"route response headers: {response.headers}") 1hijklmn

20 return response 1hijklmn

21 

22 return custom_route_handler 1abcdefg

23 

24 

25app = FastAPI() 1abcdefg

26router = APIRouter(route_class=TimedRoute) 1abcdefg

27 

28 

29@app.get("/") 1abcdefg

30async def not_timed(): 1abcdefg

31 return {"message": "Not timed"} 1opqrstu

32 

33 

34@router.get("/timed") 1abcdefg

35async def timed(): 1abcdefg

36 return {"message": "It's the time of my life"} 1hijklmn

37 

38 

39app.include_router(router) 1abcdefg