from pathlib import Path import pytest # These paths should be relative to THIS directory. WIDGET_EXAMPLES_DIR = Path("../../docs/examples/widgets") LAYOUT_EXAMPLES_DIR = Path("../../docs/examples/guide/layout") STYLES_EXAMPLES_DIR = Path("../../docs/examples/styles") SNAPSHOT_APPS_DIR = Path("./snapshot_apps") # --- Layout related stuff --- def test_grid_layout_basic(snap_compare): assert snap_compare(LAYOUT_EXAMPLES_DIR / "grid_layout1.py") def test_grid_layout_basic_overflow(snap_compare): assert snap_compare(LAYOUT_EXAMPLES_DIR / "grid_layout2.py") def test_grid_layout_gutter(snap_compare): assert snap_compare(LAYOUT_EXAMPLES_DIR / "grid_layout7_gutter.py") def test_layers(snap_compare): assert snap_compare(LAYOUT_EXAMPLES_DIR / "layers.py") def test_horizontal_layout(snap_compare): assert snap_compare(LAYOUT_EXAMPLES_DIR / "horizontal_layout.py") def test_horizontal_layout_width_auto_dock(snap_compare): assert snap_compare(SNAPSHOT_APPS_DIR / "horizontal_auto_width.py") def test_vertical_layout(snap_compare): assert snap_compare(LAYOUT_EXAMPLES_DIR / "vertical_layout.py") def test_dock_layout_sidebar(snap_compare): assert snap_compare(LAYOUT_EXAMPLES_DIR / "dock_layout2_sidebar.py") # --- Widgets - rendering and basic interactions --- # Each widget should have a canonical example that is display in the docs. # When adding a new widget, ideally we should also create a snapshot test # from these examples which test rendering and simple interactions with it. def test_checkboxes(snap_compare): """Tests checkboxes but also acts a regression test for using width: auto in a Horizontal layout context.""" press = [ "shift+tab", "enter", # toggle off "shift+tab", "wait:20", "enter", # toggle on "wait:20", ] assert snap_compare(WIDGET_EXAMPLES_DIR / "checkbox.py", press=press) def test_input_and_focus(snap_compare): press = [ "tab", *"Darren", # Focus first input, write "Darren" "tab", *"Burns", # Tab focus to second input, write "Burns" ] assert snap_compare(WIDGET_EXAMPLES_DIR / "input.py", press=press) def test_buttons_render(snap_compare): # Testing button rendering. We press tab to focus the first button too. assert snap_compare(WIDGET_EXAMPLES_DIR / "button.py", press=["tab"]) def test_datatable_render(snap_compare): press = ["tab", "down", "down", "right", "up", "left"] assert snap_compare(WIDGET_EXAMPLES_DIR / "data_table.py", press=press) def test_footer_render(snap_compare): assert snap_compare(WIDGET_EXAMPLES_DIR / "footer.py") def test_header_render(snap_compare): assert snap_compare(WIDGET_EXAMPLES_DIR / "header.py") def test_textlog_max_lines(snap_compare): assert snap_compare("snapshot_apps/textlog_max_lines.py", press=[*"abcde", "_"]) def test_fr_units(snap_compare): assert snap_compare("snapshot_apps/fr_units.py") # --- CSS properties --- # We have a canonical example for each CSS property that is shown in their docs. # If any of these change, something has likely broken, so snapshot each of them. PATHS = [ path.name for path in (Path(__file__).parent / STYLES_EXAMPLES_DIR).iterdir() if path.suffix == ".py" ] @pytest.mark.parametrize("file_name", PATHS) def test_css_property(file_name, snap_compare): path_to_app = STYLES_EXAMPLES_DIR / file_name assert snap_compare(path_to_app) def test_multiple_css(snap_compare): # Interaction between multiple CSS files and app-level/classvar CSS assert snap_compare("snapshot_apps/multiple_css/multiple_css.py")