From 4bdc1858fabcb777ccdbb0cda2decbcb291a39b3 Mon Sep 17 00:00:00 2001 From: Sherin Thomas Date: Sat, 10 Dec 2022 00:33:50 +0530 Subject: [PATCH] [App] Fix import errors for the packages installed by shebang (#15996) * import fix * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * import fix * move req * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * Update requirements/app/base.txt * revert * skip doctest * import fix Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Jirka --- .../components/serve/python_server.py | 57 ++++++++++--------- 1 file changed, 29 insertions(+), 28 deletions(-) diff --git a/src/lightning_app/components/serve/python_server.py b/src/lightning_app/components/serve/python_server.py index c522a25eb3f3d..e447673993973 100644 --- a/src/lightning_app/components/serve/python_server.py +++ b/src/lightning_app/components/serve/python_server.py @@ -7,7 +7,7 @@ import uvicorn from fastapi import FastAPI -from lightning_utilities.core.imports import compare_version, module_available +from lightning_utilities.core.imports import compare_version from pydantic import BaseModel from lightning_app.core.work import LightningWork @@ -16,10 +16,8 @@ logger = Logger(__name__) -__doctest_skip__ = [] -# Skip doctests if requirements aren't available -if not module_available("lightning_api_access"): - __doctest_skip__ += ["PythonServer", "PythonServer.*"] +__doctest_skip__ = ["PythonServer", "PythonServer.*"] + # Skip doctests if requirements aren't available if not _is_torch_available(): @@ -72,7 +70,7 @@ class PythonServer(LightningWork, abc.ABC): _start_method = "spawn" - @requires(["torch", "lightning_api_access"]) + @requires(["torch"]) def __init__( # type: ignore self, input_type: type = _DefaultInputData, @@ -193,29 +191,32 @@ def predict_fn(request: input_type): # type: ignore fastapi_app.post("/predict", response_model=output_type)(predict_fn) def configure_layout(self) -> None: - if module_available("lightning_api_access"): + try: from lightning_api_access import APIAccessFrontend - - class_name = self.__class__.__name__ - url = f"{self.url}/predict" - - try: - request = self._get_sample_dict_from_datatype(self.configure_input_type()) - response = self._get_sample_dict_from_datatype(self.configure_output_type()) - except TypeError: - return None - - return APIAccessFrontend( - apis=[ - { - "name": class_name, - "url": url, - "method": "POST", - "request": request, - "response": response, - } - ] - ) + except ModuleNotFoundError: + logger.warn("APIAccessFrontend not found. Please install lightning-api-access to enable the UI") + return + + class_name = self.__class__.__name__ + url = f"{self.url}/predict" + + try: + request = self._get_sample_dict_from_datatype(self.configure_input_type()) + response = self._get_sample_dict_from_datatype(self.configure_output_type()) + except TypeError: + return None + + return APIAccessFrontend( + apis=[ + { + "name": class_name, + "url": url, + "method": "POST", + "request": request, + "response": response, + } + ] + ) def run(self, *args: Any, **kwargs: Any) -> Any: """Run method takes care of configuring and setting up a FastAPI server behind the scenes.