From 6dae86f5ad99a730839565ff88e823ab2b454d24 Mon Sep 17 00:00:00 2001 From: Darren Burns Date: Wed, 27 Sep 2023 14:04:15 +0100 Subject: [PATCH] Test TextArea terminal cursor position update --- tests/text_area/test_selection.py | 28 ++++++++++++++++++++++--- tests/text_area/test_text_area_theme.py | 0 2 files changed, 25 insertions(+), 3 deletions(-) delete mode 100644 tests/text_area/test_text_area_theme.py diff --git a/tests/text_area/test_selection.py b/tests/text_area/test_selection.py index d089aecc0f..dc983f7a15 100644 --- a/tests/text_area/test_selection.py +++ b/tests/text_area/test_selection.py @@ -18,10 +18,12 @@ def compose(self) -> ComposeResult: yield text_area -def test_default_selection(): +async def test_default_selection(): """The cursor starts at (0, 0) in the document.""" - text_area = TextArea() - assert text_area.selection == Selection.cursor((0, 0)) + app = TextAreaApp() + async with app.run_test(): + text_area = app.query_one(TextArea) + assert text_area.selection == Selection.cursor((0, 0)) async def test_cursor_location_get(): @@ -294,3 +296,23 @@ async def test_select_line(index, content, expected_selection): text_area.select_line(index) assert text_area.selection == expected_selection + + +async def test_cursor_screen_offset_and_terminal_cursor_position_update(): + class TextAreaCursorScreenOffset(App): + def compose(self) -> ComposeResult: + yield TextArea("abc\ndef") + + app = TextAreaCursorScreenOffset() + async with app.run_test(): + text_area = app.query_one(TextArea) + + assert app.cursor_position == (3, 0) + + text_area.cursor_location = (1, 1) + + assert text_area.cursor_screen_offset == (4, 1) + + # Also ensure that this update has been reported back to the app + # for the benefit of IME/emoji popups. + assert app.cursor_position == (4, 1) diff --git a/tests/text_area/test_text_area_theme.py b/tests/text_area/test_text_area_theme.py deleted file mode 100644 index e69de29bb2..0000000000