virt-manager/tests/uitests/test_manager.py
Cole Robinson 8ce83dbc53 uitests: big mess of work
* Convert to pytest style functions
* Move lots of shared code to our App class
* Reduce dogtail sleep amounts to speed up the whole testsuite
* Improve robustness in a lot of areas

Signed-off-by: Cole Robinson <crobinso@redhat.com>
2020-09-19 17:10:19 -04:00

336 lines
9.8 KiB
Python

# This work is licensed under the GNU GPLv2 or later.
# See the COPYING file in the top-level directory.
import tests.utils
from . import lib
#############################################################
# UI tests for manager window, and basic VM lifecycle stuff #
#############################################################
def _testVMLifecycle(app):
"""
Basic VM lifecycle test, shared between standard and no-events
testing
"""
manager = app.topwin
shutdown = manager.find("Shut Down", "push button")
pause = manager.find("Pause", "toggle button")
run = manager.find("Run", "push button")
force = manager.find("Force Off", "menu item")
smenu = manager.find("Menu", "toggle button")
save = manager.find("Save", "menu item")
c = manager.find("test-many-devices", "table cell")
c.click()
smenu.click()
force.click()
app.click_alert_button("Are you sure you want", "Yes")
lib.utils.check(lambda: run.sensitive, timeout=5)
run.click()
lib.utils.check(lambda: not run.sensitive, timeout=5)
pause.click()
lib.utils.check(lambda: pause.checked, timeout=5)
pause.click()
lib.utils.check(lambda: not pause.checked, timeout=5)
smenu.click()
save.click()
lib.utils.check(lambda: run.sensitive, timeout=5)
lib.utils.check(lambda: "Saved" in c.text)
run.click()
lib.utils.check(lambda: shutdown.sensitive, timeout=5)
def testVMLifecycle(app):
# qemu hits some different domain code paths for setTime
app.uri = tests.utils.URIs.kvm
_testVMLifecycle(app)
def testVMNoEventsLifecycle(app):
app.open(extra_opts=["--test-options=no-events"])
# Change preferences timeout to 1 second
app.root.find("Edit", "menu").click()
app.root.find("Preferences", "menu item").click()
win = app.find_window("Preferences")
win.find("Polling", "page tab").click()
win.find("cpu-poll").set_text("1")
win.find("Close", "push button").click()
_testVMLifecycle(app)
def testVMLifecycleExtra(app):
"""
Test vmmenu lifecycle options
"""
app.open(keyfile="confirm-all.ini")
manager = app.topwin
run = manager.find("Run", "push button")
shutdown = manager.find("Shut Down", "push button")
pause = manager.find("Pause", "toggle button")
def confirm_is_running():
lib.utils.check(lambda: not run.sensitive)
def confirm_is_shutdown():
lib.utils.check(lambda: not shutdown.sensitive)
def confirm_is_paused():
lib.utils.check(lambda: pause.checked)
def confirm_not_paused():
lib.utils.check(lambda: not pause.checked)
def test_action(**kwargs):
app.manager_vm_action("test", confirm_click_no=True, **kwargs)
confirm_is_running()
test_action(reset=True)
confirm_is_running()
test_action(reboot=True)
confirm_is_running()
test_action(shutdown=True)
confirm_is_shutdown()
test_action(run=True)
confirm_is_running()
test_action(destroy=True)
confirm_is_shutdown()
test_action(run=True)
confirm_is_running()
test_action(pause=True)
confirm_is_paused()
test_action(resume=True)
confirm_not_paused()
test_action(save=True)
confirm_is_shutdown()
test_action(restore=True)
confirm_is_running()
def testManagerSaveCancelError(app):
"""
Test managed save special behavior
"""
app.open(extra_opts=["--test-options=test-managed-save"])
manager = app.topwin
run = manager.find("Run", "push button")
smenu = manager.find("Menu", "toggle button")
save = manager.find("Save", "menu item")
c = manager.find("test-many-devices", "table cell")
c.click()
# Save it, attempt a cancel operation
smenu.click()
save.click()
progwin = app.find_window("Saving Virtual Machine")
# Attempt cancel which will fail, then find the error message
progwin.find("Cancel", "push button").click()
progwin.find("Error cancelling save job")
lib.utils.check(lambda: not progwin.showing, timeout=5)
lib.utils.check(lambda: run.sensitive)
# Restore will fail and offer to remove managed save
run.click()
app.click_alert_button("remove the saved state", "No")
lib.utils.check(lambda: run.sensitive)
run.click()
app.click_alert_button("remove the saved state", "Yes")
lib.utils.check(lambda: not run.sensitive)
def testManagerQEMUSetTime(app):
"""
Fake qemu setTime behavior for code coverage
"""
app.uri = tests.utils.URIs.kvm
manager = app.topwin
run = manager.find("Run", "push button")
smenu = manager.find("Menu", "toggle button")
save = manager.find("Save", "menu item")
c = manager.find("test alternate devs title", "table cell")
c.click()
# Save -> resume -> save
smenu.click()
save.click()
lib.utils.check(lambda: run.sensitive)
app.sleep(1)
run.click()
lib.utils.check(lambda: not run.sensitive)
app.sleep(1)
smenu.click()
save.click()
lib.utils.check(lambda: run.sensitive)
app.sleep(1)
def testManagerVMRunFail(app):
# Force VM startup to fail so we can test the error path
app.open(extra_opts=["--test-options=test-vm-run-fail"])
manager = app.topwin
c = manager.find("test-clone-simple", "table cell")
c.click()
manager.find("Run", "push button").click()
app.click_alert_button("fake error", "Close")
def testManagerColumns(app):
# Enable all stat options
# Need to expand the window size so all columns are onscreen
app.open(keyfile="winsize.ini")
app.root.find("Edit", "menu").click()
app.root.find("Preferences", "menu item").click()
win = app.find_window("Preferences")
win.find("Polling", "page tab").click()
win.find_fuzzy("Poll Disk", "check").click()
win.find_fuzzy("Poll Network", "check").click()
win.find_fuzzy("Poll Memory", "check").click()
win.find("Close", "push button").click()
manager = app.topwin
def _test_sort(name):
col = manager.find(name, "table column header")
col.check_onscreen()
# Trigger sorting
col.click()
col.click()
def _click_column_menu(name):
manager.find("View", "menu").click()
menu = manager.find("Graph", "menu")
menu.point()
menu.find_fuzzy(name, "check menu item").click()
def _test_column(name):
_click_column_menu(name)
_test_sort(name)
_test_sort("Name")
_click_column_menu("Guest CPU")
_click_column_menu("Guest CPU")
_test_sort("CPU usage")
_test_column("Host CPU")
_test_column("Memory")
_test_column("Disk I/O")
_test_column("Network I/O")
def testManagerWindowReposition(app):
"""
Restore previous position when window is reopened
"""
manager = app.topwin
host = app.manager_open_host("Storage")
fmenu = host.find("File", "menu")
fmenu.click()
fmenu.find("View Manager", "menu item").click()
lib.utils.check(lambda: manager.active)
manager.window_maximize()
newx = manager.position[0]
newy = manager.position[1]
manager.keyCombo("<alt>F4")
host.click_title()
host.find("File", "menu").click()
host.find("View Manager", "menu item").click()
lib.utils.check(lambda: manager.showing)
assert manager.position == (newx, newy)
def testManagerWindowCleanup(app):
"""
Open migrate, clone, delete, newvm, details, host windows, close the
connection, make sure they all disappear
"""
def _drag(win):
"""
Drag a window so it's not obscuring the manager window
"""
win.drag(1000, 1000)
manager = app.topwin
app.sleep(1)
manager.window_maximize()
# Open delete window hitting a special code path, then close it
manager.find("test-many-devices", "table cell").click()
manager.find("Edit", "menu").click()
manager.find("Delete", "menu item").click()
delete = app.root.find_fuzzy("Delete", "frame")
app.sleep(.5)
delete.click_title()
delete.window_close()
# Open Clone window hitting a special code path, then close it
manager.find("test-clone", "table cell").click()
app.rawinput.pressKey("Menu")
app.root.find("Clone...", "menu item").click()
clone = app.find_window("Clone Virtual Machine")
app.sleep(.5)
clone.click_title()
clone.window_close()
# Open host
c = manager.find_fuzzy("testdriver.xml", "table cell")
c.click()
app.sleep(.5)
c.doubleClick()
host = app.find_window("test testdriver.xml - Connection Details")
_drag(host)
# Open details
c = manager.find("test-many-devices", "table cell")
c.click()
app.sleep(.5)
c.doubleClick()
details = app.find_details_window("test-many-devices")
_drag(details)
# Close the connection
app.sleep(.5)
manager.click_title()
app.sleep(.5)
app.manager_conn_disconnect("test testdriver.xml")
# Ensure all those windows aren't showing
lib.utils.check(lambda: not details.showing)
# Delete the connection, ensure the host dialog disappears
app.manager_conn_delete("test testdriver.xml")
lib.utils.check(lambda: not host.showing)
def testManagerDefaultStartup(app):
app.open(use_uri=False)
manager = app.topwin
errlabel = manager.find("error-label")
lib.utils.check(
lambda: "Checking for virtualization" in errlabel.text)
lib.utils.check(
lambda: "File->Add Connection" in errlabel.text)
lib.utils.check(
lambda: "appropriate QEMU/KVM" in errlabel.text)
manager.find("File", "menu").click()
manager.find("Quit", "menu item").click()
def testManagerConnOpenFail(app):
app.open(keyfile="baduri.ini")
manager = app.topwin
manager.find_fuzzy("bad uri", "table cell").doubleClick()
lib.utils.check(lambda: not manager.active)
app.click_alert_button("Unable to connect", "Close")
lib.utils.check(lambda: manager.active)