From a5f341da6329bd8ba2cfe07d0bf374fa33aed7ce Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Thu, 14 Jan 2016 04:28:17 +0100 Subject: [PATCH] tests: regression test for #1389 QubesOS/qubes-issues#1389 (cherry picked from commit caa75cbc187d3345a2579119b2ba6aef91bfc264) --- tests/regressions.py | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/tests/regressions.py b/tests/regressions.py index 3248e0da4..f61f3a2b5 100644 --- a/tests/regressions.py +++ b/tests/regressions.py @@ -24,11 +24,14 @@ # import multiprocessing +import os import time import unittest import qubes.qubes import qubes.tests +import subprocess + class TC_00_Regressions(qubes.tests.SystemTestsMixin, qubes.tests.QubesTestCase): # Bug: #906 @@ -57,3 +60,22 @@ def create_vm(vmname): self.assertIsNotNone(qc.get_vm_by_name(vmname1)) self.assertIsNotNone(qc.get_vm_by_name(vmname2)) + def test_bug_1389_dispvm_qubesdb_crash(self): + """ + Sometimes QubesDB instance in DispVM crashes at startup. + Unfortunately we don't have reliable way to reproduce it, so try twice + :return: + """ + self.qc.unlock_db() + for try_no in xrange(2): + p = subprocess.Popen(['/usr/lib/qubes/qfile-daemon-dvm', + 'qubes.VMShell', 'dom0', 'DEFAULT'], + stdin=subprocess.PIPE, + stdout=subprocess.PIPE, + stderr=open(os.devnull, 'w')) + p.stdin.write("qubesdb-read /name || echo ERROR\n") + dispvm_name = p.stdout.readline() + p.stdin.close() + self.assertTrue(dispvm_name.startswith("disp"), + "Try {} failed".format(try_no)) +