From 1ce67887b942cb87e3914f70e7407784be139a1e Mon Sep 17 00:00:00 2001 From: sm-Fifteen <516999+sm-Fifteen@users.noreply.github.com> Date: Sat, 29 Feb 2020 11:28:30 -0500 Subject: [PATCH] :recycle: Refactor function calling a path operation function to simplify profiling (#1027) --- fastapi/routing.py | 22 +++++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) diff --git a/fastapi/routing.py b/fastapi/routing.py index 7c626af41..05919be66 100644 --- a/fastapi/routing.py +++ b/fastapi/routing.py @@ -87,6 +87,19 @@ async def serialize_response( return jsonable_encoder(response) +async def run_endpoint_function( + *, dependant: Dependant, values: Dict[str, Any], is_coroutine: bool +) -> Any: + # Only called by get_request_handler. Has been split into its own function to + # facilitate profiling endpoints, since inner functions are harder to profile. + assert dependant.call is not None, "dependant.call must be a function" + + if is_coroutine: + return await dependant.call(**values) + else: + return await run_in_threadpool(dependant.call, **values) + + def get_request_handler( dependant: Dependant, body_field: ModelField = None, @@ -128,11 +141,10 @@ def get_request_handler( if errors: raise RequestValidationError(errors, body=body) else: - assert dependant.call is not None, "dependant.call must be a function" - if is_coroutine: - raw_response = await dependant.call(**values) - else: - raw_response = await run_in_threadpool(dependant.call, **values) + raw_response = await run_endpoint_function( + dependant=dependant, values=values, is_coroutine=is_coroutine + ) + if isinstance(raw_response, Response): if raw_response.background is None: raw_response.background = background_tasks