2020-01-30 19:32:30 +03:00
|
|
|
#!/usr/bin/env python3
|
2021-01-16 16:44:19 +03:00
|
|
|
# group: rw quick
|
2019-09-02 22:33:20 +03:00
|
|
|
#
|
|
|
|
# Test VPC and file image creation
|
|
|
|
#
|
|
|
|
# Copyright (C) 2019 Red Hat, Inc.
|
|
|
|
#
|
|
|
|
# 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/>.
|
|
|
|
#
|
|
|
|
|
|
|
|
import iotests
|
|
|
|
from iotests import imgfmt
|
|
|
|
|
|
|
|
|
|
|
|
# Successful image creation (defaults)
|
|
|
|
def implicit_defaults(vm, file_path):
|
|
|
|
iotests.log("=== Successful image creation (defaults) ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
# 8 heads, 964 cyls/head, 17 secs/cyl
|
|
|
|
# (Close to 64 MB)
|
|
|
|
size = 8 * 964 * 17 * 512
|
|
|
|
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'protocol-node',
|
|
|
|
'size': size })
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
# Successful image creation (explicit defaults)
|
|
|
|
def explicit_defaults(vm, file_path):
|
|
|
|
iotests.log("=== Successful image creation (explicit defaults) ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
# 16 heads, 964 cyls/head, 17 secs/cyl
|
|
|
|
# (Close to 128 MB)
|
|
|
|
size = 16 * 964 * 17 * 512
|
|
|
|
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'protocol-node',
|
|
|
|
'size': size,
|
|
|
|
'subformat': 'dynamic',
|
|
|
|
'force-size': False })
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
# Successful image creation (non-default options)
|
|
|
|
def non_defaults(vm, file_path):
|
|
|
|
iotests.log("=== Successful image creation (non-default options) ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
# Not representable in CHS (fine with force-size=True)
|
|
|
|
size = 1048576
|
|
|
|
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'protocol-node',
|
|
|
|
'size': size,
|
|
|
|
'subformat': 'fixed',
|
|
|
|
'force-size': True })
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
# Size not representable in CHS with force-size=False
|
|
|
|
def non_chs_size_without_force(vm, file_path):
|
|
|
|
iotests.log("=== Size not representable in CHS ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
# Not representable in CHS (will not work with force-size=False)
|
|
|
|
size = 1048576
|
|
|
|
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'protocol-node',
|
|
|
|
'size': size,
|
|
|
|
'force-size': False })
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
# Zero size
|
|
|
|
def zero_size(vm, file_path):
|
|
|
|
iotests.log("=== Zero size===")
|
|
|
|
iotests.log("")
|
|
|
|
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'protocol-node',
|
|
|
|
'size': 0 })
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
# Maximum CHS size
|
|
|
|
def maximum_chs_size(vm, file_path):
|
|
|
|
iotests.log("=== Maximum CHS size===")
|
|
|
|
iotests.log("")
|
|
|
|
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'protocol-node',
|
|
|
|
'size': 16 * 65535 * 255 * 512 })
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
# Actual maximum size
|
|
|
|
def maximum_size(vm, file_path):
|
|
|
|
iotests.log("=== Actual maximum size===")
|
|
|
|
iotests.log("")
|
|
|
|
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': imgfmt,
|
|
|
|
'file': 'protocol-node',
|
|
|
|
'size': 0xff000000 * 512,
|
|
|
|
'force-size': True })
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
for test_func in [implicit_defaults, explicit_defaults, non_defaults,
|
|
|
|
non_chs_size_without_force, zero_size, maximum_chs_size,
|
|
|
|
maximum_size]:
|
|
|
|
|
|
|
|
with iotests.FilePath('t.vpc') as file_path, \
|
|
|
|
iotests.VM() as vm:
|
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
|
|
|
|
iotests.log('--- Creating empty file ---')
|
2019-12-16 19:57:19 +03:00
|
|
|
vm.blockdev_create({ 'driver': 'file',
|
|
|
|
'filename': file_path,
|
|
|
|
'size': 0 })
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
vm.qmp_log('blockdev-add', driver='file', filename=file_path,
|
|
|
|
node_name='protocol-node',
|
|
|
|
filters=[iotests.filter_qmp_testfiles])
|
|
|
|
iotests.log('')
|
|
|
|
|
|
|
|
print_info = test_func(vm, file_path)
|
|
|
|
iotests.log('')
|
|
|
|
|
|
|
|
vm.shutdown()
|
iotests: make qemu_img_log and img_info_log raise on error
Add a `check: bool = True` parameter to both functions and make their
qemu_img() invocations raise on error by default.
users of img_info_log:
206, 207, 210, 211, 212, 213, 237, 242, 266, 274, 302
users of qemu_img_log:
044, 209, 274, 302, 304
iotests 242 and 266 need to use check=False for their negative tests.
iotests 206, 210, 211, 212, 213, 237, 274 and 302 continue working
normally.
As of this commit, all calls to QEMU_IMG made from iotests enforce a
return code of zero by default unless explicitly disabled or suppressed
by passing check=False or with an exception handler.
Signed-off-by: John Snow <jsnow@redhat.com>
Message-Id: <20220321201618.903471-19-jsnow@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Hanna Reitz <hreitz@redhat.com>
2022-03-21 23:16:18 +03:00
|
|
|
iotests.img_info_log(file_path, check=False)
|
2019-09-02 22:33:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
iotests.script_main(main,
|
|
|
|
supported_fmts=['vpc'],
|
|
|
|
supported_protocols=['file'])
|