mirror of
https://github.com/virt-manager/virt-manager.git
synced 2025-01-25 06:03:55 +03:00
uitests: Cover more createvm validation checks
Signed-off-by: Cole Robinson <crobinso@redhat.com>
This commit is contained in:
parent
e3be4b677e
commit
95bf8bf6b9
@ -1641,6 +1641,19 @@ ba</description>
|
|||||||
</permissions>
|
</permissions>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
|
<volume type='file'>
|
||||||
|
<name>aaa-unused.qcow2</name>
|
||||||
|
<capacity>1000000</capacity>
|
||||||
|
<allocation>50000</allocation>
|
||||||
|
<target>
|
||||||
|
<format type='qcow2'/>
|
||||||
|
<permissions>
|
||||||
|
<mode>0700</mode>
|
||||||
|
<owner>10736</owner>
|
||||||
|
<group>10736</group>
|
||||||
|
</permissions>
|
||||||
|
</target>
|
||||||
|
</volume>
|
||||||
<volume type='file'>
|
<volume type='file'>
|
||||||
<name>default-vol</name>
|
<name>default-vol</name>
|
||||||
<capacity>1000000</capacity>
|
<capacity>1000000</capacity>
|
||||||
|
@ -408,7 +408,7 @@ class AddHardware(uiutils.UITestCase):
|
|||||||
tab.find("Nbd", "menu item").click()
|
tab.find("Nbd", "menu item").click()
|
||||||
tab.find("Format:", "combo box").click_combo_entry()
|
tab.find("Format:", "combo box").click_combo_entry()
|
||||||
tab.find("qcow2", "menu item").click()
|
tab.find("qcow2", "menu item").click()
|
||||||
tab.find("Target path:", "text").text = "/foo/target"
|
|
||||||
source = tab.find("Source path:", "text")
|
source = tab.find("Source path:", "text")
|
||||||
source.text = "/foo/source"
|
source.text = "/foo/source"
|
||||||
tab.find("Browse...", "push button").click()
|
tab.find("Browse...", "push button").click()
|
||||||
@ -425,6 +425,12 @@ class AddHardware(uiutils.UITestCase):
|
|||||||
lambda: source.text == "/dev/default-pool/dir-vol")
|
lambda: source.text == "/dev/default-pool/dir-vol")
|
||||||
|
|
||||||
tab.find_fuzzy("Export filesystem", "check").click()
|
tab.find_fuzzy("Export filesystem", "check").click()
|
||||||
|
# Use this to test some error.py logic for truncating large errors
|
||||||
|
badtarget = "a" * 1024
|
||||||
|
tab.find("Target path:", "text").text = badtarget
|
||||||
|
finish.click()
|
||||||
|
self._click_alert_button("aaa...", "Close")
|
||||||
|
tab.find("Target path:", "text").text = "/foo/target"
|
||||||
finish.click()
|
finish.click()
|
||||||
uiutils.check_in_loop(lambda: details.active)
|
uiutils.check_in_loop(lambda: details.active)
|
||||||
|
|
||||||
|
@ -411,8 +411,14 @@ class NewVM(uiutils.UITestCase):
|
|||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
|
|
||||||
# Set custom init
|
# Set custom init
|
||||||
newvm.find_fuzzy(None,
|
apptext = newvm.find_fuzzy(None, "text", "application path")
|
||||||
"text", "application path").text = "/sbin/init"
|
apptext.text = ""
|
||||||
|
self.forward(newvm, check=False)
|
||||||
|
self._click_alert_button("path is required", "OK")
|
||||||
|
newvm.find("install-app-browse").click()
|
||||||
|
self._select_storagebrowser_volume("default-pool", "aaa-unused.qcow2")
|
||||||
|
uiutils.check_in_loop(lambda: "aaa-unused.qcow2" in apptext.text)
|
||||||
|
|
||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
# Trigger back, to ensure disk page skipping works
|
# Trigger back, to ensure disk page skipping works
|
||||||
@ -438,8 +444,15 @@ class NewVM(uiutils.UITestCase):
|
|||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
|
|
||||||
# Set directory path
|
# Set directory path
|
||||||
newvm.find_fuzzy(None,
|
dirtext = newvm.find_fuzzy(None, "text", "root directory")
|
||||||
"text", "root directory").text = "/tmp"
|
dirtext.text = ""
|
||||||
|
self.forward(newvm, check=False)
|
||||||
|
self._click_alert_button("path is required", "OK")
|
||||||
|
|
||||||
|
newvm.find("install-oscontainer-browse").click()
|
||||||
|
self._select_storagebrowser_volume("default-pool", "dir-vol")
|
||||||
|
uiutils.check_in_loop(lambda: "dir-vol" in dirtext.text)
|
||||||
|
|
||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
newvm.find_fuzzy("Finish", "button").click()
|
newvm.find_fuzzy("Finish", "button").click()
|
||||||
@ -574,16 +587,20 @@ class NewVM(uiutils.UITestCase):
|
|||||||
vmname = "fooxmleditvm"
|
vmname = "fooxmleditvm"
|
||||||
newvm.find_fuzzy("Local install media", "radio").click()
|
newvm.find_fuzzy("Local install media", "radio").click()
|
||||||
newvm.find_fuzzy("Forward", "button").click()
|
newvm.find_fuzzy("Forward", "button").click()
|
||||||
|
nonexistpath = "/dev/foovmm-idontexist"
|
||||||
existpath = "/dev/default-pool/testvol1.img"
|
existpath = "/dev/default-pool/testvol1.img"
|
||||||
newvm.find("media-entry").text = existpath
|
newvm.find("media-entry").text = nonexistpath
|
||||||
uiutils.check_in_loop(
|
uiutils.check_in_loop(
|
||||||
lambda: newvm.find("oslist-entry").text == "None detected")
|
lambda: newvm.find("oslist-entry").text == "None detected")
|
||||||
newvm.find_fuzzy("Automatically detect", "check").click()
|
newvm.find_fuzzy("Automatically detect", "check").click()
|
||||||
newvm.find("oslist-entry").text = "generic"
|
newvm.find("oslist-entry").text = "generic"
|
||||||
newvm.find("oslist-popover").find_fuzzy("generic").click()
|
newvm.find("oslist-popover").find_fuzzy("generic").click()
|
||||||
newvm.find_fuzzy("Forward", "button").click()
|
self.forward(newvm, check=False)
|
||||||
newvm.find_fuzzy("Forward", "button").click()
|
self._click_alert_button("Error setting installer", "OK")
|
||||||
newvm.find_fuzzy("Forward", "button").click()
|
newvm.find("media-entry").text = existpath
|
||||||
|
self.forward(newvm)
|
||||||
|
self.forward(newvm)
|
||||||
|
self.forward(newvm)
|
||||||
newvm.find_fuzzy("Customize", "check").click()
|
newvm.find_fuzzy("Customize", "check").click()
|
||||||
newvm.find_fuzzy("Name", "text").text = vmname
|
newvm.find_fuzzy("Name", "text").text = vmname
|
||||||
newvm.find_fuzzy("Finish", "button").click()
|
newvm.find_fuzzy("Finish", "button").click()
|
||||||
@ -657,6 +674,29 @@ class NewVM(uiutils.UITestCase):
|
|||||||
|
|
||||||
newvm.find_fuzzy("Import", "radio").click()
|
newvm.find_fuzzy("Import", "radio").click()
|
||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
|
importtext = newvm.find_fuzzy(None, "text", "existing storage")
|
||||||
|
|
||||||
|
# Click forward, hitting missing OS error
|
||||||
|
self.forward(newvm, check=False)
|
||||||
|
self._click_alert_button("select an OS", "OK")
|
||||||
|
|
||||||
|
# Set OS
|
||||||
|
newvm.find("oslist-entry").text = "generic"
|
||||||
|
newvm.find("oslist-popover").find_fuzzy("generic").click()
|
||||||
|
|
||||||
|
# Click forward, hitting missing Import path error
|
||||||
|
self.forward(newvm, check=False)
|
||||||
|
self._click_alert_button("import is required", "OK")
|
||||||
|
|
||||||
|
# Click forward, but Import path doesn't exist
|
||||||
|
importtext.text = "/dev/default-pool/idontexist"
|
||||||
|
self.forward(newvm, check=False)
|
||||||
|
self._click_alert_button("import path must point", "OK")
|
||||||
|
|
||||||
|
# Click forward, but Import path is in use, and exit
|
||||||
|
importtext.text = "/dev/default-pool/default-vol"
|
||||||
|
self.forward(newvm, check=False)
|
||||||
|
self._click_alert_button("in use", "No")
|
||||||
|
|
||||||
# storagebrowser bits
|
# storagebrowser bits
|
||||||
newvm.find("install-import-browse").click()
|
newvm.find("install-import-browse").click()
|
||||||
@ -672,12 +712,9 @@ class NewVM(uiutils.UITestCase):
|
|||||||
browsewin.find_fuzzy("default-pool", "table cell").click()
|
browsewin.find_fuzzy("default-pool", "table cell").click()
|
||||||
browsewin.find_fuzzy("bochs-vol", "table cell").click()
|
browsewin.find_fuzzy("bochs-vol", "table cell").click()
|
||||||
browsewin.find("Choose Volume").click()
|
browsewin.find("Choose Volume").click()
|
||||||
importtext = newvm.find_fuzzy(None, "text", "existing storage")
|
|
||||||
uiutils.check_in_loop(
|
uiutils.check_in_loop(
|
||||||
lambda: importtext.text == "/dev/default-pool/bochs-vol")
|
lambda: importtext.text == "/dev/default-pool/bochs-vol")
|
||||||
|
|
||||||
newvm.find("oslist-entry").text = "generic"
|
|
||||||
newvm.find("oslist-popover").find_fuzzy("generic").click()
|
|
||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
self.forward(newvm)
|
self.forward(newvm)
|
||||||
|
|
||||||
|
@ -281,9 +281,9 @@ class VMMDogtailNode(dogtail.tree.Node):
|
|||||||
if self.roleName in ["menu", "menu item", "frame"]:
|
if self.roleName in ["menu", "menu item", "frame"]:
|
||||||
return True
|
return True
|
||||||
screen = Gdk.Screen.get_default()
|
screen = Gdk.Screen.get_default()
|
||||||
return (self.position[0] > 0 and
|
return (self.position[0] >= 0 and
|
||||||
self.position[0] + self.size[0] < screen.get_width() and
|
self.position[0] + self.size[0] < screen.get_width() and
|
||||||
self.position[1] > 0 and
|
self.position[1] >= 0 and
|
||||||
self.position[1] + self.size[1] < screen.get_height())
|
self.position[1] + self.size[1] < screen.get_height())
|
||||||
|
|
||||||
def click_secondary_icon(self):
|
def click_secondary_icon(self):
|
||||||
|
@ -1581,7 +1581,7 @@ class vmmCreateVM(vmmGObjectUI):
|
|||||||
if not template:
|
if not template:
|
||||||
return self.err.val_err(_("A template name is required."))
|
return self.err.val_err(_("A template name is required."))
|
||||||
|
|
||||||
# Validate media location
|
# Build the installer and Guest instance
|
||||||
try:
|
try:
|
||||||
if init:
|
if init:
|
||||||
self._gdata.init = init
|
self._gdata.init = init
|
||||||
@ -1599,12 +1599,6 @@ class vmmCreateVM(vmmGObjectUI):
|
|||||||
fsdev.source = template
|
fsdev.source = template
|
||||||
self._gdata.filesystem = fsdev
|
self._gdata.filesystem = fsdev
|
||||||
|
|
||||||
except Exception as e:
|
|
||||||
msg = _("Error setting install media location.")
|
|
||||||
return self.err.val_err(msg, e)
|
|
||||||
|
|
||||||
# Build the installer and Guest instance
|
|
||||||
try:
|
|
||||||
self._gdata.location = location
|
self._gdata.location = location
|
||||||
self._gdata.cdrom = cdrom
|
self._gdata.cdrom = cdrom
|
||||||
self._gdata.extra_args = extra
|
self._gdata.extra_args = extra
|
||||||
|
Loading…
x
Reference in New Issue
Block a user