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:
Marek Marczykowski-Górecki 2017-06-21 04:45:46 +02:00
parent 376ac4b32d
commit a73dcf6016
No known key found for this signature in database
GPG Key ID: 063938BA42CFA724
2 changed files with 13 additions and 0 deletions

View File

@ -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

View File

@ -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',