tests: fix vm.run_for_stdio in some more places
When test expect to wait for remote process, use vm.run_for_stdio. Additionally, when the call fail, (stdout, stderr) is not assigned - use the one attached to exception object instead.
This commit is contained in:
parent
a0f616f14e
commit
376ac4b32d
@ -497,8 +497,9 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
with self.qrexec_policy('test.Argument', '$anyvm', '$anyvm', False):
|
with self.qrexec_policy('test.Argument', '$anyvm', '$anyvm', False):
|
||||||
with self.qrexec_policy('test.Argument+argument',
|
with self.qrexec_policy('test.Argument+argument',
|
||||||
self.testvm1.name, self.testvm2.name):
|
self.testvm1.name, self.testvm2.name):
|
||||||
stdout, stderr = self.loop.run_until_complete(self.testvm1.run(
|
stdout, stderr = self.loop.run_until_complete(
|
||||||
'/usr/lib/qubes/qrexec-client-vm '
|
self.testvm1.run_for_stdio(
|
||||||
|
'/usr/lib/qubes/qrexec-client-vm '
|
||||||
'{} test.Argument+argument'.format(self.testvm2.name)))
|
'{} test.Argument+argument'.format(self.testvm2.name)))
|
||||||
self.assertEqual(stdout, b'argument')
|
self.assertEqual(stdout, b'argument')
|
||||||
|
|
||||||
@ -516,7 +517,8 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
with self.assertRaises(subprocess.CalledProcessError,
|
with self.assertRaises(subprocess.CalledProcessError,
|
||||||
msg='Service request should be denied'):
|
msg='Service request should be denied'):
|
||||||
self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
self.testvm1.run('/usr/lib/qubes/qrexec-client-vm {} '
|
self.testvm1.run_for_stdio(
|
||||||
|
'/usr/lib/qubes/qrexec-client-vm {} '
|
||||||
'test.Argument+argument'.format(self.testvm2.name)))
|
'test.Argument+argument'.format(self.testvm2.name)))
|
||||||
|
|
||||||
def test_083_qrexec_service_argument_specific_implementation(self):
|
def test_083_qrexec_service_argument_specific_implementation(self):
|
||||||
@ -564,12 +566,12 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
|
|
||||||
with self.qrexec_policy('qubes.Filecopy', self.testvm1, self.testvm2):
|
with self.qrexec_policy('qubes.Filecopy', self.testvm1, self.testvm2):
|
||||||
try:
|
try:
|
||||||
stdout, stderr = self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
self.testvm1.run_for_stdio(
|
self.testvm1.run_for_stdio(
|
||||||
'qvm-copy-to-vm {} /etc/passwd'.format(
|
'qvm-copy-to-vm {} /etc/passwd'.format(
|
||||||
self.testvm2.name)))
|
self.testvm2.name)))
|
||||||
except subprocess.CalledProcessError:
|
except subprocess.CalledProcessError as e:
|
||||||
self.fail('qvm-copy-to-vm failed: {}'.format(stderr))
|
self.fail('qvm-copy-to-vm failed: {}'.format(e.stderr))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
self.loop.run_until_complete(self.testvm2.run_for_stdio(
|
self.loop.run_until_complete(self.testvm2.run_for_stdio(
|
||||||
@ -593,11 +595,11 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
'cp /etc/passwd passwd'))
|
'cp /etc/passwd passwd'))
|
||||||
with self.qrexec_policy('qubes.Filecopy', self.testvm1, self.testvm2):
|
with self.qrexec_policy('qubes.Filecopy', self.testvm1, self.testvm2):
|
||||||
try:
|
try:
|
||||||
stdout, stderr = self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
self.testvm1.run_for_stdio(
|
self.testvm1.run_for_stdio(
|
||||||
'qvm-move-to-vm {} passwd'.format(self.testvm2.name)))
|
'qvm-move-to-vm {} passwd'.format(self.testvm2.name)))
|
||||||
except subprocess.CalledProcessError:
|
except subprocess.CalledProcessError as e:
|
||||||
self.fail('qvm-move-to-vm failed: {}'.format(stderr))
|
self.fail('qvm-move-to-vm failed: {}'.format(e.stderr))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
self.loop.run_until_complete(self.testvm2.run_for_stdio(
|
self.loop.run_until_complete(self.testvm2.run_for_stdio(
|
||||||
@ -615,12 +617,12 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
|
|
||||||
with self.qrexec_policy('qubes.Filecopy', self.testvm1, self.testvm2):
|
with self.qrexec_policy('qubes.Filecopy', self.testvm1, self.testvm2):
|
||||||
try:
|
try:
|
||||||
stdout, stderr = self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
self.testvm1.run_for_stdio(
|
self.testvm1.run_for_stdio(
|
||||||
'qvm-copy-to-vm {} /etc/passwd'.format(
|
'qvm-copy-to-vm {} /etc/passwd'.format(
|
||||||
self.testvm2.name)))
|
self.testvm2.name)))
|
||||||
except subprocess.CalledProcessError:
|
except subprocess.CalledProcessError as e:
|
||||||
self.fail('qvm-copy-to-vm failed: {}'.format(stderr))
|
self.fail('qvm-copy-to-vm failed: {}'.format(e.stderr))
|
||||||
|
|
||||||
# workaround for libvirt bug (domain ID isn't updated when is started
|
# workaround for libvirt bug (domain ID isn't updated when is started
|
||||||
# from other application) - details in
|
# from other application) - details in
|
||||||
@ -650,7 +652,7 @@ class TC_00_AppVMMixin(qubes.tests.SystemTestsMixin):
|
|||||||
with self.qrexec_policy('qubes.Filecopy', self.testvm1, self.testvm2,
|
with self.qrexec_policy('qubes.Filecopy', self.testvm1, self.testvm2,
|
||||||
allow=False):
|
allow=False):
|
||||||
with self.assertRaises(subprocess.CalledProcessError):
|
with self.assertRaises(subprocess.CalledProcessError):
|
||||||
stdout, stderr = self.loop.run_until_complete(
|
self.loop.run_until_complete(
|
||||||
self.testvm1.run_for_stdio(
|
self.testvm1.run_for_stdio(
|
||||||
'qvm-copy-to-vm {} /etc/passwd'.format(
|
'qvm-copy-to-vm {} /etc/passwd'.format(
|
||||||
self.testvm2.name)))
|
self.testvm2.name)))
|
||||||
|
Loading…
Reference in New Issue
Block a user