2022-06-30 20:45:15 +00:00
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
from unittest import mock
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
from click.testing import CliRunner
|
|
|
|
from tests_app import _PROJECT_ROOT
|
|
|
|
|
|
|
|
from lightning_app import LightningApp
|
|
|
|
from lightning_app.cli.lightning_cli import run_app
|
2022-10-28 13:57:35 +00:00
|
|
|
from lightning_app.testing.helpers import _RunIf
|
2022-06-30 20:45:15 +00:00
|
|
|
from lightning_app.testing.testing import run_app_in_cloud, wait_for
|
|
|
|
|
|
|
|
|
|
|
|
class QuickStartApp(LightningApp):
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super().__init__(*args, **kwargs)
|
|
|
|
self.root.serve_work._parallel = True
|
|
|
|
|
|
|
|
def run_once(self):
|
|
|
|
done = super().run_once()
|
|
|
|
if self.root.train_work.best_model_path:
|
|
|
|
return True
|
|
|
|
return done
|
|
|
|
|
|
|
|
|
2022-07-17 18:19:01 +00:00
|
|
|
# TODO: Investigate why it doesn't work
|
2022-07-02 05:05:16 +00:00
|
|
|
@pytest.mark.skipif(True, reason="test is skipped because CI was blocking all the PRs.")
|
2022-10-28 13:57:35 +00:00
|
|
|
@_RunIf(pl=True, skip_windows=True, skip_linux=True)
|
2022-06-30 20:45:15 +00:00
|
|
|
def test_quick_start_example(caplog, monkeypatch):
|
|
|
|
"""This test ensures the Quick Start example properly train and serve PyTorch Lightning."""
|
|
|
|
|
|
|
|
monkeypatch.setattr("logging.getLogger", mock.MagicMock(return_value=logging.getLogger()))
|
|
|
|
|
|
|
|
with caplog.at_level(logging.INFO):
|
|
|
|
with mock.patch("lightning_app.LightningApp", QuickStartApp):
|
|
|
|
runner = CliRunner()
|
|
|
|
result = runner.invoke(
|
|
|
|
run_app,
|
|
|
|
[
|
|
|
|
os.path.join(_PROJECT_ROOT, "lightning-quick-start/app.py"),
|
|
|
|
"--blocking",
|
|
|
|
"False",
|
|
|
|
"--open-ui",
|
|
|
|
"False",
|
|
|
|
],
|
|
|
|
catch_exceptions=False,
|
|
|
|
)
|
|
|
|
assert result.exit_code == 0
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.cloud
|
|
|
|
def test_quick_start_example_cloud() -> None:
|
2022-11-08 16:47:38 +00:00
|
|
|
with run_app_in_cloud(os.path.join(_PROJECT_ROOT, "examples", "lightning-quick-start/")) as (_, view_page, _, _):
|
2022-06-30 20:45:15 +00:00
|
|
|
|
|
|
|
def click_gradio_demo(*_, **__):
|
|
|
|
button = view_page.locator('button:has-text("Interactive demo")')
|
2022-09-27 07:16:46 +00:00
|
|
|
button.wait_for(timeout=5 * 1000)
|
2022-06-30 20:45:15 +00:00
|
|
|
button.click()
|
|
|
|
return True
|
|
|
|
|
|
|
|
wait_for(view_page, click_gradio_demo)
|
|
|
|
|
|
|
|
def check_examples(*_, **__):
|
|
|
|
locator = view_page.frame_locator("iframe").locator('button:has-text("Submit")')
|
|
|
|
locator.wait_for(timeout=10 * 1000)
|
|
|
|
if len(locator.all_text_contents()) > 0:
|
|
|
|
return True
|
|
|
|
|
|
|
|
wait_for(view_page, check_examples)
|