test_element.py 2.6 KB

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