virt-manager/tests/uitests/lib/utils.py
Cole Robinson 2ddbea5d0b uitests: Fix get_text() on fedora40
Seems like some dependent lib started exposing a similarly named
function, so ours stopped working

Signed-off-by: Cole Robinson <crobinso@redhat.com>
2024-08-14 06:17:10 -04:00

118 lines
3.7 KiB
Python

# This work is licensed under the GNU GPLv2 or later.
# See the COPYING file in the top-level directory.
import time
import dogtail.config
def check(func, timeout=2):
"""
Run the passed func in a loop every .1 seconds until timeout is hit or
the func returns True.
"""
start_time = time.time()
interval = 0.1
while True:
if func() is True:
return
if (time.time() - start_time) > timeout:
raise RuntimeError("Loop condition wasn't met")
time.sleep(interval)
class dogtail_timeout:
"""
Context helper to run a specific check with custom timeout, in seconds
"""
def __init__(self, timeout):
backoff = dogtail.config.config.searchBackoffDuration
self._tmpval = int(timeout / backoff)
self._origval = dogtail.config.config.searchCutoffCount
def _set(self, val):
dogtail.config.config.searchCutoffCount = val
def __enter__(self):
self._set(self._tmpval)
return self
def __exit__(self, exc_type, exc_val, exc_tb):
self._set(self._origval)
def walkUIList(app, win, lst, error_cb, reverse=False):
"""
Toggle down through a UI list like addhardware, net/storage/iface
lists, and ensure an error isn't raised.
"""
# Walk the lst UI and find all labelled table cells, these are
# the actual list entries
all_cells = lst.findChildren(lambda w: w.roleName == "table cell")
if reverse:
all_cells.reverse()
all_cells[0].point()
all_cells[0].click()
cells_per_selection = len([c for c in all_cells if c.focused])
idx = 0
while idx < len(all_cells):
cell = all_cells[idx]
if not cell.state_selected:
# Could be a separator table cell. Try to figure it out
if not any([c.name for c in
all_cells[idx:(idx + cells_per_selection)]]):
idx += cells_per_selection
continue
check(lambda: cell.state_selected)
app.rawinput.pressKey(reverse and "Up" or "Down")
if not win.active:
# Should mean an error dialog popped up
app.root.find("Error", "alert")
raise AssertionError("Error dialog raised?")
if error_cb():
raise AssertionError("Error found on a page")
idx += cells_per_selection
if idx >= len(all_cells):
# Last cell, selection shouldn't have changed
check(lambda: cell.state_selected)
else:
check(lambda: not cell.state_selected)
def test_xmleditor_interactions(app, win, finish):
"""
Helper to test some common XML editor interactions
"""
# Click the tab, make a bogus XML edit
win.find("XML", "page tab").click()
xmleditor = win.find("XML editor")
xmleditor.set_text(xmleditor.text.replace("<", "<FOO", 1))
# Trying to click away should warn that there's unapplied changes
win.find("Details", "page tab").click()
# Select 'No', meaning don't abandon changes
app.click_alert_button("changes will be lost", "No")
check(lambda: xmleditor.showing)
# Click the finish button, but our bogus change should trigger error
finish.click()
app.click_alert_button("(xmlParseDoc|tag.mismatch)", "Close")
# Try unapplied changes again, this time abandon our changes
win.find("Details", "page tab").click()
app.click_alert_button("changes will be lost", "Yes")
check(lambda: not xmleditor.showing)
def get_xmleditor_xml(_app, win):
win.find("XML", "page tab").click()
xmleditor = win.find("XML editor")
xml = xmleditor.get_text_override()
win.find("Details", "page tab").click()
check(lambda: not xmleditor.showing)
return xml