test_element.py 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. from nicegui import ui
  2. from selenium.webdriver.common.action_chains import ActionChains
  3. from selenium.webdriver.common.keys import Keys
  4. from .user import User
  5. def test_keyboard(user: User):
  6. result = ui.label('')
  7. ui.keyboard(on_key=lambda e: result.set_text(f'{e.key, e.action}'))
  8. user.open('/')
  9. assert any(s.endswith('keyboard.js') for s in user.get_attributes('script', 'src'))
  10. assert user.selenium.find_element_by_tag_name('span') # NOTE keyboard dom element is a span
  11. ActionChains(user.selenium).send_keys('t').perform()
  12. user.should_see('t, KeyboardAction(keydown=False, keyup=True, repeat=False)')
  13. def test_classes(user: User):
  14. label = ui.label('Some label')
  15. def assert_classes(classes: str) -> None:
  16. assert user.selenium.find_element_by_xpath(f'//*[normalize-space(@class)="{classes}" and text()="Some label"]')
  17. user.open('/')
  18. assert_classes('')
  19. label.classes('one')
  20. assert_classes('one')
  21. label.classes('one')
  22. assert_classes('one')
  23. label.classes('two three')
  24. assert_classes('one two three')
  25. label.classes(remove='two')
  26. assert_classes('one three')
  27. label.classes(replace='four')
  28. assert_classes('four')
  29. def test_style(user: User):
  30. label = ui.label('Some label')
  31. def assert_style(style: str) -> None:
  32. assert user.selenium.find_element_by_xpath(f'//*[normalize-space(@style)="{style}" and text()="Some label"]')
  33. user.open('/')
  34. assert_style('')
  35. label.style('color: red')
  36. assert_style('color: red;')
  37. label.style('color: red')
  38. assert_style('color: red;')
  39. label.style('color: blue')
  40. assert_style('color: blue;')
  41. label.style('font-weight: bold')
  42. assert_style('color: blue; font-weight: bold;')
  43. label.style(remove='color: blue')
  44. assert_style('font-weight: bold;')
  45. label.style(replace='text-decoration: underline')
  46. assert_style('text-decoration: underline;')
  47. def test_props(user: User):
  48. input = ui.input()
  49. def assert_props(*props: str) -> None:
  50. class_conditions = [f'contains(@class, "q-field--{prop}")' for prop in props]
  51. assert user.selenium.find_element_by_xpath(f'//label[{" and ".join(class_conditions)}]')
  52. user.open('/')
  53. assert_props('standard', 'labeled')
  54. input.props('dark')
  55. assert_props('standard', 'labeled', 'dark')
  56. input.props('dark')
  57. assert_props('standard', 'labeled', 'dark')
  58. input.props(remove='dark')
  59. assert_props('standard', 'labeled')