test_query.py 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. from typing import List
  2. from nicegui import ui
  3. from nicegui.testing import Screen
  4. def test_query_body(screen: Screen):
  5. ui.label('Hello')
  6. ui.query('body').classes('bg-orange-100')
  7. ui.button('Red background', on_click=lambda: ui.query('body').classes(replace='bg-red-100'))
  8. ui.button('Blue background', on_click=lambda: ui.query('body').classes(replace='bg-blue-100'))
  9. ui.button('Small padding', on_click=lambda: ui.query('body').style('padding: 1px'))
  10. ui.button('Large padding', on_click=lambda: ui.query('body').style('padding: 10px'))
  11. ui.button('Data X = 1', on_click=lambda: ui.query('body').props('data-x=1'))
  12. ui.button('Data X = 2', on_click=lambda: ui.query('body').props('data-x=2'))
  13. def get_bg_classes() -> List[str]:
  14. return [c for c in (screen.find_by_tag('body').get_attribute('class') or '').split() if c.startswith('bg-')]
  15. screen.open('/')
  16. screen.should_contain('Hello')
  17. assert get_bg_classes() == ['bg-orange-100']
  18. screen.click('Red background')
  19. screen.wait(0.5)
  20. assert get_bg_classes() == ['bg-red-100']
  21. screen.click('Blue background')
  22. screen.wait(0.5)
  23. assert get_bg_classes() == ['bg-blue-100']
  24. screen.click('Small padding')
  25. screen.wait(0.5)
  26. assert screen.find_by_tag('body').value_of_css_property('padding') == '1px'
  27. screen.click('Large padding')
  28. screen.wait(0.5)
  29. assert screen.find_by_tag('body').value_of_css_property('padding') == '10px'
  30. screen.click('Data X = 1')
  31. screen.wait(0.5)
  32. assert screen.find_by_tag('body').get_attribute('data-x') == '1'
  33. screen.click('Data X = 2')
  34. screen.wait(0.5)
  35. assert screen.find_by_tag('body').get_attribute('data-x') == '2'
  36. def test_query_multiple_divs(screen: Screen):
  37. ui.label('A')
  38. ui.label('B')
  39. ui.button('Add border', on_click=lambda: ui.query('div').style('border: 1px solid black'))
  40. screen.open('/')
  41. screen.click('Add border')
  42. screen.wait(0.5)
  43. assert screen.find('A').value_of_css_property('border') == '1px solid rgb(0, 0, 0)'
  44. assert screen.find('B').value_of_css_property('border') == '1px solid rgb(0, 0, 0)'
  45. def test_query_with_css_variables(screen: Screen):
  46. ui.add_body_html('<div id="element">Test</div>')
  47. ui.query('#element').style('--color: red; color: var(--color)')
  48. screen.open('/')
  49. assert screen.find('Test').value_of_css_property('color') == 'rgba(255, 0, 0, 1)'