提交 b0f90495 编写于 作者: A Alberto Garcia 提交者: Kevin Wolf

qemu-iotests: Add iotests.supports_quorum()

There's many tests that need Quorum support in order to run. At the
moment each test implements its own check to see if Quorum is
enabled. This patch centralizes all those checks in a new function
called iotests.supports_quorum().
Signed-off-by: NAlberto Garcia <berto@igalia.com>
Reviewed-by: NKevin Wolf <kwolf@redhat.com>
Signed-off-by: NKevin Wolf <kwolf@redhat.com>
上级 704d59f1
...@@ -760,9 +760,6 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -760,9 +760,6 @@ class TestRepairQuorum(iotests.QMPTestCase):
image_len = 1 * 1024 * 1024 # MB image_len = 1 * 1024 * 1024 # MB
IMAGES = [ quorum_img1, quorum_img2, quorum_img3 ] IMAGES = [ quorum_img1, quorum_img2, quorum_img3 ]
def has_quorum(self):
return 'quorum' in iotests.qemu_img_pipe('--help')
def setUp(self): def setUp(self):
self.vm = iotests.VM() self.vm = iotests.VM()
...@@ -783,7 +780,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -783,7 +780,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
#assemble the quorum block device from the individual files #assemble the quorum block device from the individual files
args = { "driver": "quorum", "node-name": "quorum0", args = { "driver": "quorum", "node-name": "quorum0",
"vote-threshold": 2, "children": [ "img0", "img1", "img2" ] } "vote-threshold": 2, "children": [ "img0", "img1", "img2" ] }
if self.has_quorum(): if iotests.supports_quorum():
result = self.vm.qmp("blockdev-add", **args) result = self.vm.qmp("blockdev-add", **args)
self.assert_qmp(result, 'return', {}) self.assert_qmp(result, 'return', {})
...@@ -798,7 +795,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -798,7 +795,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
pass pass
def test_complete(self): def test_complete(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
self.assert_no_active_block_jobs() self.assert_no_active_block_jobs()
...@@ -817,7 +814,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -817,7 +814,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
'target image does not match source after mirroring') 'target image does not match source after mirroring')
def test_cancel(self): def test_cancel(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
self.assert_no_active_block_jobs() self.assert_no_active_block_jobs()
...@@ -834,7 +831,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -834,7 +831,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
self.vm.shutdown() self.vm.shutdown()
def test_cancel_after_ready(self): def test_cancel_after_ready(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
self.assert_no_active_block_jobs() self.assert_no_active_block_jobs()
...@@ -853,7 +850,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -853,7 +850,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
'target image does not match source after mirroring') 'target image does not match source after mirroring')
def test_pause(self): def test_pause(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
self.assert_no_active_block_jobs() self.assert_no_active_block_jobs()
...@@ -883,7 +880,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -883,7 +880,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
'target image does not match source after mirroring') 'target image does not match source after mirroring')
def test_medium_not_found(self): def test_medium_not_found(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
if iotests.qemu_default_machine != 'pc': if iotests.qemu_default_machine != 'pc':
...@@ -897,7 +894,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -897,7 +894,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
self.assert_qmp(result, 'error/class', 'GenericError') self.assert_qmp(result, 'error/class', 'GenericError')
def test_image_not_found(self): def test_image_not_found(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
result = self.vm.qmp('drive-mirror', job_id='job0', device='quorum0', result = self.vm.qmp('drive-mirror', job_id='job0', device='quorum0',
...@@ -907,7 +904,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -907,7 +904,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
self.assert_qmp(result, 'error/class', 'GenericError') self.assert_qmp(result, 'error/class', 'GenericError')
def test_device_not_found(self): def test_device_not_found(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
result = self.vm.qmp('drive-mirror', job_id='job0', result = self.vm.qmp('drive-mirror', job_id='job0',
...@@ -918,7 +915,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -918,7 +915,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
self.assert_qmp(result, 'error/class', 'GenericError') self.assert_qmp(result, 'error/class', 'GenericError')
def test_wrong_sync_mode(self): def test_wrong_sync_mode(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
result = self.vm.qmp('drive-mirror', device='quorum0', job_id='job0', result = self.vm.qmp('drive-mirror', device='quorum0', job_id='job0',
...@@ -928,7 +925,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -928,7 +925,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
self.assert_qmp(result, 'error/class', 'GenericError') self.assert_qmp(result, 'error/class', 'GenericError')
def test_no_node_name(self): def test_no_node_name(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
result = self.vm.qmp('drive-mirror', job_id='job0', device='quorum0', result = self.vm.qmp('drive-mirror', job_id='job0', device='quorum0',
...@@ -937,7 +934,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -937,7 +934,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
self.assert_qmp(result, 'error/class', 'GenericError') self.assert_qmp(result, 'error/class', 'GenericError')
def test_nonexistent_replaces(self): def test_nonexistent_replaces(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
result = self.vm.qmp('drive-mirror', job_id='job0', device='quorum0', result = self.vm.qmp('drive-mirror', job_id='job0', device='quorum0',
...@@ -946,7 +943,7 @@ class TestRepairQuorum(iotests.QMPTestCase): ...@@ -946,7 +943,7 @@ class TestRepairQuorum(iotests.QMPTestCase):
self.assert_qmp(result, 'error/class', 'GenericError') self.assert_qmp(result, 'error/class', 'GenericError')
def test_after_a_quorum_snapshot(self): def test_after_a_quorum_snapshot(self):
if not self.has_quorum(): if not iotests.supports_quorum():
return return
result = self.vm.qmp('blockdev-snapshot-sync', node_name='img1', result = self.vm.qmp('blockdev-snapshot-sync', node_name='img1',
......
...@@ -336,8 +336,9 @@ class TestBlockdevDel(iotests.QMPTestCase): ...@@ -336,8 +336,9 @@ class TestBlockdevDel(iotests.QMPTestCase):
self.checkBlockDriverState('node1', False) self.checkBlockDriverState('node1', False)
def testQuorum(self): def testQuorum(self):
if not 'quorum' in iotests.qemu_img_pipe('--help'): if not iotests.supports_quorum():
return return
self.addQuorum('quorum0', 'node0', 'node1') self.addQuorum('quorum0', 'node0', 'node1')
# We cannot remove the children of a Quorum device # We cannot remove the children of a Quorum device
self.delBlockDriverState('node0', expect_error = True) self.delBlockDriverState('node0', expect_error = True)
......
...@@ -348,9 +348,12 @@ def verify_platform(supported_oses=['linux']): ...@@ -348,9 +348,12 @@ def verify_platform(supported_oses=['linux']):
if True not in [sys.platform.startswith(x) for x in supported_oses]: if True not in [sys.platform.startswith(x) for x in supported_oses]:
notrun('not suitable for this OS: %s' % sys.platform) notrun('not suitable for this OS: %s' % sys.platform)
def supports_quorum():
return 'quorum' in qemu_img_pipe('--help')
def verify_quorum(): def verify_quorum():
'''Skip test suite if quorum support is not available''' '''Skip test suite if quorum support is not available'''
if 'quorum' not in qemu_img_pipe('--help'): if not supports_quorum():
notrun('quorum support missing') notrun('quorum support missing')
def main(supported_fmts=[], supported_oses=['linux']): def main(supported_fmts=[], supported_oses=['linux']):
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册