tests: improve qvm-run of GUI apps tests, include qubes-desktop-run
This commit is contained in:
parent
9cb62f8f4d
commit
f064a4c6ea
@ -70,7 +70,42 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
|
|
||||||
@unittest.skipUnless(spawn.find_executable('xdotool'),
|
@unittest.skipUnless(spawn.find_executable('xdotool'),
|
||||||
"xdotool not installed")
|
"xdotool not installed")
|
||||||
def test_010_run_gui_app(self):
|
def test_010_run_xterm(self):
|
||||||
|
self.testvm1.start()
|
||||||
|
self.assertEquals(self.testvm1.get_power_state(), "Running")
|
||||||
|
self.testvm1.run("xterm")
|
||||||
|
wait_count = 0
|
||||||
|
while subprocess.call(
|
||||||
|
['xdotool', 'search', '--name', 'user@{}'.
|
||||||
|
format(self.testvm1.name)],
|
||||||
|
stdout=open(os.path.devnull, 'w'),
|
||||||
|
stderr=subprocess.STDOUT) > 0:
|
||||||
|
wait_count += 1
|
||||||
|
if wait_count > 100:
|
||||||
|
self.fail("Timeout while waiting for gnome-terminal window")
|
||||||
|
time.sleep(0.1)
|
||||||
|
|
||||||
|
time.sleep(0.5)
|
||||||
|
subprocess.check_call(
|
||||||
|
['xdotool', 'search', '--name', 'user@{}'.format(self.testvm1.name),
|
||||||
|
'windowactivate', 'type', 'exit\n'])
|
||||||
|
|
||||||
|
wait_count = 0
|
||||||
|
while subprocess.call(['xdotool', 'search', '--name',
|
||||||
|
'user@{}'.format(self.testvm1.name)],
|
||||||
|
stdout=open(os.path.devnull, 'w'),
|
||||||
|
stderr=subprocess.STDOUT) == 0:
|
||||||
|
wait_count += 1
|
||||||
|
if wait_count > 100:
|
||||||
|
self.fail("Timeout while waiting for gnome-terminal "
|
||||||
|
"termination")
|
||||||
|
time.sleep(0.1)
|
||||||
|
|
||||||
|
@unittest.skipUnless(spawn.find_executable('xdotool'),
|
||||||
|
"xdotool not installed")
|
||||||
|
def test_011_run_gnome_terminal(self):
|
||||||
|
if "minimal" in self.template:
|
||||||
|
self.skipTest("Minimal template doesn't have 'gnome-terminal'")
|
||||||
self.testvm1.start()
|
self.testvm1.start()
|
||||||
self.assertEquals(self.testvm1.get_power_state(), "Running")
|
self.assertEquals(self.testvm1.get_power_state(), "Running")
|
||||||
self.testvm1.run("gnome-terminal")
|
self.testvm1.run("gnome-terminal")
|
||||||
@ -101,6 +136,46 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
"termination")
|
"termination")
|
||||||
time.sleep(0.1)
|
time.sleep(0.1)
|
||||||
|
|
||||||
|
@unittest.skipUnless(spawn.find_executable('xdotool'),
|
||||||
|
"xdotool not installed")
|
||||||
|
def test_012_qubes_desktop_run(self):
|
||||||
|
self.testvm1.start()
|
||||||
|
self.assertEquals(self.testvm1.get_power_state(), "Running")
|
||||||
|
xterm_desktop_path = "/usr/share/applications/xterm.desktop"
|
||||||
|
# Debian has it different...
|
||||||
|
xterm_desktop_path_debian = \
|
||||||
|
"/usr/share/applications/debian-xterm.desktop"
|
||||||
|
if self.testvm1.run("test -r {}".format(xterm_desktop_path_debian),
|
||||||
|
wait=True) == 0:
|
||||||
|
xterm_desktop_path = xterm_desktop_path_debian
|
||||||
|
self.testvm1.run("qubes-desktop-run {}".format(xterm_desktop_path))
|
||||||
|
wait_count = 0
|
||||||
|
while subprocess.call(
|
||||||
|
['xdotool', 'search', '--name', 'user@{}'.
|
||||||
|
format(self.testvm1.name)],
|
||||||
|
stdout=open(os.path.devnull, 'w'),
|
||||||
|
stderr=subprocess.STDOUT) > 0:
|
||||||
|
wait_count += 1
|
||||||
|
if wait_count > 100:
|
||||||
|
self.fail("Timeout while waiting for gnome-terminal window")
|
||||||
|
time.sleep(0.1)
|
||||||
|
|
||||||
|
time.sleep(0.5)
|
||||||
|
subprocess.check_call(
|
||||||
|
['xdotool', 'search', '--name', 'user@{}'.format(self.testvm1.name),
|
||||||
|
'windowactivate', 'type', 'exit\n'])
|
||||||
|
|
||||||
|
wait_count = 0
|
||||||
|
while subprocess.call(['xdotool', 'search', '--name',
|
||||||
|
'user@{}'.format(self.testvm1.name)],
|
||||||
|
stdout=open(os.path.devnull, 'w'),
|
||||||
|
stderr=subprocess.STDOUT) == 0:
|
||||||
|
wait_count += 1
|
||||||
|
if wait_count > 100:
|
||||||
|
self.fail("Timeout while waiting for gnome-terminal "
|
||||||
|
"termination")
|
||||||
|
time.sleep(0.1)
|
||||||
|
|
||||||
def test_050_qrexec_simple_eof(self):
|
def test_050_qrexec_simple_eof(self):
|
||||||
"""Test for data and EOF transmission dom0->VM"""
|
"""Test for data and EOF transmission dom0->VM"""
|
||||||
result = multiprocessing.Value('i', 0)
|
result = multiprocessing.Value('i', 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user