From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:48956) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Yt5nN-00044x-Dc for qemu-devel@nongnu.org; Thu, 14 May 2015 22:56:18 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1Yt5nM-00009C-DS for qemu-devel@nongnu.org; Thu, 14 May 2015 22:56:17 -0400 Date: Fri, 15 May 2015 10:56:09 +0800 From: Fam Zheng Message-ID: <20150515025609.GM28144@ad.nay.redhat.com> References: <0faf3d82dca9bf334d99f761e84874cb36fa466b.1431523498.git.berto@igalia.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <0faf3d82dca9bf334d99f761e84874cb36fa466b.1431523498.git.berto@igalia.com> Subject: Re: [Qemu-devel] [PATCH 11/11] qemu-iotests: test overlapping block-stream operations List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Alberto Garcia Cc: qemu-devel@nongnu.org, qemu-block@nongnu.org On Wed, 05/13 16:27, Alberto Garcia wrote: > This test case checks that it's not possible to perform two > block-stream operations if there are nodes involved in both. > > Signed-off-by: Alberto Garcia > Reviewed-by: Max Reitz > --- > tests/qemu-iotests/030 | 27 +++++++++++++++++++++++++++ > tests/qemu-iotests/030.out | 4 ++-- > 2 files changed, 29 insertions(+), 2 deletions(-) > > diff --git a/tests/qemu-iotests/030 b/tests/qemu-iotests/030 > index c199cef..f898c92 100755 > --- a/tests/qemu-iotests/030 > +++ b/tests/qemu-iotests/030 > @@ -225,6 +225,33 @@ class TestParallelOps(iotests.QMPTestCase): > qemu_io('-f', iotests.imgfmt, '-c', 'map', self.imgs[i-1]), > 'image file map does not match backing file after streaming') > > + # Test that it's not possible to perform two block-stream > + # operations if there are nodes involved in both. > + def test_stream_overlapping(self): > + self.assert_no_active_block_jobs() > + > + # Set a speed limit to make sure that this job blocks the rest > + result = self.vm.qmp('block-stream', device='node4', base=self.imgs[0], speed=32768) > + self.assert_qmp(result, 'return', {}) > + > + result = self.vm.qmp('block-stream', device='node5', base=self.imgs[1]) > + self.assert_qmp(result, 'error/class', 'GenericError') > + > + result = self.vm.qmp('block-stream', device='node3', base=self.imgs[2]) > + self.assert_qmp(result, 'error/class', 'GenericError') > + > + result = self.vm.qmp('block-stream', device='node4') > + self.assert_qmp(result, 'error/class', 'GenericError') > + > + # If node4 is the active node, the id of the block job is drive0 > + if self.num_imgs == 5: Isn't self.num_imgs a constant (9) ? Fam > + self.wait_until_completed(drive='drive0') > + else: > + self.wait_until_completed(drive='node4') > + self.assert_no_active_block_jobs() > + > + self.vm.shutdown() > + > class TestSmallerBackingFile(iotests.QMPTestCase): > backing_len = 1 * 1024 * 1024 # MB > image_len = 2 * backing_len > diff --git a/tests/qemu-iotests/030.out b/tests/qemu-iotests/030.out > index b6f2576..52d796e 100644 > --- a/tests/qemu-iotests/030.out > +++ b/tests/qemu-iotests/030.out > @@ -1,5 +1,5 @@ > -................ > +................. > ---------------------------------------------------------------------- > -Ran 16 tests > +Ran 17 tests > > OK > -- > 2.1.4 > >