Message ID | 1510851298-59922-5-git-send-email-anton.nefedov@virtuozzo.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Thu, Nov 16, 2017 at 07:54:58PM +0300, Anton Nefedov wrote: > Signed-off-by: Anton Nefedov <anton.nefedov@virtuozzo.com> > --- > tests/qemu-iotests/030 | 66 +++++++++++++++++++++++++++++++++++++++++++++- > tests/qemu-iotests/030.out | 4 +-- > 2 files changed, 67 insertions(+), 3 deletions(-) > > diff --git a/tests/qemu-iotests/030 b/tests/qemu-iotests/030 > index 457984b..831d6f3 100755 > --- a/tests/qemu-iotests/030 > +++ b/tests/qemu-iotests/030 > @@ -21,7 +21,7 @@ > import time > import os > import iotests > -from iotests import qemu_img, qemu_io > +from iotests import qemu_img, qemu_img_pipe, qemu_io > > backing_img = os.path.join(iotests.test_dir, 'backing.img') > mid_img = os.path.join(iotests.test_dir, 'mid.img') > @@ -804,5 +804,69 @@ class TestSetSpeed(iotests.QMPTestCase): > > self.cancel_and_wait(resume=True) > > +class TestCompressed(iotests.QMPTestCase): > + supported_fmts = ['qcow2'] > + cluster_size = 64 * 1024; > + image_len = 1 * 1024 * 1024; Please drop the unnecessary semicolons > + > + def setUp(self): > + qemu_img('create', '-f', iotests.imgfmt, '-o', 'cluster_size=%d' % TestCompressed.cluster_size, backing_img, str(TestCompressed.image_len)) > + qemu_io('-c', 'write -P 1 0 ' + str(TestCompressed.image_len), backing_img) > + qemu_img('create', '-f', iotests.imgfmt, '-o', 'backing_file=%s,cluster_size=%d' % (backing_img, TestCompressed.cluster_size), test_img) > + > + # write '3' in every 3rd cluster > + step = 3 > + for off in range(0, TestCompressed.image_len, TestCompressed.cluster_size * step): > + qemu_io('-c', 'write -P %d %d %d' % > + (step, off, TestCompressed.cluster_size), test_img) > + > + self.vm = iotests.VM().add_drive(test_img) > + self.vm.launch() > + > + def tearDown(self): > + os.remove(test_img) > + os.remove(backing_img) > + > + def _first_divider(self, x, divs): "Divisor" or "factor": https://en.wikipedia.org/wiki/Divisor > + return divs[0] if not x%divs[0] else self._first_divider(x, divs[1:]) An alternative that I find easier to read than conditional expressions: for divisor in divs: if x % divisor == 0: return divisor raise ValueError('No suitable divisor found') > + > + def test_compressed(self): > + self.assert_no_active_block_jobs() > + > + result = self.vm.qmp('block-stream', device='drive0', compress=True) > + if iotests.imgfmt not in TestCompressed.supported_fmts: > + self.assert_qmp( > + result, 'error/desc', > + 'Compression is not supported for this drive drive0') > + return > + self.assert_qmp(result, 'return', {}) > + > + # write '4' in every 4th cluster > + step = 4 > + for off in range(0, TestCompressed.image_len, TestCompressed.cluster_size * step): > + result = self.vm.qmp('human-monitor-command', > + command_line= > + 'qemu-io drive0 "write -P %d %d %d"' % > + (step, off, TestCompressed.cluster_size)) > + self.assert_qmp(result, 'return', "") > + > + self.wait_until_completed() > + self.assert_no_active_block_jobs() > + > + self.vm.shutdown() It is safe to call self.vm.shutdown() multiple times. Please call it from tearDown() too so the QEMU process is cleaned up on failure.
On 20/11/2017 5:38 PM, Stefan Hajnoczi wrote: > On Thu, Nov 16, 2017 at 07:54:58PM +0300, Anton Nefedov wrote: >> Signed-off-by: Anton Nefedov <anton.nefedov@virtuozzo.com> >> --- >> tests/qemu-iotests/030 | 66 +++++++++++++++++++++++++++++++++++++++++++++- >> tests/qemu-iotests/030.out | 4 +-- >> 2 files changed, 67 insertions(+), 3 deletions(-) >> >> diff --git a/tests/qemu-iotests/030 b/tests/qemu-iotests/030 >> index 457984b..831d6f3 100755 >> --- a/tests/qemu-iotests/030 >> +++ b/tests/qemu-iotests/030 >> @@ -21,7 +21,7 @@ >> import time >> import os >> import iotests >> -from iotests import qemu_img, qemu_io >> +from iotests import qemu_img, qemu_img_pipe, qemu_io >> >> backing_img = os.path.join(iotests.test_dir, 'backing.img') >> mid_img = os.path.join(iotests.test_dir, 'mid.img') >> @@ -804,5 +804,69 @@ class TestSetSpeed(iotests.QMPTestCase): >> >> self.cancel_and_wait(resume=True) >> >> +class TestCompressed(iotests.QMPTestCase): >> + supported_fmts = ['qcow2'] >> + cluster_size = 64 * 1024; >> + image_len = 1 * 1024 * 1024; > > Please drop the unnecessary semicolons > >> + >> + def setUp(self): >> + qemu_img('create', '-f', iotests.imgfmt, '-o', 'cluster_size=%d' % TestCompressed.cluster_size, backing_img, str(TestCompressed.image_len)) >> + qemu_io('-c', 'write -P 1 0 ' + str(TestCompressed.image_len), backing_img) >> + qemu_img('create', '-f', iotests.imgfmt, '-o', 'backing_file=%s,cluster_size=%d' % (backing_img, TestCompressed.cluster_size), test_img) >> + >> + # write '3' in every 3rd cluster >> + step = 3 >> + for off in range(0, TestCompressed.image_len, TestCompressed.cluster_size * step): >> + qemu_io('-c', 'write -P %d %d %d' % >> + (step, off, TestCompressed.cluster_size), test_img) >> + >> + self.vm = iotests.VM().add_drive(test_img) >> + self.vm.launch() >> + >> + def tearDown(self): >> + os.remove(test_img) >> + os.remove(backing_img) >> + >> + def _first_divider(self, x, divs): > > "Divisor" or "factor": > https://en.wikipedia.org/wiki/Divisor > >> + return divs[0] if not x%divs[0] else self._first_divider(x, divs[1:]) > > An alternative that I find easier to read than conditional expressions: > > for divisor in divs: > if x % divisor == 0: > return divisor > raise ValueError('No suitable divisor found') > >> + >> + def test_compressed(self): >> + self.assert_no_active_block_jobs() >> + >> + result = self.vm.qmp('block-stream', device='drive0', compress=True) >> + if iotests.imgfmt not in TestCompressed.supported_fmts: >> + self.assert_qmp( >> + result, 'error/desc', >> + 'Compression is not supported for this drive drive0') >> + return >> + self.assert_qmp(result, 'return', {}) >> + >> + # write '4' in every 4th cluster >> + step = 4 >> + for off in range(0, TestCompressed.image_len, TestCompressed.cluster_size * step): >> + result = self.vm.qmp('human-monitor-command', >> + command_line= >> + 'qemu-io drive0 "write -P %d %d %d"' % >> + (step, off, TestCompressed.cluster_size)) >> + self.assert_qmp(result, 'return', "") >> + >> + self.wait_until_completed() >> + self.assert_no_active_block_jobs() >> + >> + self.vm.shutdown() > > It is safe to call self.vm.shutdown() multiple times. Please call it > from tearDown() too so the QEMU process is cleaned up on failure. > Thank you, done to all remarks.
diff --git a/tests/qemu-iotests/030 b/tests/qemu-iotests/030 index 457984b..831d6f3 100755 --- a/tests/qemu-iotests/030 +++ b/tests/qemu-iotests/030 @@ -21,7 +21,7 @@ import time import os import iotests -from iotests import qemu_img, qemu_io +from iotests import qemu_img, qemu_img_pipe, qemu_io backing_img = os.path.join(iotests.test_dir, 'backing.img') mid_img = os.path.join(iotests.test_dir, 'mid.img') @@ -804,5 +804,69 @@ class TestSetSpeed(iotests.QMPTestCase): self.cancel_and_wait(resume=True) +class TestCompressed(iotests.QMPTestCase): + supported_fmts = ['qcow2'] + cluster_size = 64 * 1024; + image_len = 1 * 1024 * 1024; + + def setUp(self): + qemu_img('create', '-f', iotests.imgfmt, '-o', 'cluster_size=%d' % TestCompressed.cluster_size, backing_img, str(TestCompressed.image_len)) + qemu_io('-c', 'write -P 1 0 ' + str(TestCompressed.image_len), backing_img) + qemu_img('create', '-f', iotests.imgfmt, '-o', 'backing_file=%s,cluster_size=%d' % (backing_img, TestCompressed.cluster_size), test_img) + + # write '3' in every 3rd cluster + step = 3 + for off in range(0, TestCompressed.image_len, TestCompressed.cluster_size * step): + qemu_io('-c', 'write -P %d %d %d' % + (step, off, TestCompressed.cluster_size), test_img) + + self.vm = iotests.VM().add_drive(test_img) + self.vm.launch() + + def tearDown(self): + os.remove(test_img) + os.remove(backing_img) + + def _first_divider(self, x, divs): + return divs[0] if not x%divs[0] else self._first_divider(x, divs[1:]) + + def test_compressed(self): + self.assert_no_active_block_jobs() + + result = self.vm.qmp('block-stream', device='drive0', compress=True) + if iotests.imgfmt not in TestCompressed.supported_fmts: + self.assert_qmp( + result, 'error/desc', + 'Compression is not supported for this drive drive0') + return + self.assert_qmp(result, 'return', {}) + + # write '4' in every 4th cluster + step = 4 + for off in range(0, TestCompressed.image_len, TestCompressed.cluster_size * step): + result = self.vm.qmp('human-monitor-command', + command_line= + 'qemu-io drive0 "write -P %d %d %d"' % + (step, off, TestCompressed.cluster_size)) + self.assert_qmp(result, 'return', "") + + self.wait_until_completed() + self.assert_no_active_block_jobs() + + self.vm.shutdown() + + for i in range(TestCompressed.image_len / TestCompressed.cluster_size): + outp = qemu_io('-c', 'read -P %d %d %d' % + (self._first_divider(i, [4, 3, 1]), + i * TestCompressed.cluster_size, + TestCompressed.cluster_size), + test_img) + self.assertTrue(not 'fail' in outp) + self.assertTrue('read' in outp and 'at offset' in outp) + + self.assertTrue( + "File contains external, encrypted or compressed clusters." + in qemu_img_pipe('map', test_img)) + if __name__ == '__main__': iotests.main(supported_fmts=['qcow2', 'qed']) diff --git a/tests/qemu-iotests/030.out b/tests/qemu-iotests/030.out index 391c857..42314e9 100644 --- a/tests/qemu-iotests/030.out +++ b/tests/qemu-iotests/030.out @@ -1,5 +1,5 @@ -....................... +........................ ---------------------------------------------------------------------- -Ran 23 tests +Ran 24 tests OK
Signed-off-by: Anton Nefedov <anton.nefedov@virtuozzo.com> --- tests/qemu-iotests/030 | 66 +++++++++++++++++++++++++++++++++++++++++++++- tests/qemu-iotests/030.out | 4 +-- 2 files changed, 67 insertions(+), 3 deletions(-)