3 # Test VDI and file image creation
5 # Copyright (C) 2018 Red Hat, Inc.
7 # Creator/Owner: Kevin Wolf <kwolf@redhat.com>
9 # This program is free software; you can redistribute it and/or modify
10 # it under the terms of the GNU General Public License as published by
11 # the Free Software Foundation; either version 2 of the License, or
12 # (at your option) any later version.
14 # This program is distributed in the hope that it will be useful,
15 # but WITHOUT ANY WARRANTY; without even the implied warranty of
16 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 # GNU General Public License for more details.
19 # You should have received a copy of the GNU General Public License
20 # along with this program. If not, see <http://www.gnu.org/licenses/>.
24 from iotests
import imgfmt
26 iotests
.verify_image_format(supported_fmts
=['vdi'])
27 iotests
.verify_protocol(supported
=['file'])
29 def blockdev_create(vm
, options
):
30 result
= vm
.qmp_log('blockdev-create', job_id
='job0', options
=options
,
31 filters
=[iotests
.filter_qmp_testfiles
])
33 if 'return' in result
:
34 assert result
['return'] == {}
35 error
= vm
.run_job('job0')
36 if error
and 'Could not allocate bmap' in error
:
37 iotests
.notrun('Insufficient memory')
40 with iotests
.FilePath('t.vdi') as disk_path
, \
44 # Successful image creation (defaults)
46 iotests
.log("=== Successful image creation (defaults) ===")
49 size
= 128 * 1024 * 1024
52 blockdev_create(vm
, { 'driver': 'file',
53 'filename': disk_path
,
56 vm
.qmp_log('blockdev-add', driver
='file', filename
=disk_path
,
57 node_name
='imgfile', filters
=[iotests
.filter_qmp_testfiles
])
59 blockdev_create(vm
, { 'driver': imgfmt
,
64 iotests
.img_info_log(disk_path
)
65 iotests
.log(iotests
.qemu_img_pipe('map', '--output=json', disk_path
))
68 # Successful image creation (explicit defaults)
70 iotests
.log("=== Successful image creation (explicit defaults) ===")
73 size
= 64 * 1024 * 1024
76 blockdev_create(vm
, { 'driver': 'file',
77 'filename': disk_path
,
79 blockdev_create(vm
, { 'driver': imgfmt
,
82 'filename': disk_path
,
85 'preallocation': 'off' })
88 iotests
.img_info_log(disk_path
)
89 iotests
.log(iotests
.qemu_img_pipe('map', '--output=json', disk_path
))
92 # Successful image creation (with non-default options)
94 iotests
.log("=== Successful image creation (with non-default options) ===")
97 size
= 32 * 1024 * 1024
100 blockdev_create(vm
, { 'driver': 'file',
101 'filename': disk_path
,
103 blockdev_create(vm
, { 'driver': imgfmt
,
106 'filename': disk_path
,
109 'preallocation': 'metadata' })
112 iotests
.img_info_log(disk_path
)
113 iotests
.log(iotests
.qemu_img_pipe('map', '--output=json', disk_path
))
116 # Invalid BlockdevRef
118 iotests
.log("=== Invalid BlockdevRef ===")
122 blockdev_create(vm
, { 'driver': imgfmt
,
123 'file': "this doesn't exist",
130 iotests
.log("=== Zero size ===")
133 vm
.add_blockdev('driver=file,filename=%s,node-name=node0' % (disk_path
))
135 blockdev_create(vm
, { 'driver': imgfmt
,
140 iotests
.img_info_log(disk_path
)
145 iotests
.log("=== Maximum size ===")
149 blockdev_create(vm
, { 'driver': imgfmt
,
151 'size': 562949819203584 })
154 iotests
.img_info_log(disk_path
)
160 # TODO Negative image sizes aren't handled correctly, but this is a problem
161 # with QAPI's implementation of the 'size' type and affects other commands
162 # as well. Once this is fixed, we may want to add a test case here.
165 # 2. 2^63 = 8 EB (qemu-img enforces image sizes less than this)
166 # 3. 0x1fffff8000001 (one byte more than maximum image size for VDI)
168 iotests
.log("=== Invalid sizes ===")
172 for size
in [ 18446744073709551104, 9223372036854775808, 562949819203585 ]:
173 blockdev_create(vm
, { 'driver': imgfmt
,