tests: wait for session in tests requiring running GUI
Since tests expose qubesd socket, qvm-start-gui should handle starting GUI daemons (so, GUI session inside VM). Add synchronization with it using qubes.WaitForSession service.
This commit is contained in:
parent
376ac4b32d
commit
a73dcf6016
@ -938,6 +938,13 @@ class SystemTestsMixin(object):
|
|||||||
'cat > {}'.format(shlex.quote(filename)),
|
'cat > {}'.format(shlex.quote(filename)),
|
||||||
user='root', input=content.encode('utf-8')))
|
user='root', input=content.encode('utf-8')))
|
||||||
|
|
||||||
|
@asyncio.coroutine
|
||||||
|
def wait_for_session(self, vm):
|
||||||
|
yield from asyncio.wait_for(
|
||||||
|
vm.run_service_for_stdio(
|
||||||
|
'qubes.WaitForSession', input=vm.default_user.encode()),
|
||||||
|
timeout=30)
|
||||||
|
|
||||||
|
|
||||||
def load_tests(loader, tests, pattern): # pylint: disable=unused-argument
|
def load_tests(loader, tests, pattern): # pylint: disable=unused-argument
|
||||||
# discard any tests from this module, because it hosts base classes
|
# discard any tests from this module, because it hosts base classes
|
||||||
|
@ -68,6 +68,7 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
self.loop.run_until_complete(self.testvm1.start())
|
self.loop.run_until_complete(self.testvm1.start())
|
||||||
self.assertEqual(self.testvm1.get_power_state(), "Running")
|
self.assertEqual(self.testvm1.get_power_state(), "Running")
|
||||||
|
|
||||||
|
self.loop.run_until_complete(self.wait_for_session(self.testvm1))
|
||||||
p = self.loop.run_until_complete(self.testvm1.run('xterm'))
|
p = self.loop.run_until_complete(self.testvm1.run('xterm'))
|
||||||
try:
|
try:
|
||||||
wait_count = 0
|
wait_count = 0
|
||||||
@ -110,6 +111,7 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
self.skipTest("Minimal template doesn't have 'gnome-terminal'")
|
self.skipTest("Minimal template doesn't have 'gnome-terminal'")
|
||||||
self.loop.run_until_complete(self.testvm1.start())
|
self.loop.run_until_complete(self.testvm1.start())
|
||||||
self.assertEqual(self.testvm1.get_power_state(), "Running")
|
self.assertEqual(self.testvm1.get_power_state(), "Running")
|
||||||
|
self.loop.run_until_complete(self.wait_for_session(self.testvm1))
|
||||||
p = self.loop.run_until_complete(self.testvm1.run('gnome-terminal'))
|
p = self.loop.run_until_complete(self.testvm1.run('gnome-terminal'))
|
||||||
try:
|
try:
|
||||||
title = 'user@{}'.format(self.testvm1.name)
|
title = 'user@{}'.format(self.testvm1.name)
|
||||||
@ -163,6 +165,7 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
xterm_desktop_path = xterm_desktop_path_debian
|
xterm_desktop_path = xterm_desktop_path_debian
|
||||||
|
self.loop.run_until_complete(self.wait_for_session(self.testvm1))
|
||||||
self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
self.testvm1.run('qubes-desktop-run {}'.format(xterm_desktop_path)))
|
self.testvm1.run('qubes-desktop-run {}'.format(xterm_desktop_path)))
|
||||||
title = 'user@{}'.format(self.testvm1.name)
|
title = 'user@{}'.format(self.testvm1.name)
|
||||||
@ -687,6 +690,8 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
self.testvm1.start(),
|
self.testvm1.start(),
|
||||||
self.testvm2.start()]))
|
self.testvm2.start()]))
|
||||||
|
|
||||||
|
self.loop.run_until_complete(self.wait_for_session(self.testvm1))
|
||||||
|
|
||||||
# Prepare test file
|
# Prepare test file
|
||||||
self.loop.run_until_complete(self.testvm1.run_for_stdio(
|
self.loop.run_until_complete(self.testvm1.run_for_stdio(
|
||||||
'yes teststring | dd of=testfile bs=1M count=50 iflag=fullblock'))
|
'yes teststring | dd of=testfile bs=1M count=50 iflag=fullblock'))
|
||||||
@ -818,6 +823,7 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
# exclude from memory balancing
|
# exclude from memory balancing
|
||||||
self.testvm1.features['services/meminfo-writer'] = False
|
self.testvm1.features['services/meminfo-writer'] = False
|
||||||
yield from self.testvm1.start()
|
yield from self.testvm1.start()
|
||||||
|
yield from self.wait_for_session(self.testvm1)
|
||||||
|
|
||||||
# and allow large map count
|
# and allow large map count
|
||||||
yield from self.testvm1.run('echo 256000 > /proc/sys/vm/max_map_count',
|
yield from self.testvm1.run('echo 256000 > /proc/sys/vm/max_map_count',
|
||||||
|
Loading…
Reference in New Issue
Block a user