2018-05-23 19:19:00 +03:00
|
|
|
#!/usr/bin/env python
|
2018-02-08 22:06:41 +03:00
|
|
|
#
|
|
|
|
# Test ssh image creation
|
|
|
|
#
|
|
|
|
# Copyright (C) 2018 Red Hat, Inc.
|
|
|
|
#
|
2018-05-23 19:19:00 +03:00
|
|
|
# Creator/Owner: Kevin Wolf <kwolf@redhat.com>
|
|
|
|
#
|
2018-02-08 22:06:41 +03:00
|
|
|
# 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-05-23 19:19:00 +03:00
|
|
|
import iotests
|
|
|
|
import subprocess
|
|
|
|
import re
|
|
|
|
|
|
|
|
iotests.verify_image_format(supported_fmts=['raw'])
|
|
|
|
iotests.verify_protocol(supported=['ssh'])
|
|
|
|
|
2019-02-10 17:57:31 +03:00
|
|
|
def filter_hash(qmsg):
|
|
|
|
def _filter(key, value):
|
|
|
|
if key == 'hash' and re.match('[0-9a-f]+', value):
|
|
|
|
return 'HASH'
|
|
|
|
return value
|
|
|
|
return iotests.filter_qmp(qmsg, _filter)
|
2018-05-23 19:19:00 +03:00
|
|
|
|
|
|
|
def blockdev_create(vm, options):
|
2018-05-25 19:24:51 +03:00
|
|
|
result = vm.qmp_log('blockdev-create', job_id='job0', options=options,
|
2019-02-10 17:57:31 +03:00
|
|
|
filters=[iotests.filter_qmp_testfiles, filter_hash])
|
2018-05-23 19:19:00 +03:00
|
|
|
|
|
|
|
if 'return' in result:
|
|
|
|
assert result['return'] == {}
|
|
|
|
vm.run_job('job0')
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
with iotests.FilePath('t.img') as disk_path, \
|
|
|
|
iotests.VM() as vm:
|
|
|
|
|
|
|
|
remote_path = iotests.remote_filename(disk_path)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Successful image creation (defaults)
|
|
|
|
#
|
|
|
|
iotests.log("=== Successful image creation (defaults) ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': disk_path,
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 4194304 })
|
|
|
|
vm.shutdown()
|
|
|
|
|
2019-02-25 22:08:27 +03:00
|
|
|
iotests.img_info_log(remote_path)
|
2018-05-23 19:19:00 +03:00
|
|
|
iotests.log("")
|
|
|
|
iotests.img_info_log(disk_path)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Test host-key-check options
|
|
|
|
#
|
|
|
|
iotests.log("=== Test host-key-check options ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': disk_path,
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
},
|
|
|
|
'host-key-check': {
|
|
|
|
'mode': 'none'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 8388608 })
|
|
|
|
vm.shutdown()
|
|
|
|
|
2019-02-25 22:08:27 +03:00
|
|
|
iotests.img_info_log(remote_path)
|
2018-05-23 19:19:00 +03:00
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': disk_path,
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
},
|
|
|
|
'host-key-check': {
|
|
|
|
'mode': 'known_hosts'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 4194304 })
|
|
|
|
vm.shutdown()
|
|
|
|
|
2019-02-25 22:08:27 +03:00
|
|
|
iotests.img_info_log(remote_path)
|
2018-05-23 19:19:00 +03:00
|
|
|
|
|
|
|
md5_key = subprocess.check_output(
|
|
|
|
'ssh-keyscan -t rsa 127.0.0.1 2>/dev/null | grep -v "\\^#" | ' +
|
|
|
|
'cut -d" " -f3 | base64 -d | md5sum -b | cut -d" " -f1',
|
2018-10-22 16:53:01 +03:00
|
|
|
shell=True).rstrip().decode('ascii')
|
2018-05-23 19:19:00 +03:00
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': disk_path,
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
},
|
|
|
|
'host-key-check': {
|
|
|
|
'mode': 'hash',
|
|
|
|
'type': 'md5',
|
|
|
|
'hash': 'wrong',
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 2097152 })
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': disk_path,
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
},
|
|
|
|
'host-key-check': {
|
|
|
|
'mode': 'hash',
|
|
|
|
'type': 'md5',
|
|
|
|
'hash': md5_key,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 8388608 })
|
|
|
|
vm.shutdown()
|
|
|
|
|
2019-02-25 22:08:27 +03:00
|
|
|
iotests.img_info_log(remote_path)
|
2018-05-23 19:19:00 +03:00
|
|
|
|
|
|
|
sha1_key = subprocess.check_output(
|
|
|
|
'ssh-keyscan -t rsa 127.0.0.1 2>/dev/null | grep -v "\\^#" | ' +
|
|
|
|
'cut -d" " -f3 | base64 -d | sha1sum -b | cut -d" " -f1',
|
2018-10-22 16:53:01 +03:00
|
|
|
shell=True).rstrip().decode('ascii')
|
2018-05-23 19:19:00 +03:00
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': disk_path,
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
},
|
|
|
|
'host-key-check': {
|
|
|
|
'mode': 'hash',
|
|
|
|
'type': 'sha1',
|
|
|
|
'hash': 'wrong',
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 2097152 })
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': disk_path,
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
},
|
|
|
|
'host-key-check': {
|
|
|
|
'mode': 'hash',
|
|
|
|
'type': 'sha1',
|
|
|
|
'hash': sha1_key,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 4194304 })
|
|
|
|
vm.shutdown()
|
|
|
|
|
2019-02-25 22:08:27 +03:00
|
|
|
iotests.img_info_log(remote_path)
|
2018-05-23 19:19:00 +03:00
|
|
|
|
|
|
|
#
|
|
|
|
# Invalid path and user
|
|
|
|
#
|
|
|
|
iotests.log("=== Invalid path and user ===")
|
|
|
|
iotests.log("")
|
|
|
|
|
|
|
|
vm.launch()
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': '/this/is/not/an/existing/path',
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
},
|
|
|
|
'host-key-check': {
|
|
|
|
'mode': 'none'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 4194304 })
|
|
|
|
blockdev_create(vm, { 'driver': 'ssh',
|
|
|
|
'location': {
|
|
|
|
'path': disk_path,
|
|
|
|
'user': 'invalid user',
|
|
|
|
'server': {
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': '22'
|
|
|
|
},
|
|
|
|
'host-key-check': {
|
|
|
|
'mode': 'none'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'size': 4194304 })
|
|
|
|
vm.shutdown()
|