123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- """Integration tests for table and related components."""
- from typing import Generator
- import pytest
- from playwright.sync_api import Page
- from reflex.testing import AppHarness
- expected_col_headers = ["Name", "Age", "Location"]
- expected_row_headers = ["John", "Jane", "Joe"]
- expected_cells_data = [
- ["30", "New York"],
- ["31", "San Fransisco"],
- ["32", "Los Angeles"],
- ]
- def Table():
- """App using table component."""
- import reflex as rx
- app = rx.App(state=rx.State)
- @app.add_page
- def index():
- return rx.center(
- rx.table.root(
- rx.table.header(
- rx.table.row(
- rx.table.column_header_cell("Name"),
- rx.table.column_header_cell("Age"),
- rx.table.column_header_cell("Location"),
- ),
- ),
- rx.table.body(
- rx.table.row(
- rx.table.row_header_cell("John"),
- rx.table.cell(30),
- rx.table.cell("New York"),
- ),
- rx.table.row(
- rx.table.row_header_cell("Jane"),
- rx.table.cell(31),
- rx.table.cell("San Fransisco"),
- ),
- rx.table.row(
- rx.table.row_header_cell("Joe"),
- rx.table.cell(32),
- rx.table.cell("Los Angeles"),
- ),
- ),
- width="100%",
- ),
- )
- @pytest.fixture()
- def table_app(tmp_path_factory) -> Generator[AppHarness, None, None]:
- """Start Table app at tmp_path via AppHarness.
- Args:
- tmp_path_factory: pytest tmp_path_factory fixture
- Yields:
- running AppHarness instance
- """
- with AppHarness.create(
- root=tmp_path_factory.mktemp("table"),
- app_source=Table,
- ) as harness:
- assert harness.app_instance is not None, "app is not running"
- yield harness
- def test_table(page: Page, table_app: AppHarness):
- """Test that a table component is rendered properly.
- Args:
- table_app: Harness for Table app
- page: Playwright page instance
- """
- assert table_app.frontend_url is not None, "frontend url is not available"
- page.goto(table_app.frontend_url)
- table = page.get_by_role("table")
- # Check column headers
- headers = table.get_by_role("columnheader").all_inner_texts()
- assert headers == expected_col_headers
- # Check rows headers
- rows = table.get_by_role("rowheader").all_inner_texts()
- assert rows == expected_row_headers
- # Check cells
- rows = table.get_by_role("cell").all_inner_texts()
- for i, expected_row in enumerate(expected_cells_data):
- assert [rows[idx := i * 2], rows[idx + 1]] == expected_row
|