2018-12-06 18:07:34 +03:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#
|
|
|
|
# Test vmdk and file image creation
|
|
|
|
#
|
|
|
|
# Copyright (C) 2018 Red Hat, Inc.
|
|
|
|
#
|
|
|
|
# Creator/Owner: Kevin Wolf <kwolf@redhat.com>
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
|
2018-12-07 14:42:19 +03:00
|
|
|
import math
|
2018-12-06 18:07:34 +03:00
|
|
|
import iotests
|
|
|
|
from iotests import imgfmt
|
|
|
|
|
|
|
|
iotests.verify_image_format(supported_fmts=['vmdk'])
|
|
|
|
|
|
|
|
with iotests.FilePath('t.vmdk') as disk_path, \
|
|
|
|
iotests.FilePath('t.vmdk.1') as extent1_path, \
|
|
|
|
iotests.FilePath('t.vmdk.2') as extent2_path, \
|
|
|
|
iotests.FilePath('t.vmdk.3') as extent3_path, \
|
|
|
|
iotests.VM() as vm:
|
|
|
|
|
|
|
|
#
|
|
|
|
# Successful image creation (defaults)
|
|
|
|
#
|
|
|
|
iotests.log("=== Successful image creation (defaults) ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
size = 5 * 1024 * 1024 * 1024
|
|
|
|
|
|
|
|
vm.launch()
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': 'file',
|
|
|
|
'filename': disk_path,
|
|
|
|
'size': 0 })
|
2018-12-06 18:07:34 +03:00
|
|
|
|
|
|
|
vm.qmp_log('blockdev-add', driver='file', filename=disk_path,
|
2019-02-10 17:57:27 +03:00
|
|
|
node_name='imgfile', filters=[iotests.filter_qmp_testfiles])
|
2018-12-06 18:07:34 +03:00
|
|
|
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'imgfile',
|
|
|
|
'size': size })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
iotests.img_info_log(disk_path)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Successful image creation (inline blockdev-add, explicit defaults)
|
|
|
|
#
|
|
|
|
iotests.log("=== Successful image creation (inline blockdev-add, explicit defaults) ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
# Choose a different size to show that we got a new image
|
|
|
|
size = 64 * 1024 * 1024
|
|
|
|
|
|
|
|
vm.launch()
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': 'file',
|
|
|
|
'filename': disk_path,
|
|
|
|
'size': 0 })
|
|
|
|
|
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': {
|
|
|
|
'driver': 'file',
|
|
|
|
'filename': disk_path,
|
|
|
|
},
|
|
|
|
'size': size,
|
|
|
|
'extents': [],
|
|
|
|
'subformat': 'monolithicSparse',
|
|
|
|
'adapter-type': 'ide',
|
|
|
|
'hwversion': '4',
|
|
|
|
'zeroed-grain': False })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
iotests.img_info_log(disk_path)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Successful image creation (non-default options)
|
|
|
|
#
|
|
|
|
iotests.log("=== Successful image creation (with non-default options) ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
# Choose a different size to show that we got a new image
|
|
|
|
size = 32 * 1024 * 1024
|
|
|
|
|
|
|
|
vm.launch()
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': 'file',
|
|
|
|
'filename': disk_path,
|
|
|
|
'size': 0 })
|
|
|
|
|
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': {
|
|
|
|
'driver': 'file',
|
|
|
|
'filename': disk_path,
|
|
|
|
},
|
|
|
|
'size': size,
|
|
|
|
'extents': [],
|
|
|
|
'subformat': 'monolithicSparse',
|
|
|
|
'adapter-type': 'buslogic',
|
|
|
|
'zeroed-grain': True })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
iotests.img_info_log(disk_path)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Invalid BlockdevRef
|
|
|
|
#
|
|
|
|
iotests.log("=== Invalid BlockdevRef ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': "this doesn't exist",
|
|
|
|
'size': size })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
#
|
|
|
|
# Adapter types
|
|
|
|
#
|
|
|
|
|
|
|
|
iotests.log("=== Adapter types ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.add_blockdev('driver=file,filename=%s,node-name=node0' % (disk_path))
|
|
|
|
|
|
|
|
# Valid
|
|
|
|
iotests.log("== Valid adapter types ==")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
for adapter_type in [ 'ide', 'buslogic', 'lsilogic', 'legacyESX' ]:
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'node0',
|
|
|
|
'size': size,
|
|
|
|
'adapter-type': adapter_type })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
# Invalid
|
|
|
|
iotests.log("== Invalid adapter types ==")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
for adapter_type in [ 'foo', 'IDE', 'legacyesx', 1 ]:
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'node0',
|
|
|
|
'size': size,
|
|
|
|
'adapter-type': adapter_type })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
#
|
|
|
|
# Other subformats
|
|
|
|
#
|
|
|
|
iotests.log("=== Other subformats ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
for path in [ extent1_path, extent2_path, extent3_path ]:
|
|
|
|
msg = iotests.qemu_img_pipe('create', '-f', imgfmt, path, '0')
|
|
|
|
iotests.log(msg, [iotests.filter_testfiles])
|
|
|
|
|
|
|
|
vm.add_blockdev('driver=file,filename=%s,node-name=ext1' % (extent1_path))
|
|
|
|
vm.add_blockdev('driver=file,filename=%s,node-name=ext2' % (extent2_path))
|
|
|
|
vm.add_blockdev('driver=file,filename=%s,node-name=ext3' % (extent3_path))
|
|
|
|
|
|
|
|
# Missing extent
|
|
|
|
iotests.log("== Missing extent ==")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'node0',
|
|
|
|
'size': size,
|
|
|
|
'subformat': 'monolithicFlat' })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
# Correct extent
|
|
|
|
iotests.log("== Correct extent ==")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'node0',
|
|
|
|
'size': size,
|
|
|
|
'subformat': 'monolithicFlat',
|
|
|
|
'extents': ['ext1'] })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
# Extra extent
|
|
|
|
iotests.log("== Extra extent ==")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'node0',
|
|
|
|
'size': 512,
|
|
|
|
'subformat': 'monolithicFlat',
|
|
|
|
'extents': ['ext1', 'ext2', 'ext3'] })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
# Split formats
|
|
|
|
iotests.log("== Split formats ==")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
for size in [ 512, 1073741824, 2147483648, 5368709120 ]:
|
|
|
|
for subfmt in [ 'twoGbMaxExtentFlat', 'twoGbMaxExtentSparse' ]:
|
|
|
|
iotests.log("= %s %d =" % (subfmt, size))
|
|
|
|
iotests.log("")
|
|
|
|
|
2019-02-10 17:57:28 +03:00
|
|
|
num_extents = int(math.ceil(size / 2.0**31))
|
2018-12-07 14:42:19 +03:00
|
|
|
extents = [ "ext%d" % (i) for i in range(1, num_extents + 1) ]
|
|
|
|
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.launch()
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'node0',
|
|
|
|
'size': size,
|
|
|
|
'subformat': subfmt,
|
|
|
|
'extents': extents })
|
2018-12-06 18:07:34 +03:00
|
|
|
vm.shutdown()
|
|
|
|
|
|
|
|
iotests.img_info_log(disk_path)
|