Fix detection of whether app is running in cloud (#16045)

This commit is contained in:
Adrian Wälchli 2022-12-19 01:39:21 +01:00 committed by GitHub
parent 22b254f491
commit e54f4f58be
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 23 additions and 10 deletions

View File

@ -21,7 +21,8 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/).
### Changed ### Changed
-
- The utility `lightning.app.utilities.cloud.is_running_in_cloud` now returns `True` during loading of the app locally when running with `--cloud` ([#16045](https://github.com/Lightning-AI/lightning/pull/16045))
### Deprecated ### Deprecated

View File

@ -1,5 +1,6 @@
import fnmatch import fnmatch
import json import json
import os
import random import random
import re import re
import string import string
@ -589,6 +590,10 @@ class CloudRuntime(Runtime):
@classmethod @classmethod
def load_app_from_file(cls, filepath: str) -> "LightningApp": def load_app_from_file(cls, filepath: str) -> "LightningApp":
"""Load a LightningApp from a file, mocking the imports.""" """Load a LightningApp from a file, mocking the imports."""
# Pretend we are running in the cloud when loading the app locally
os.environ["LAI_RUNNING_IN_CLOUD"] = "1"
try: try:
app = load_app_from_file(filepath, raise_exception=True, mock_imports=True) app = load_app_from_file(filepath, raise_exception=True, mock_imports=True)
except FileNotFoundError as e: except FileNotFoundError as e:
@ -599,6 +604,8 @@ class CloudRuntime(Runtime):
# Create a generic app. # Create a generic app.
logger.info("Could not load the app locally. Starting the app directly on the cloud.") logger.info("Could not load the app locally. Starting the app directly on the cloud.")
app = LightningApp(EmptyFlow()) app = LightningApp(EmptyFlow())
finally:
del os.environ["LAI_RUNNING_IN_CLOUD"]
return app return app
@staticmethod @staticmethod

View File

@ -39,4 +39,4 @@ def _sigterm_flow_handler(*_, app: "lightning_app.LightningApp"):
def is_running_in_cloud() -> bool: def is_running_in_cloud() -> bool:
"""Returns True if the Lightning App is running in the cloud.""" """Returns True if the Lightning App is running in the cloud."""
return "LIGHTNING_APP_STATE_URL" in os.environ return bool(int(os.environ.get("LAI_RUNNING_IN_CLOUD", "0"))) or "LIGHTNING_APP_STATE_URL" in os.environ

View File

@ -4,13 +4,18 @@ from unittest import mock
from lightning_app.utilities.cloud import is_running_in_cloud from lightning_app.utilities.cloud import is_running_in_cloud
@mock.patch.dict(os.environ, clear=True)
def test_is_running_locally():
"""We can determine if Lightning is running locally."""
assert not is_running_in_cloud()
@mock.patch.dict(os.environ, {"LIGHTNING_APP_STATE_URL": "127.0.0.1"})
def test_is_running_cloud(): def test_is_running_cloud():
"""We can determine if Lightning is running in the cloud.""" """We can determine if Lightning is running in the cloud."""
assert is_running_in_cloud() with mock.patch.dict(os.environ, {}, clear=True):
assert not is_running_in_cloud()
with mock.patch.dict(os.environ, {"LAI_RUNNING_IN_CLOUD": "0"}, clear=True):
assert not is_running_in_cloud()
# in the cloud, LIGHTNING_APP_STATE_URL is defined
with mock.patch.dict(os.environ, {"LIGHTNING_APP_STATE_URL": "defined"}, clear=True):
assert is_running_in_cloud()
# LAI_RUNNING_IN_CLOUD is used to fake the value of `is_running_in_cloud` when loading the app for --cloud
with mock.patch.dict(os.environ, {"LAI_RUNNING_IN_CLOUD": "1"}):
assert is_running_in_cloud()