1
0

test_element_filter.py 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. from typing import List
  2. import pytest
  3. from nicegui import ElementFilter, ui
  4. from nicegui.elements.mixins.text_element import TextElement
  5. from nicegui.testing import User
  6. pytestmark = pytest.mark.usefixtures('user')
  7. # pylint: disable=missing-function-docstring
  8. def texts(element_filter: ElementFilter) -> List[str]:
  9. return [element.text for element in element_filter]
  10. def test_find_all() -> None:
  11. ui.button('button A')
  12. ui.label('label A')
  13. with ui.row():
  14. ui.button('button B')
  15. ui.label('label B')
  16. elements: List[ui.element] = list(ElementFilter())
  17. assert len(elements) == 8
  18. assert elements[0].tag == 'q-page-container'
  19. assert elements[1].tag == 'q-page'
  20. assert elements[2].classes == ['nicegui-content']
  21. assert elements[3].text == 'button A' # type: ignore
  22. assert elements[4].text == 'label A' # type: ignore
  23. assert elements[5].__class__ == ui.row
  24. assert elements[6].text == 'button B' # type: ignore
  25. assert elements[7].text == 'label B' # type: ignore
  26. def test_find_kind():
  27. ui.icon('home')
  28. ui.button('button A')
  29. ui.label('label A')
  30. ui.button('button B')
  31. ui.label('label B')
  32. assert texts(ElementFilter(kind=ui.button)) == ['button A', 'button B']
  33. assert texts(ElementFilter(kind=TextElement)) == ['button A', 'label A', 'button B', 'label B']
  34. def test_find_content():
  35. ui.button('button A')
  36. ui.label('label A')
  37. ui.button('button B')
  38. ui.label('label B')
  39. assert texts(ElementFilter(content='A')) == ['button A', 'label A']
  40. assert texts(ElementFilter(content=['A', 'butt'])) == ['button A']
  41. def test_find_radio():
  42. radio_list = ui.radio(['radio 1', 'radio 2'])
  43. radio_dict = ui.radio({'radio 1': 'Radio A', 'radio 2': 'Radio B'})
  44. assert next(iter(ElementFilter(content=['radio 1']))) is radio_list
  45. assert next(iter(ElementFilter(content=['Radio A']))) is radio_dict
  46. def test_find_toggle():
  47. toggle_list = ui.toggle(['toggle 1', 'toggle 2'])
  48. toggle_dict = ui.toggle({'toggle 1': 'Toggle A', 'toggle 2': 'Toggle B'})
  49. assert next(iter(ElementFilter(content=['toggle 1']))) is toggle_list
  50. assert next(iter(ElementFilter(content=['Toggle A']))) is toggle_dict
  51. def test_find_select():
  52. select_list = ui.select(['select 1', 'select 2'])
  53. select_dict = ui.select({'select 1': 'Select A', 'select 2': 'Select B'})
  54. select_list._is_showing_popup = True # pylint: disable=protected-access
  55. select_dict._is_showing_popup = True # pylint: disable=protected-access
  56. assert next(iter(ElementFilter(content=['select 1']))) is select_list
  57. assert next(iter(ElementFilter(content=['Select A']))) is select_dict
  58. def test_find_marker():
  59. ui.button('button A')
  60. ui.button('button B').mark('important')
  61. ui.button('button C').mark('important ', 'foo')
  62. ui.button('button D').mark(' important bar')
  63. assert texts(ElementFilter(marker='important')) == ['button B', 'button C', 'button D']
  64. assert texts(ElementFilter(marker='foo')) == ['button C']
  65. assert texts(ElementFilter(marker='bar important')) == ['button D']
  66. assert texts(ElementFilter(marker='important bar')) == ['button D']
  67. def test_find_within_marker():
  68. ui.button('button A')
  69. ui.label('label A')
  70. with ui.row().mark('horizontal'):
  71. ui.button('button B')
  72. ui.label('label B')
  73. with ui.column().mark('vertical'):
  74. ui.button('button C')
  75. ui.label('label C')
  76. assert texts(ElementFilter(kind=ui.button).within(marker='horizontal')) == ['button B', 'button C']
  77. assert texts(ElementFilter(kind=ui.button).within(marker='horizontal vertical')) == ['button C']
  78. assert texts(ElementFilter(kind=ui.button).not_within(marker='horizontal')) == ['button A']
  79. assert texts(ElementFilter(kind=ui.button).not_within(marker='horizontal vertical')) == ['button A']
  80. def test_find_within_marker2():
  81. with ui.row().mark('a b'):
  82. ui.label('Label 1')
  83. with ui.row().mark('a'):
  84. ui.label('Label 2')
  85. ui.label('Label 3')
  86. assert texts(ElementFilter(kind=ui.label).within(marker='a b')) == ['Label 1']
  87. assert texts(ElementFilter(kind=ui.label).within(marker='b a')) == ['Label 1']
  88. assert texts(ElementFilter(kind=ui.label).within(marker='b')) == ['Label 1']
  89. assert texts(ElementFilter(kind=ui.label).within(marker='a')) == ['Label 1', 'Label 2']
  90. assert texts(ElementFilter(kind=ui.label).not_within(marker='a b')) == ['Label 3']
  91. assert texts(ElementFilter(kind=ui.label).not_within(marker='b a')) == ['Label 3']
  92. assert texts(ElementFilter(kind=ui.label).not_within(marker='b')) == ['Label 2', 'Label 3']
  93. assert texts(ElementFilter(kind=ui.label).not_within(marker='a')) == ['Label 3']
  94. def test_find_within_instance():
  95. ui.button('button A')
  96. ui.label('label A')
  97. with ui.row() as row:
  98. ui.button('button B')
  99. ui.label('label B')
  100. with ui.column() as column1:
  101. ui.button('button C')
  102. ui.label('label C')
  103. with ui.column() as column2:
  104. ui.button('button D')
  105. ui.label('label D')
  106. assert texts(ElementFilter(kind=ui.button).within(instance=row)) == ['button B', 'button C', 'button D']
  107. assert texts(ElementFilter(kind=ui.button).within(instance=[row, column1])) == ['button C']
  108. assert texts(ElementFilter(kind=ui.button).within(instance=[column1, column2])) == []
  109. assert texts(ElementFilter(kind=ui.button).not_within(instance=row)) == ['button A']
  110. def test_find_within_kind():
  111. ui.button('button A')
  112. with ui.row():
  113. ui.label('label A')
  114. ui.button('button B')
  115. ui.label('label B')
  116. with ui.column():
  117. ui.label('label C')
  118. with ui.card():
  119. ui.button('button C')
  120. assert texts(ElementFilter(content='B').within(kind=ui.row)) == ['button B', 'label B']
  121. assert texts(ElementFilter(content='C').within(kind=ui.column)) == ['label C', 'button C']
  122. assert texts(ElementFilter(content='C').within(kind=ui.column).within(kind=ui.card)) == ['button C']
  123. assert texts(ElementFilter(kind=ui.button).not_within(kind=ui.row)) == ['button A', 'button C']
  124. def test_find_exclude_kind():
  125. ui.button('button A')
  126. ui.label('label A')
  127. ui.button('button B')
  128. ui.label('label B')
  129. assert texts(ElementFilter(content='A').exclude(kind=ui.label)) == ['button A']
  130. def test_find_exclude_marker():
  131. ui.button('button A').mark('normal')
  132. ui.label('label A').mark('important')
  133. ui.button('button B')
  134. ui.label('label B').mark('normal')
  135. assert texts(ElementFilter(kind=TextElement).exclude(marker='normal')) == ['label A', 'button B']
  136. def test_find_exclude_content():
  137. ui.button('button A')
  138. ui.label('label A')
  139. ui.button('button B')
  140. ui.label('label B')
  141. assert texts(ElementFilter(kind=ui.button).exclude(content='A')) == ['button B']
  142. def test_find_in_local_scope():
  143. ui.button('button A')
  144. ui.label('label A')
  145. with ui.row():
  146. ui.button('button B')
  147. ui.label('label B')
  148. assert texts(ElementFilter(local_scope=True)) == ['button B', 'label B']
  149. async def test_setting_classes(user: User):
  150. ui.label('label A')
  151. ui.label('label B')
  152. ElementFilter(kind=ui.label).classes('text-2xl')
  153. await user.open('/')
  154. for label in user.find('label').elements:
  155. assert label.classes == ['text-2xl']
  156. async def test_setting_style(user: User):
  157. ui.label('label A')
  158. ui.label('label B')
  159. ElementFilter(kind=ui.label).style('color: red')
  160. await user.open('/')
  161. for label in user.find('label').elements:
  162. assert label.style['color'] == 'red'
  163. async def test_setting_props(user: User):
  164. ui.button('button A')
  165. ui.button('button B')
  166. ElementFilter(kind=ui.button).props('flat')
  167. await user.open('/')
  168. for button in user.find('button').elements:
  169. assert button.props['flat']
  170. async def test_typing(user: User):
  171. ui.button('button A')
  172. ui.label('label A')
  173. await user.open('/')
  174. # NOTE we have not yet found a way to test the typing suggestions automatically
  175. # to test, hover over the variable and verify that your IDE infers the correct type
  176. _ = ElementFilter(kind=ui.button) # ElementFilter[ui.button]
  177. _ = ElementFilter(kind=ui.label) # ElementFilter[ui.label]
  178. _ = ElementFilter() # ElementFilter[Element]