2014-02-06 15:12:12 +04:00
# Copyright (C) 2013, 2014 Red Hat, Inc.
2013-03-18 01:06:52 +04:00
#
2018-04-04 16:35:41 +03:00
# This work is licensed under the GNU GPLv2 or later.
2018-03-20 22:00:02 +03:00
# See the COPYING file in the top-level directory.
2013-03-18 01:06:52 +04:00
import atexit
2017-10-11 14:35:50 +03:00
import io
2013-03-18 01:06:52 +04:00
import os
import shlex
2013-09-29 01:23:23 +04:00
import shutil
2013-03-18 01:06:52 +04:00
import sys
import traceback
import unittest
2018-12-19 19:53:14 +03:00
try :
import argcomplete
except ImportError :
argcomplete = None
2019-06-17 04:12:39 +03:00
from virtinst import log
2019-06-17 04:34:47 +03:00
from virtinst . install import unattended
2019-06-10 03:18:13 +03:00
2014-09-07 02:05:43 +04:00
from tests import virtinstall , virtclone , virtconvert , virtxml
2013-04-11 03:48:07 +04:00
from tests import utils
2013-03-18 01:06:52 +04:00
os . environ [ " LANG " ] = " en_US.UTF-8 "
2013-09-28 22:42:37 +04:00
os . environ [ " HOME " ] = " /tmp "
os . environ [ " DISPLAY " ] = " :3.4 "
2018-06-12 19:26:13 +03:00
TMP_IMAGE_DIR = " /tmp/__virtinst_cli_ "
XMLDIR = " tests/cli-test-xml "
2019-01-30 19:55:40 +03:00
OLD_OSINFO = utils . has_old_osinfo ( )
2019-06-10 03:18:13 +03:00
NO_OSINFO_UNATTEND = not unattended . OSInstallScript . have_new_libosinfo ( )
2019-06-05 21:15:23 +03:00
HAS_ISOINFO = shutil . which ( " isoinfo " )
2013-03-18 01:06:52 +04:00
# Images that will be created by virt-install/virt-clone, and removed before
# each run
new_images = [
2018-06-12 19:26:13 +03:00
TMP_IMAGE_DIR + " new1.img " ,
TMP_IMAGE_DIR + " new2.img " ,
TMP_IMAGE_DIR + " new3.img " ,
TMP_IMAGE_DIR + " exist1-clone.img " ,
TMP_IMAGE_DIR + " exist2-clone.img " ,
2013-03-18 01:06:52 +04:00
]
# Images that are expected to exist before a command is run
exist_images = [
2018-06-12 19:26:13 +03:00
TMP_IMAGE_DIR + " exist1.img " ,
TMP_IMAGE_DIR + " exist2.img " ,
2013-03-18 01:06:52 +04:00
]
2015-04-23 00:48:40 +03:00
exist_files = exist_images
2014-09-07 02:05:43 +04:00
new_files = new_images
2019-07-18 00:47:46 +03:00
clean_files = ( new_images + exist_images )
2013-03-18 01:06:52 +04:00
test_files = {
2018-06-12 18:48:11 +03:00
' URI-TEST-FULL ' : utils . URIs . test_full ,
' URI-TEST-REMOTE ' : utils . URIs . test_remote ,
' URI-KVM ' : utils . URIs . kvm ,
' URI-KVM-ARMV7L ' : utils . URIs . kvm_armv7l ,
' URI-KVM-AARCH64 ' : utils . URIs . kvm_aarch64 ,
' URI-KVM-PPC64LE ' : utils . URIs . kvm_ppc64le ,
' URI-KVM-S390X ' : utils . URIs . kvm_s390x ,
2019-04-04 13:49:42 +03:00
' URI-QEMU-RISCV64 ' : utils . URIs . qemu_riscv64 ,
2018-06-12 19:26:13 +03:00
' NEWIMG1 ' : " /dev/default-pool/new1.img " ,
' NEWIMG2 ' : " /dev/default-pool/new2.img " ,
' NEWCLONEIMG1 ' : new_images [ 0 ] ,
' NEWCLONEIMG2 ' : new_images [ 1 ] ,
' NEWCLONEIMG3 ' : new_images [ 2 ] ,
' EXISTIMG1 ' : " /dev/default-pool/testvol1.img " ,
' EXISTIMG2 ' : " /dev/default-pool/testvol2.img " ,
' EXISTIMG3 ' : exist_images [ 0 ] ,
' EXISTIMG4 ' : exist_images [ 1 ] ,
2019-07-18 00:47:46 +03:00
' ISOTREE ' : " %s /fake-fedora17-tree.iso " % XMLDIR ,
' ISOLABEL ' : " %s /fake-centos65-label.iso " % XMLDIR ,
' ISO-NO-OS ' : " %s /fake-no-osinfo.iso " % XMLDIR ,
' ISO-WIN7 ' : " %s /fake-win7.iso " % XMLDIR ,
' ISO-F26-NETINST ' : " %s /fake-f26-netinst.iso " % XMLDIR ,
' ISO-F29-LIVE ' : " %s /fake-f29-live.iso " % XMLDIR ,
2018-06-12 19:26:13 +03:00
' TREEDIR ' : " %s /fakefedoratree " % XMLDIR ,
' COLLIDE ' : " /dev/default-pool/collidevol1.img " ,
2019-07-03 17:01:28 +03:00
' ADMIN-PASSWORD-FILE ' : " %s /admin-password.txt " % XMLDIR ,
' USER-PASSWORD-FILE ' : " %s /user-password.txt " % XMLDIR ,
2013-03-18 01:06:52 +04:00
}
2019-01-30 19:55:40 +03:00
def has_old_osinfo ( ) :
if OLD_OSINFO :
return " osinfo is too old "
2019-02-04 00:18:50 +03:00
def missing_isoinfo ( ) :
2019-01-30 19:55:40 +03:00
if not HAS_ISOINFO :
return " isoinfo not installed "
2019-06-10 03:18:13 +03:00
def no_osinfo_unattend_cb ( ) :
if NO_OSINFO_UNATTEND :
return " osinfo is too old for unattended testing "
2013-03-18 01:06:52 +04:00
######################
# Test class helpers #
######################
2019-05-16 20:18:12 +03:00
class SkipChecks :
"""
Class to track all ' skip ' style checks we might do . All checks
can be callable functions , or version strings to check against libvirt
: param prerun_check : If check resolves , skip before running the command
: param precompare_check : If check resolves , skip after running the command
but before comparing output
: param predefine_check : If check resolves , skip after comparing output
but before defining it
"""
def __init__ ( self , parent_skip_checks ,
precompare_check = None ,
predefine_check = None ,
prerun_check = None ) :
p = parent_skip_checks
self . precompare_check = precompare_check or ( p and p . precompare_check )
self . predefine_check = predefine_check or (
p and p . predefine_check )
self . prerun_check = prerun_check or ( p and p . prerun_check )
def _check ( self , conn , check ) :
if check is None :
return
if callable ( check ) :
msg = check ( )
skip = bool ( msg )
else :
2019-06-07 21:48:59 +03:00
skip = not conn . support . _check_version ( check ) # pylint: disable=protected-access
2019-05-16 20:18:12 +03:00
msg = " Skipping check due to version < %s " % check
if skip :
raise unittest . case . SkipTest ( msg )
def prerun_skip ( self , conn ) :
self . _check ( conn , self . prerun_check )
def precompare_skip ( self , conn ) :
self . _check ( conn , self . precompare_check )
def predefine_skip ( self , conn ) :
self . _check ( conn , self . predefine_check )
2013-03-18 01:06:52 +04:00
class Command ( object ) :
"""
Instance of a single cli command to test
"""
2019-05-16 20:18:12 +03:00
def __init__ ( self , cmd , input_file = None , need_conn = True , grep = None ,
nogrep = None , skip_checks = None , compare_file = None , env = None ,
2019-06-14 19:10:00 +03:00
check_success = True , input_text = None , * * kwargs ) :
2019-05-16 20:18:12 +03:00
# Options that alter what command we run
2013-03-18 01:06:52 +04:00
self . cmdstr = cmd % test_files
app , opts = self . cmdstr . split ( " " , 1 )
2014-01-19 02:01:43 +04:00
self . app = app
2013-03-18 01:06:52 +04:00
self . argv = [ os . path . abspath ( app ) ] + shlex . split ( opts )
2019-05-16 20:18:12 +03:00
self . env = env
self . input_file = input_file
2019-06-14 19:10:00 +03:00
self . input_text = input_text
2019-05-16 20:18:12 +03:00
self . need_conn = need_conn
# Options that alter the results we check for
self . check_success = check_success
self . compare_file = compare_file
self . grep = grep
self . nogrep = nogrep
# Options that determine when we skip tests
self . skip_checks = SkipChecks ( skip_checks , * * kwargs )
2013-03-18 01:06:52 +04:00
2014-01-30 17:50:52 +04:00
def _launch_command ( self , conn ) :
2019-06-17 04:12:39 +03:00
log . debug ( self . cmdstr )
2013-03-18 01:06:52 +04:00
app = self . argv [ 0 ]
2018-12-18 22:20:57 +03:00
oldenv = None
2013-03-18 01:06:52 +04:00
oldstdout = sys . stdout
oldstderr = sys . stderr
2014-01-26 03:16:16 +04:00
oldstdin = sys . stdin
2013-03-18 01:06:52 +04:00
oldargv = sys . argv
try :
2018-12-18 22:20:57 +03:00
if self . env :
oldenv = os . environ . copy ( )
os . environ . update ( self . env )
2018-01-27 22:19:12 +03:00
out = io . StringIO ( )
2017-10-11 14:36:00 +03:00
2013-03-18 01:06:52 +04:00
sys . stdout = out
sys . stderr = out
sys . argv = self . argv
2014-01-26 03:16:16 +04:00
if self . input_file :
2017-05-05 21:19:54 +03:00
sys . stdin = open ( self . input_file )
2019-06-14 19:10:00 +03:00
elif self . input_text :
sys . stdin = io . StringIO ( self . input_text + " \n " )
else :
sys . stdin = io . StringIO ( )
sys . stdin . close ( )
2013-03-18 01:06:52 +04:00
2014-02-09 01:36:45 +04:00
exc = " "
2013-03-18 01:06:52 +04:00
try :
2018-02-14 03:04:08 +03:00
if " virt-install " in app :
2013-03-18 01:06:52 +04:00
ret = virtinstall . main ( conn = conn )
2018-02-14 03:04:08 +03:00
elif " virt-clone " in app :
2013-03-18 01:06:52 +04:00
ret = virtclone . main ( conn = conn )
2018-02-14 03:04:08 +03:00
elif " virt-convert " in app :
2014-02-06 04:09:26 +04:00
ret = virtconvert . main ( conn = conn )
2018-02-14 03:04:08 +03:00
elif " virt-xml " in app :
2014-02-06 04:09:26 +04:00
ret = virtxml . main ( conn = conn )
2017-05-05 19:47:21 +03:00
except SystemExit as sys_e :
2013-03-18 01:06:52 +04:00
ret = sys_e . code
2014-02-09 01:36:45 +04:00
except Exception :
ret = - 1
exc = " \n " + " " . join ( traceback . format_exc ( ) )
2013-03-18 01:06:52 +04:00
if ret != 0 :
ret = - 1
2014-02-09 01:36:45 +04:00
outt = out . getvalue ( ) + exc
2013-03-18 01:06:52 +04:00
if outt . endswith ( " \n " ) :
outt = outt [ : - 1 ]
return ( ret , outt )
finally :
sys . stdout = oldstdout
sys . stderr = oldstderr
2014-01-26 03:16:16 +04:00
sys . stdin = oldstdin
2013-03-18 01:06:52 +04:00
sys . argv = oldargv
2018-12-18 22:20:57 +03:00
if oldenv :
os . environ = oldenv
2013-03-18 01:06:52 +04:00
2014-01-30 17:50:52 +04:00
def _get_output ( self , conn ) :
2013-03-18 01:06:52 +04:00
try :
for i in new_files :
2013-09-29 01:23:23 +04:00
if os . path . isdir ( i ) :
shutil . rmtree ( i )
elif os . path . exists ( i ) :
os . unlink ( i )
2013-03-18 01:06:52 +04:00
2014-01-30 17:50:52 +04:00
code , output = self . _launch_command ( conn )
2013-03-18 01:06:52 +04:00
2019-06-17 04:12:39 +03:00
log . debug ( " %s \n " , output )
2013-03-18 01:06:52 +04:00
return code , output
2017-05-05 19:47:21 +03:00
except Exception as e :
2013-03-18 01:06:52 +04:00
return ( - 1 , " " . join ( traceback . format_exc ( ) ) + str ( e ) )
2019-05-16 20:18:12 +03:00
def _check_compare_file ( self , conn , output ) :
self . skip_checks . precompare_skip ( conn )
2013-08-17 21:50:36 +04:00
2019-05-14 16:54:12 +03:00
# Generate test files that don't exist yet
filename = self . compare_file
if ( utils . clistate . regenerate_output or
not os . path . exists ( filename ) ) :
open ( filename , " w " ) . write ( output )
if " --print-diff " in self . argv and output . count ( " \n " ) > 3 :
# 1) Strip header
# 2) Simplify context lines to reduce churn when
# libvirt or testdriver changes
newlines = [ ]
for line in output . splitlines ( ) [ 3 : ] :
if line . startswith ( " @@ " ) :
line = " @@ "
newlines . append ( line )
output = " \n " . join ( newlines )
utils . diff_compare ( output , filename )
2019-05-16 20:18:12 +03:00
self . skip_checks . predefine_skip ( conn )
2019-05-16 02:41:44 +03:00
2019-05-14 17:09:57 +03:00
# Define the <domain>s generated for compare output, to ensure
# we are generating valid XML
if " --print-xml " in self . argv or " --print-step " in self . argv :
for domxml in output . split ( " </domain> " ) :
if " <domain " not in domxml :
continue
domxml = domxml + " </domain> "
try :
dom = conn . defineXML ( domxml )
dom . undefine ( )
except Exception as e :
raise AssertionError ( " Bad XML: \n %s \n \n Error was: %s : %s " %
( domxml , e . __class__ . __name__ , str ( e ) ) )
2019-05-16 20:18:12 +03:00
def _run ( self ) :
2019-05-14 16:54:12 +03:00
conn = None
for idx in reversed ( range ( len ( self . argv ) ) ) :
if self . argv [ idx ] == " --connect " :
conn = utils . URIs . openconn ( self . argv [ idx + 1 ] )
break
if not conn and self . need_conn :
raise RuntimeError ( " couldn ' t parse URI from command %s " %
self . argv )
2019-05-16 20:18:12 +03:00
self . skip_checks . prerun_skip ( conn )
2019-05-14 16:54:12 +03:00
code , output = self . _get_output ( conn )
def _raise_error ( _msg ) :
raise AssertionError (
( " Command was: %s \n " % self . cmdstr ) +
( " Error code : %d \n " % code ) +
( " Output was: \n %s " % output ) +
( " \n \n \n TESTSUITE: " + _msg + " \n " ) )
if bool ( code ) == self . check_success :
_raise_error ( " Expected command to %s , but it didn ' t. \n " %
( self . check_success and " pass " or " fail " ) )
if self . grep and self . grep not in output :
_raise_error ( " Didn ' t find grep= %s " % self . grep )
if self . nogrep and self . nogrep in output :
_raise_error ( " Found grep= %s when we shouldn ' t see it " %
self . nogrep )
if self . compare_file :
2019-05-16 20:18:12 +03:00
self . _check_compare_file ( conn , output )
2019-05-14 16:54:12 +03:00
2013-08-18 16:59:19 +04:00
def run ( self , tests ) :
2013-03-18 01:06:52 +04:00
err = None
try :
2019-05-16 20:18:12 +03:00
self . _run ( )
2017-05-05 19:47:21 +03:00
except AssertionError as e :
2013-03-18 01:06:52 +04:00
err = self . cmdstr + " \n " + str ( e )
2013-08-18 16:59:19 +04:00
if err :
tests . fail ( err )
2013-03-18 01:06:52 +04:00
2013-08-17 17:44:11 +04:00
class _CategoryProxy ( object ) :
2019-05-16 20:18:12 +03:00
"""
Category of an App . Let ' s us register chunks of suboptions per logical
grouping of tests . So we may have a virt - install ' storage ' group which
specifies default install options like - - pxe but leaves storage
specification up to each individual test .
"""
def __init__ ( self , app , name , default_args , * * kwargs ) :
2013-08-17 17:44:11 +04:00
self . _app = app
self . _name = name
2014-01-30 17:50:52 +04:00
self . default_args = default_args
2019-05-16 20:18:12 +03:00
self . skip_checks = SkipChecks ( self . _app . skip_checks , * * kwargs )
2014-01-30 17:50:52 +04:00
2013-08-17 17:44:11 +04:00
def add_valid ( self , * args , * * kwargs ) :
return self . _app . add_valid ( self . _name , * args , * * kwargs )
def add_invalid ( self , * args , * * kwargs ) :
return self . _app . add_invalid ( self . _name , * args , * * kwargs )
def add_compare ( self , * args , * * kwargs ) :
return self . _app . add_compare ( self . _name , * args , * * kwargs )
2013-04-24 00:16:30 +04:00
class App ( object ) :
2019-05-16 20:18:12 +03:00
"""
Represents a top level app test suite , like virt - install or virt - xml
"""
def __init__ ( self , appname , uri = None , * * kwargs ) :
2013-04-24 00:16:30 +04:00
self . appname = appname
self . categories = { }
self . cmds = [ ]
2019-05-16 20:18:12 +03:00
self . skip_checks = SkipChecks ( None , * * kwargs )
2018-02-20 23:00:46 +03:00
self . uri = uri
2013-04-24 00:16:30 +04:00
2019-06-11 19:23:09 +03:00
def _default_args ( self , cli , iscompare ) :
2013-04-24 00:16:30 +04:00
args = " "
if not iscompare :
args = " --debug "
2014-02-06 04:09:26 +04:00
if " --connect " not in cli :
2018-06-12 19:26:13 +03:00
uri = self . uri or utils . URIs . test_suite
2018-02-20 23:00:46 +03:00
args + = " --connect %s " % uri
2013-04-24 00:16:30 +04:00
if self . appname in [ " virt-install " ] :
if " --ram " not in cli :
args + = " --ram 64 "
2019-06-11 19:23:09 +03:00
if iscompare :
2013-04-24 00:16:30 +04:00
if self . appname == " virt-install " :
2018-02-14 03:04:08 +03:00
if ( " --print-xml " not in cli and
" --print-step " not in cli and
" --quiet " not in cli ) :
2013-04-24 00:16:30 +04:00
args + = " --print-step all "
elif self . appname == " virt-clone " :
2018-02-14 03:04:08 +03:00
if " --print-xml " not in cli :
2013-04-24 00:16:30 +04:00
args + = " --print-xml "
return args
2019-05-16 20:18:12 +03:00
def add_category ( self , catname , default_args , * args , * * kwargs ) :
obj = _CategoryProxy ( self , catname , default_args , * args , * * kwargs )
2014-01-30 17:50:52 +04:00
self . categories [ catname ] = obj
return obj
2019-05-16 20:18:12 +03:00
def _add ( self , catname , testargs , compbase , * * kwargs ) :
2014-01-30 17:50:52 +04:00
category = self . categories [ catname ]
args = category . default_args + " " + testargs
2019-06-11 19:23:09 +03:00
use_default_args = kwargs . pop ( " use_default_args " , True )
if use_default_args :
args = category . default_args + " " + testargs
defargs = self . _default_args ( args , bool ( compbase ) )
args + = " " + defargs
else :
args = testargs
cmdstr = " ./ %s %s " % ( self . appname , args )
2019-05-16 20:18:12 +03:00
kwargs [ " skip_checks " ] = category . skip_checks
if compbase :
2018-06-12 19:26:13 +03:00
compare_XMLDIR = " %s /compare " % XMLDIR
2019-05-16 20:18:12 +03:00
kwargs [ " compare_file " ] = " %s / %s - %s .xml " % (
compare_XMLDIR , os . path . basename ( self . appname ) , compbase )
cmd = Command ( cmdstr , * * kwargs )
2013-04-24 00:16:30 +04:00
self . cmds . append ( cmd )
2013-08-17 21:50:36 +04:00
def add_valid ( self , cat , args , * * kwargs ) :
2019-05-16 20:18:12 +03:00
self . _add ( cat , args , None , check_success = True , * * kwargs )
2013-08-17 21:50:36 +04:00
def add_invalid ( self , cat , args , * * kwargs ) :
2019-05-16 20:18:12 +03:00
self . _add ( cat , args , None , check_success = False , * * kwargs )
def add_compare ( self , cat , args , compbase , * * kwargs ) :
self . _add ( cat , args , compbase ,
check_success = not compbase . endswith ( " -fail " ) ,
* * kwargs )
2013-04-24 00:16:30 +04:00
#
# The test matrix
#
# add_valid: A test that should pass
# add_invalid: A test that should fail
# add_compare: Get the generated XML, and compare against the passed filename
# in tests/clitest-xml/compare/
#
2014-12-10 17:33:02 +03:00
######################
# virt-install tests #
######################
2013-08-17 17:44:11 +04:00
2014-12-10 17:33:02 +03:00
vinst = App ( " virt-install " )
2013-08-17 17:44:11 +04:00
2014-12-10 17:33:02 +03:00
#############################################
# virt-install verbose XML comparison tests #
#############################################
2019-05-16 20:18:12 +03:00
c = vinst . add_category ( " xml-comparsion " , " --connect % (URI-KVM)s --noautoconsole --os-variant fedora-unknown " , prerun_check = has_old_osinfo )
2014-12-10 17:33:02 +03:00
# Singleton element test #1, for simpler strings
2019-05-14 18:25:52 +03:00
c . add_compare ( """
- - memory 1024
2019-06-11 01:13:31 +03:00
- - uuid 12345678 - 12 F4 - 1234 - 1234 - 123456789 AFA
2019-05-14 18:25:52 +03:00
- - vcpus 4 , cores = 2 , threads = 2 , sockets = 2 - - cpuset = 1 , 3 - 5
- - cpu host - copy
- - description \" foobar & baz \"
2019-05-14 20:43:56 +03:00
- - boot uefi , smbios_mode = emulate , boot1 . dev = hd , boot . dev = network , initarg1 = bar = baz , initarg = foo
2019-05-16 00:49:58 +03:00
- - seclabel type = dynamic
2019-05-14 18:25:52 +03:00
- - security type = none , model = dac
- - numatune 1 , 2 , 3 , 5 - 7 , ^ 6
- - memorybacking hugepages = on
- - features apic = off
- - clock offset = localtime
- - resource / virtualmachines / production
- - events on_crash = restart
2019-05-14 21:26:19 +03:00
- - metadata genid_enable = yes
2019-07-02 21:07:16 +03:00
- - sysinfo host
2019-05-14 18:25:52 +03:00
- - disk none
- - console none
- - channel none
- - network none
- - controller usb2
- - graphics spice
- - video vga
- - sound none
- - redirdev none
- - memballoon none
- - smartcard none
- - watchdog default
- - tpm / dev / tpm0
- - rng / dev / random
2019-06-09 23:39:15 +03:00
- - vsock default
2018-09-01 01:28:08 +03:00
""" , " singleton-config-1 " )
2014-12-10 17:33:02 +03:00
# Singleton element test #2, for complex strings
2019-05-14 18:25:52 +03:00
c . add_compare ( """ --pxe
- - memory 512 , maxmemory = 1024
- - vcpus 9
2019-05-15 23:14:33 +03:00
- - cpu foobar , + x2apic , + x2apicagain , - distest , forbid = foo , forbid = bar , disable = distest2 , optional = opttest , require = reqtest , match = strict , vendor = meee , mode = custom , \
virtinst: Add NUMA distance support
Now that libvirt has support for administration of distances between NUMA cells
it would be nice to be able to set those with virt-install directly instead of
having to 'virsh edit' the domain XML manually after installation.
For example
--cpu cell0.memory=1234,cell0.cpus=0-3,cell1.memory=5678,cell1.cpus=4-7,\
cell0.distances.sibling0.id=0,cell0.distances.sibling0.value=10,\
cell0.distances.sibling1.id=1,cell0.distances.sibling1.value=21,\
cell1.distances.sibling0.id=0,cell1.distances.sibling0.value=21,\
cell1.distances.sibling1.id=1,cell1.distances.sibling1.value=10
would generate the following XML:
<cpu>
<numa>
<cell cpus="0-3" memory="1234">
<distances>
<sibling id="0" value="10"/>
<sibling id="1" value="21"/>
</distances>
</cell>
<cell cpus="4-7" memory="5678">
<distances>
<sibling id="0" value="21"/>
<sibling id="1" value="10"/>
</distances>
</cell>
</numa>
</cpu>
Signed-off-by: Menno Lageman <menno.lageman@oracle.com>
(crobinso: rework cli format, drop some validation, drop man changes)
2018-01-22 15:36:00 +03:00
cell . id = 0 , cell . cpus = 1 , 2 , 3 , cell . memory = 1024 , \
cell1 . id = 1 , cell1 . memory = 256 , cell1 . cpus = 5 - 8 , \
2019-05-14 22:45:16 +03:00
numa . cell2 . id = 2 , numa . cell2 . memory = 256 , numa . cell2 . cpus = 4 , \
virtinst: Add NUMA distance support
Now that libvirt has support for administration of distances between NUMA cells
it would be nice to be able to set those with virt-install directly instead of
having to 'virsh edit' the domain XML manually after installation.
For example
--cpu cell0.memory=1234,cell0.cpus=0-3,cell1.memory=5678,cell1.cpus=4-7,\
cell0.distances.sibling0.id=0,cell0.distances.sibling0.value=10,\
cell0.distances.sibling1.id=1,cell0.distances.sibling1.value=21,\
cell1.distances.sibling0.id=0,cell1.distances.sibling0.value=21,\
cell1.distances.sibling1.id=1,cell1.distances.sibling1.value=10
would generate the following XML:
<cpu>
<numa>
<cell cpus="0-3" memory="1234">
<distances>
<sibling id="0" value="10"/>
<sibling id="1" value="21"/>
</distances>
</cell>
<cell cpus="4-7" memory="5678">
<distances>
<sibling id="0" value="21"/>
<sibling id="1" value="10"/>
</distances>
</cell>
</numa>
</cpu>
Signed-off-by: Menno Lageman <menno.lageman@oracle.com>
(crobinso: rework cli format, drop some validation, drop man changes)
2018-01-22 15:36:00 +03:00
cell0 . distances . sibling0 . id = 0 , cell0 . distances . sibling0 . value = 10 , \
cell0 . distances . sibling1 . id = 1 , cell0 . distances . sibling1 . value = 21 , \
2019-05-15 23:14:33 +03:00
numa . cell1 . distances . sibling0 . id = 0 , numa . cell1 . distances . sibling0 . value = 21 , \
virtinst: Add NUMA distance support
Now that libvirt has support for administration of distances between NUMA cells
it would be nice to be able to set those with virt-install directly instead of
having to 'virsh edit' the domain XML manually after installation.
For example
--cpu cell0.memory=1234,cell0.cpus=0-3,cell1.memory=5678,cell1.cpus=4-7,\
cell0.distances.sibling0.id=0,cell0.distances.sibling0.value=10,\
cell0.distances.sibling1.id=1,cell0.distances.sibling1.value=21,\
cell1.distances.sibling0.id=0,cell1.distances.sibling0.value=21,\
cell1.distances.sibling1.id=1,cell1.distances.sibling1.value=10
would generate the following XML:
<cpu>
<numa>
<cell cpus="0-3" memory="1234">
<distances>
<sibling id="0" value="10"/>
<sibling id="1" value="21"/>
</distances>
</cell>
<cell cpus="4-7" memory="5678">
<distances>
<sibling id="0" value="21"/>
<sibling id="1" value="10"/>
</distances>
</cell>
</numa>
</cpu>
Signed-off-by: Menno Lageman <menno.lageman@oracle.com>
(crobinso: rework cli format, drop some validation, drop man changes)
2018-01-22 15:36:00 +03:00
cell1 . distances . sibling1 . id = 1 , cell1 . distances . sibling1 . value = 10 , \
2019-05-14 18:25:52 +03:00
cache . mode = emulate , cache . level = 3
- - cputune vcpupin0 . vcpu = 0 , vcpupin0 . cpuset = 0 - 3
2019-06-04 18:42:59 +03:00
- - iothreads iothreads = 2 , iothreadids . iothread1 . id = 1 , iothreadids . iothread2 . id = 2
2019-05-14 21:26:19 +03:00
- - metadata title = my - title , description = my - description , uuid = 00000000 - 1111 - 2222 - 3333 - 444444444444 , genid = e9392370 - 2917 - 565e-692 b - d057f46512d6
2019-06-17 00:15:08 +03:00
- - boot cdrom , fd , hd , network , menu = off , loader = / foo / bar , emulator = / new / emu , bootloader = / new / bootld , rebootTimeout = 3 , initargs = " foo=bar baz=woo " , firmware = efi
2019-05-14 18:25:52 +03:00
- - idmap uid_start = 0 , uid_target = 1000 , uid_count = 10 , gid_start = 0 , gid_target = 1000 , gid_count = 10
2019-05-16 00:49:58 +03:00
- - seclabel type = static , label = ' system_u:object_r:svirt_image_t:s0:c100,c200 ' , relabel = yes , baselabel = baselabel
2019-06-09 23:39:15 +03:00
- - seclabel type = dynamic , label = 012 : 345
2019-07-21 16:37:37 +03:00
- - keywrap cipher0 . name = aes , cipher0 . state = on
2019-06-17 22:32:54 +03:00
- - numatune 1 - 3 , 4 , mode = strict , \
memnode0 . cellid = 1 , memnode0 . mode = strict , memnode0 . nodeset = 2
2019-05-14 18:25:52 +03:00
- - memtune hard_limit = 10 , soft_limit = 20 , swap_hard_limit = 30 , min_guarantee = 40
- - blkiotune weight = 100 , device_path = / home / test / 1. img , device_weight = 200
2019-05-16 18:29:12 +03:00
- - memorybacking size = 1 , unit = ' G ' , nodeset = 0 , 1 , nosharepages = yes , locked = yes , discard = yes , allocation . mode = immediate , access_mode = shared , source_type = file , hugepages . page . size = 12 , hugepages . page1 . size = 1234 , hugepages . page1 . unit = MB , hugepages . page1 . nodeset = 2
2019-05-15 23:31:45 +03:00
- - features acpi = off , eoi = on , privnet = on , hyperv_synic = on , hyperv_reset = on , hyperv_spinlocks = on , hyperv_spinlocks_retries = 5678 , vmport = off , pmu = off , vmcoreinfo = on , kvm_hidden = off , hyperv_vapic = on
2019-07-14 14:49:16 +03:00
- - clock offset = utc , hpet_present = no , rtc_tickpolicy = merge , timer2 . name = hypervclock , timer3 . name = pit , timer1 . present = yes , timer3 . tickpolicy = delay , timer2 . present = no , timer4 . name = rtc , timer5 . name = tsc , timer6 . name = tsc , timer4 . track = wall , timer5 . frequency = 10 , timer6 . mode = emulate
2019-05-14 18:25:52 +03:00
- - sysinfo type = smbios , bios_vendor = " Acme LLC " , bios_version = 1.2 .3 , bios_date = 01 / 01 / 1970 , bios_release = 10.22
- - sysinfo type = smbios , system_manufacturer = " Acme Inc. " , system_product = Computer , system_version = 3.2 .1 , system_serial = 123456789 , system_uuid = 00000000 - 1111 - 2222 - 3333 - 444444444444 , system_sku = abc - 123 , system_family = Server
- - sysinfo type = smbios , baseBoard_manufacturer = " Acme Corp. " , baseBoard_product = Motherboard , baseBoard_version = A01 , baseBoard_serial = 1234 - 5678 , baseBoard_asset = Tag , baseBoard_location = Chassis
2019-05-14 21:05:08 +03:00
- - sysinfo type = smbios , chassis . manufacturer = " Chassis Corp. " , chassis . serial = 1234 chassis , chassis . asset = chasset , chassis . sku = chassku , chassis . version = 4.0
2019-05-14 21:16:14 +03:00
- - sysinfo type = smbios , oemStrings . entry2 = " complicated parsing, foo=bar " , oemStrings . entry1 = test1 , oemStrings . entry0 = test0
2019-05-14 18:25:52 +03:00
- - pm suspend_to_mem = yes , suspend_to_disk = no
- - resource partition = / virtualmachines / production
- - events on_poweroff = destroy , on_reboot = restart , on_crash = preserve , on_lockfailure = ignore
- - controller usb3
- - controller scsi , model = virtio - scsi
- - graphics vnc
- - filesystem / foo / source , / bar / target
2019-05-28 19:53:45 +03:00
- - memballoon virtio , autodeflate = on , stats . period = 10
2019-05-14 18:25:52 +03:00
- - watchdog ib700 , action = pause
- - tpm passthrough , model = tpm - crb , path = / dev / tpm0
2019-05-16 00:21:26 +03:00
- - rng egd , backend_host = 127.0 .0 .1 , backend_service = 8000 , backend_type = udp , backend_mode = bind , backend_connect_host = foo , backend_connect_service = 708 , rate . bytes = 1234 , rate . period = 1000 , model = virtio
2019-05-14 18:25:52 +03:00
- - panic iobase = 0x506
2014-12-10 17:33:02 +03:00
""" , " singleton-config-2 " )
2019-05-15 22:31:43 +03:00
# Test the implied defaults for gl=yes setting virgl=on
c . add_compare ( """
2019-07-02 21:07:16 +03:00
- - vcpus vcpu . current = 3 , maxvcpus = 4 , vcpu . placement = auto
2019-05-15 23:41:29 +03:00
- - memory hotplugmemorymax = 2048 , hotplugmemoryslots = 2
2019-05-15 22:31:43 +03:00
- - disk none
2019-05-15 23:31:45 +03:00
- - features apic . eoi = off , hap = on , hyperv . synic . state = on , hyperv . reset . state = off , hyperv . spinlocks . state = on , hyperv . spinlocks . retries = 5678 , pae = on , pmu . state = on , pvspinlock . state = off , smm . state = off , viridian = on , vmcoreinfo . state = on , vmport . state = off , kvm . hidden . state = on , hyperv . vapic . state = off , hyperv . relaxed . state = off , gic . version = host
2019-05-15 23:08:28 +03:00
- - clock rtc_present = no , pit_present = yes , pit_tickpolicy = catchup , tsc_present = no , platform_present = no , hypervclock_present = no , platform_tickpolicy = foo , hpet_tickpolicy = bar , tsc_tickpolicy = wibble , kvmclock_tickpolicy = wobble , hypervclock_tickpolicy = woo
2019-05-15 22:46:08 +03:00
- - boot bios . useserial = no , bios . rebootTimeout = 60 , cmdline = root = / foo , smbios . mode = host , bootmenu . enable = yes , loader_ro = yes , loader . type = rom , loader = / tmp / foo
2019-05-15 23:01:38 +03:00
- - memorybacking access . mode = shared , source . type = anonymous , hugepages = on
2019-05-15 22:31:43 +03:00
- - graphics spice , gl = yes
2019-05-16 00:21:26 +03:00
- - rng type = egd , backend . type = nmdm , backend . source . master = / dev / foo1 , backend . source . slave = / dev / foo2
2019-05-15 22:31:43 +03:00
- - panic default , , address . type = isa , address . iobase = 0x500 , address . irq = 5
2019-05-15 23:41:29 +03:00
- - cpu topology . sockets = 1 , topology . cores = 3 , topology . threads = 2 , cell0 . cpus = 0 , cell0 . memory = 1048576
- - memdev dimm , access = private , target . size = 512 , target . node = 0 , source . pagesize = 4 , source . nodemask = 1 - 2
2019-05-16 00:30:21 +03:00
- - memdev nvdimm , source . path = / path / to / nvdimm , target . size = 512 , target . node = 0 , target . label_size = 128 , alias . name = mymemdev3 , address . type = dimm , address . base = 0x100000000 , address . slot = 1
2019-05-15 22:54:28 +03:00
- - vsock auto_cid = on
2019-06-09 23:39:15 +03:00
- - memballoon default
2019-05-15 23:43:43 +03:00
- - sysinfo bios . vendor = " Acme LLC " , bios . version = 1.2 .3 , bios . date = 01 / 01 / 1970 , bios . release = 10.22 , system . manufacturer = " Acme Inc. " , system . product = Computer , system . version = 3.2 .1 , system . serial = 123456789 , system . uuid = 00000000 - 1111 - 2222 - 3333 - 444444444444 , system . sku = abc - 123 , system . family = Server , baseBoard . manufacturer = " Acme Corp. " , baseBoard . product = Motherboard , baseBoard . version = A01 , baseBoard . serial = 1234 - 5678 , baseBoard . asset = Tag , baseBoard . location = Chassis
2019-05-16 20:18:12 +03:00
""" , " singleton-config-3 " , predefine_check= " 5.3.0 " )
2019-05-15 22:31:43 +03:00
2014-12-10 17:33:02 +03:00
2019-05-14 18:25:52 +03:00
c . add_compare ( """
2019-05-15 23:53:55 +03:00
- - vcpus vcpus = 4 , cores = 1 , placement = static , \
2019-05-14 22:18:49 +03:00
vcpus . vcpu2 . id = 0 , vcpus . vcpu2 . enabled = no , \
vcpus . vcpu3 . id = 1 , vcpus . vcpu3 . hotpluggable = no , vcpus . vcpu3 . enabled = yes , \
vcpus . vcpu . id = 3 , vcpus . vcpu0 . enabled = yes , vcpus . vcpu0 . order = 3 , \
vcpus . vcpu1 . id = 2 , vcpus . vcpu1 . enabled = yes
2019-05-14 18:25:52 +03:00
- - cpu none
2019-05-17 18:26:02 +03:00
- - disk / dev / default - pool / UPPER , cache = writeback , io = threads , perms = sh , serial = WD - WMAP9A966149 , wwn = 123456789 abcdefa , boot_order = 2
2019-05-16 00:30:21 +03:00
- - disk % ( NEWIMG1 ) s , sparse = false , size = .001 , perms = ro , error_policy = enospace , discard = unmap , detect_zeroes = unmap , address . type = drive , address . controller = 0 , address . target = 2 , address . unit = 0
2019-05-14 18:25:52 +03:00
- - disk device = cdrom , bus = sata , read_bytes_sec = 1 , read_iops_sec = 2 , write_bytes_sec = 5 , write_iops_sec = 6 , driver . copy_on_read = on , geometry . cyls = 16383 , geometry . heads = 16 , geometry . secs = 63 , geometry . trans = lba
- - disk size = 1
2019-05-20 14:43:34 +03:00
- - disk / iscsi - pool / diskvol1 , total_bytes_sec = 10 , total_iops_sec = 20 , bus = scsi , device = lun , sgio = unfiltered , rawio = yes
2019-05-15 23:26:23 +03:00
- - disk / dev / default - pool / iso - vol , seclabel . model = dac , seclabel1 . model = selinux , seclabel1 . relabel = no , seclabel0 . label = foo , bar , baz , iotune . read_bytes_sec = 1 , iotune . read_iops_sec = 2 , iotune . write_bytes_sec = 5 , iotune . write_iops_sec = 6
- - disk / dev / default - pool / iso - vol , format = qcow2 , startup_policy = optional , iotune . total_bytes_sec = 10 , iotune . total_iops_sec = 20 ,
2019-05-14 18:25:52 +03:00
- - disk source_pool = rbd - ceph , source_volume = some - rbd - vol , size = .1 , driver_type = raw
2019-05-15 23:26:23 +03:00
- - disk pool = rbd - ceph , size = .1 , driver . name = qemu , driver . type = raw , driver . discard = unmap , driver . detect_zeroes = unmap , driver . io = native , driver . error_policy = stop
2019-05-14 18:25:52 +03:00
- - disk source_protocol = http , source_host_name = example . com , source_host_port = 8000 , source_name = / path / to / my / file
2019-05-15 23:26:23 +03:00
- - disk source . protocol = http , source . host0 . name = exampl2 . com , source . host . port = 8000 , source . name = / path / to / my / file
- - disk source . protocol = nbd , source . host . transport = unix , source . host . socket = / tmp / socket
- - disk source . protocol = nbd , source_host_transport = unix , source_host_socket = / tmp / socket , bus = scsi , logical_block_size = 512 , physical_block_size = 512 , blockio . logical_block_size = 512 , blockio . physical_block_size = 512 , target . dev = sdz
2019-05-14 18:25:52 +03:00
- - disk gluster : / / 192.168 .1 .100 / test - volume / some / dir / test - gluster . qcow2
2019-05-16 00:30:21 +03:00
- - disk nbd + unix : / / / var / foo / bar / socket , bus = usb , removable = on , address . type = usb , address . bus = 0 , address . port = 2
2019-05-14 18:25:52 +03:00
- - disk path = http : / / [ 1 : 2 : 3 : 4 : 1 : 2 : 3 : 4 ] : 5522 / my / path ? query = foo
- - disk vol = gluster - pool / test - gluster . raw
2019-07-02 21:07:16 +03:00
- - disk / var , device = floppy , snapshot = no , perms = rw
2019-05-15 23:26:23 +03:00
- - disk % ( NEWIMG2 ) s , size = 1 , backing_store = / tmp / foo . img , backing_format = vmdk , bus = usb , target . removable = yes
2019-05-14 19:33:07 +03:00
- - disk / tmp / brand - new . img , size = 1 , backing_store = / dev / default - pool / iso - vol , boot . order = 10 , boot . loadparm = 5
2019-05-15 23:26:23 +03:00
- - disk path = / dev / disk - pool / diskvol7 , device = lun , bus = scsi , reservations . managed = no , reservations . source . type = unix , reservations . source . path = / var / run / test / pr - helper0 . sock , reservations . source . mode = client , \
source . reservations . managed = no , source . reservations . source . type = unix , source . reservations . source . path = / var / run / test / pr - helper0 . sock , source . reservations . source . mode = client
2019-06-15 03:35:41 +03:00
- - disk vol = iscsi - direct / unit : 0 : 0 : 1
2019-07-03 02:38:09 +03:00
- - disk size = .0001 , format = raw
2019-05-14 18:25:52 +03:00
- - network user , mac = 12 : 34 : 56 : 78 : 11 : 22 , portgroup = foo , link_state = down , rom_bar = on , rom_file = / tmp / foo
2019-05-15 23:51:46 +03:00
- - network bridge = foobar , model = virtio , driver_name = qemu , driver_queues = 3 , filterref = foobar , rom . bar = off , rom . file = / some / rom , source . portgroup = foo
- - network bridge = ovsbr , virtualport . type = openvswitch , virtualport_profileid = demo , virtualport_interfaceid = 09 b11c53 - 8 b5c - 4 eeb - 8 f00 - d84eaa0aaa3b , link . state = yes , driver . name = qemu , driver . queues = 3 , filterref . filter = filterbar , target . dev = mytargetname , virtualport . parameters . profileid = demo , virtualport . parameters . interfaceid = 09 b11c53 - 8 b5c - 4 eeb - 8 f00 - d84eaa0aaa3b
- - network type = direct , source = eth5 , source_mode = vepa , source . mode = vepa , target = mytap12 , virtualport_type = 802.1 Qbg , virtualport_managerid = 12 , virtualport_typeid = 1193046 , virtualport_typeidversion = 1 , virtualport_instanceid = 09 b11c53 - 8 b5c - 4 eeb - 8 f00 - d84eaa0aaa3b , boot_order = 1 , trustGuestRxFilters = yes , mtu . size = 1500 , virtualport . parameters . managerid = 12 , virtualport . parameters . typeid = 1193046 , virtualport . parameters . typeidversion = 1 , virtualport . parameters . instanceid = 09 b11c53 - 8 b5c - 4 eeb - 8 f00 - d84eaa0aaa3b , boot_order = 1 , trustGuestRxFilters = yes , mtu . size = 1500
2019-07-02 21:07:16 +03:00
- - network user , model = virtio , address . type = spapr - vio , address . reg = 0x500 , link . state = no
2019-05-16 00:30:21 +03:00
- - network vhostuser , source_type = unix , source_path = / tmp / vhost1 . sock , source_mode = server , model = virtio , source . type = unix , source . path = / tmp / vhost1 . sock , address . type = pci , address . bus = 0x00 , address . slot = 0x10 , address . function = 0x0 , address . domain = 0x0000
2019-05-14 19:33:07 +03:00
- - network user , address . type = ccw , address . cssid = 0xfe , address . ssid = 0 , address . devno = 01 , boot . order = 15 , boot . loadparm = SYSTEM1
2019-05-14 18:25:52 +03:00
- - graphics sdl
- - graphics spice , keymap = none
- - graphics vnc , port = 5950 , listen = 1.2 .3 .4 , keymap = ja , password = foo
- - graphics spice , port = 5950 , tlsport = 5950 , listen = 1.2 .3 .4 , keymap = ja
2019-05-16 17:21:19 +03:00
- - graphics spice , image_compression = glz , streaming_mode = filter , clipboard_copypaste = yes , mouse_mode = client , filetransfer_enable = on , zlib . compression = always
2019-05-15 23:37:50 +03:00
- - graphics spice , gl = yes , listen = socket , image . compression = glz , streaming . mode = filter , clipboard . copypaste = yes , mouse . mode = client , filetransfer . enable = on , tlsPort = 6000 , passwd = testpass , passwdValidTo = 2010 - 04 - 09 T15 : 51 : 00 , passwordValidTo = 2010 - 04 - 09 T15 : 51 : 01 , defaultMode = insecure
2019-05-14 18:25:52 +03:00
- - graphics spice , gl = yes , listen = none
2019-05-15 23:37:50 +03:00
- - graphics spice , gl . enable = yes , listen = none , rendernode = / dev / dri / foo , gl . rendernode = / dev / dri / foo2
- - graphics spice , listens0 . type = address , listens0 . address = 1.2 .3 .4 , connected = disconnect
2019-05-14 18:25:52 +03:00
- - graphics spice , listens0 . type = network , listens0 . network = default
- - graphics spice , listens0 . type = socket , listens0 . socket = / tmp / foobar
- - controller usb , model = ich9 - ehci1 , address = 0 : 0 : 4.7 , index = 0
- - controller usb , model = ich9 - uhci1 , address = 0 : 0 : 4.0 , index = 0 , master = 0 , address . multifunction = on
2019-05-15 23:13:38 +03:00
- - controller usb , model = ich9 - uhci2 , address = 0 : 0 : 4.1 , index = 0 , master . startport = 2
2019-05-14 18:25:52 +03:00
- - controller usb , model = ich9 - uhci3 , address = 0 : 0 : 4.2 , index = 0 , master = 4
2019-07-02 21:07:16 +03:00
- - controller scsi , , model = virtio - scsi , driver_queues = 4 , driver . queues = 4
2019-05-14 18:25:52 +03:00
- - controller xenbus , maxGrantFrames = 64
- - input type = keyboard , bus = usb
- - input tablet
2019-06-09 23:39:15 +03:00
- - input mouse
2019-05-14 18:25:52 +03:00
2019-05-15 21:43:37 +03:00
- - serial tcp , host = : 2222 , mode = bind , protocol = telnet , log . file = / tmp / foo . log , log . append = yes , , target . model . name = pci - serial
2019-05-14 19:25:00 +03:00
- - serial nmdm , source . master = / dev / foo1 , source . slave = / dev / foo2 , alias . name = testalias7
2019-05-14 18:25:52 +03:00
- - parallel udp , host = 0.0 .0 .0 : 1234 , bind_host = 127.0 .0 .1 : 1234
2019-05-16 00:24:58 +03:00
- - parallel udp , source . connect_host = 127.0 .0 .2 , source . connect_service = 8888 , source . bind_host = 127.0 .0 .1 , source . bind_service = 7777
2019-05-14 18:25:52 +03:00
- - parallel unix , path = / tmp / foo - socket , source . seclabel0 . model = none , source . seclabel1 . model = dac , source . seclabel1 . relabel = yes , source . seclabel1 . label = foobar , source . seclabel . relabel = no
- - channel pty , target_type = guestfwd , target_address = 127.0 .0 .1 : 10000
2019-05-16 00:24:58 +03:00
- - channel pty , target_type = guestfwd , target . address = 127.0 .0 .1 , target . port = 1234
2019-05-14 18:25:52 +03:00
- - channel pty , target_type = virtio , name = org . linux - kvm . port1
2019-05-16 00:24:58 +03:00
- - channel pty , target . type = virtio , target . name = org . linux - kvm . port2
2019-05-14 18:25:52 +03:00
- - console pty , target_type = virtio
- - channel spicevmc
- - hostdev net_00_1c_25_10_b1_e4 , boot_order = 4 , rom_bar = off
- - host - device usb_device_781_5151_2004453082054CA1BEEE
- - host - device 001.003
- - hostdev 15 : 0.1
- - host - device 2 : 15 : 0.2
2019-05-14 19:20:53 +03:00
- - hostdev 0 : 15 : 0.3 , address . type = pci , address . zpci . uid = 0xffff , address . zpci . fid = 0xffffffff
2019-05-14 18:25:52 +03:00
- - host - device 0x0781 : 0x5151 , driver_name = vfio
- - host - device 04 b3 : 4485
2019-05-15 23:03:26 +03:00
- - host - device pci_8086_2829_scsi_host_scsi_device_lun0 , rom . bar = on
2019-05-14 18:25:52 +03:00
- - hostdev usb_5_20 - - hostdev usb_5_21
2019-07-02 20:01:12 +03:00
- - hostdev wlan0 , type = net
- - hostdev / dev / vdz , type = storage
- - hostdev / dev / pty7 , type = misc
2019-05-14 18:25:52 +03:00
2019-05-14 19:45:57 +03:00
- - filesystem / source , / target , alias . name = testfsalias , driver . ats = on , driver . iommu = off
2019-05-14 18:25:52 +03:00
- - filesystem template_name , / , type = template , mode = passthrough
- - filesystem type = file , source = / tmp / somefile . img , target = / mount / point , accessmode = squash
- - soundhw default
- - sound ac97
- - sound codec0 . type = micro , codec1 . type = duplex , codec2 . type = output
- - video cirrus
- - video model = qxl , vgamem = 1 , ram = 2 , vram = 3 , heads = 4 , accel3d = yes , vram64 = 65
2019-05-15 23:53:55 +03:00
- - video model = qxl , model . vgamem = 1 , model . ram = 2 , model . vram = 3 , model . heads = 4 , model . acceleration . accel3d = yes , model . vram64 = 65
2019-05-14 18:25:52 +03:00
- - smartcard passthrough , type = spicevmc
- - smartcard mode = host
- - smartcard default
2019-05-13 23:17:08 +03:00
- - smartcard passthrough , type = tcp , source . mode = bind , source . host = 1.2 .3 .4 , source . service = 5678 , protocol . type = telnet
2019-05-14 18:25:52 +03:00
- - smartcard host - certificates , type = spicevmc , database = / fake / path / to / database , certificate0 = / path / to / fake / cert0 , certificate1 = / path / to / fake / cert1 , certificate2 = / path / to / fake / cert2
- - redirdev usb , type = spicevmc
- - redirdev usb , type = tcp , server = localhost : 4000
- - redirdev usb , type = tcp , server = 127.0 .0 .1 : 4002 , boot_order = 3
- - redirdev default
2019-05-13 23:17:08 +03:00
- - redirdev type = unix , source . path = / tmp / foo . socket , log . file = / tmp / 123. log
2019-05-14 18:25:52 +03:00
2019-05-16 00:21:26 +03:00
- - rng device = / dev / urandom , backend . protocol . type = , backend . log . file = , backend . log . append =
2019-05-14 18:25:52 +03:00
- - panic iobase = 507
- - vsock cid = 17
- - tpm emulator , model = tpm - crb , version = 2.0
- - qemu - commandline env = DISPLAY = : 0.1
- - qemu - commandline = " -display gtk,gl=on "
- - qemu - commandline = " -device vfio-pci,addr=05.0,sysfsdev=/sys/class/mdev_bus/0000:00:02.0/f321853c-c584-4a6b-b99a-3eee22a3919c "
- - qemu - commandline = " -set device.video0.driver=virtio-vga "
2019-07-02 21:07:16 +03:00
- - qemu - commandline args = " -foo bar "
2019-05-16 20:18:12 +03:00
""" , " many-devices " , predefine_check= " 5.3.0 " )
2013-08-17 17:44:11 +04:00
2016-03-04 14:31:53 +03:00
2017-01-26 17:08:36 +03:00
2017-01-26 18:11:31 +03:00
########################
# Boot install options #
########################
c = vinst . add_category ( " boot " , " --nographics --noautoconsole --import --disk none --controller usb,model=none " )
c . add_compare ( " --boot loader=/path/to/loader,loader_secure=yes " , " boot-loader-secure " )
2017-05-04 14:08:14 +03:00
2013-08-17 17:44:11 +04:00
2014-12-10 17:33:02 +03:00
####################################################
# CPU/RAM/numa and other singleton VM config tests #
####################################################
2013-08-17 17:44:11 +04:00
2014-12-10 17:33:02 +03:00
c = vinst . add_category ( " cpuram " , " --hvm --nographics --noautoconsole --nodisks --pxe " )
c . add_valid ( " --ram 4000000 " ) # Ram overcommit
c . add_valid ( " --vcpus sockets=2,threads=2 " ) # Topology only
2019-07-12 23:10:39 +03:00
c . add_valid ( " --cpuset 1,2,3 " ) # cpuset backcompat with no --vcpus specified
2014-12-10 17:33:02 +03:00
c . add_valid ( " --cpu somemodel " ) # Simple --cpu
2019-06-13 21:47:08 +03:00
c . add_valid ( " --noapic --noacpi " ) # feature backcompat
2014-12-10 17:33:02 +03:00
c . add_valid ( " --security label=foobar.label,relabel=yes " ) # --security implicit static
c . add_valid ( " --security label=foobar.label,a1,z2,b3,type=static,relabel=no " ) # static with commas 1
c . add_valid ( " --security label=foobar.label,a1,z2,b3 " ) # --security static with commas 2
c . add_invalid ( " --clock foo_tickpolicy=merge " ) # Unknown timer
c . add_invalid ( " --security foobar " ) # Busted --security
2018-02-23 02:21:51 +03:00
c . add_compare ( " --cpuset auto --vcpus 2 " , " cpuset-auto " ) # --cpuset=auto actually works
2019-05-16 20:18:12 +03:00
c . add_compare ( " --memory hotplugmemorymax=2048,hotplugmemoryslots=2 --cpu cell0.cpus=0,cell0.memory=1048576 --memdev dimm,access=private,target_size=512,target_node=0,source_pagesize=4,source_nodemask=1-2 --memdev nvdimm,source_path=/path/to/nvdimm,target_size=512,target_node=0,target_label_size=128,alias.name=mymemdev3 " , " memory-hotplug " , precompare_check = " 5.3.0 " )
c . add_compare ( " --memory currentMemory=100,memory=200,maxmemory=300,maxMemory=400,maxMemory.slots=1 " , " memory-option-backcompat " , precompare_check = " 5.3.0 " )
2019-03-29 12:59:25 +03:00
c . add_compare ( " --connect " + utils . URIs . kvm_q35 + " --cpu qemu64,secure=off " , " cpu-disable-sec " ) # disable security features that are added by default
2019-05-16 20:18:12 +03:00
c . add_compare ( " --connect " + utils . URIs . kvm_rhel , " cpu-rhel7-default " , precompare_check = " 5.1.0 " ) # default CPU for old QEMU where we cannot use host-model
2013-08-17 17:44:11 +04:00
2014-12-10 17:33:02 +03:00
########################
# Storage provisioning #
########################
2013-08-17 17:44:11 +04:00
c = vinst . add_category ( " storage " , " --pxe --nographics --noautoconsole --hvm " )
c . add_valid ( " --disk path= %(EXISTIMG1)s " ) # Existing disk, no extra options
2018-06-12 19:26:13 +03:00
c . add_valid ( " --disk pool=default-pool,size=.0001 --disk pool=default-pool,size=.0001 " ) # Create 2 volumes in a pool
c . add_valid ( " --disk vol=default-pool/testvol1.img " ) # Existing volume
2013-08-17 17:44:11 +04:00
c . add_valid ( " --disk path= %(EXISTIMG1)s --disk path= %(EXISTIMG1)s --disk path= %(EXISTIMG1)s --disk path= %(EXISTIMG1)s ,device=cdrom " ) # 3 IDE and CD
2014-12-10 17:33:02 +03:00
c . add_valid ( " --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi --disk path= %(EXISTIMG1)s ,bus=scsi " ) # > 16 scsi disks
2018-06-12 19:26:13 +03:00
c . add_valid ( " --disk path= %(NEWIMG1)s ,format=raw,size=.0000001 " ) # Managed file using format raw
c . add_valid ( " --disk path= %(NEWIMG1)s ,format=qcow2,size=.0000001 " ) # Managed file using format qcow2
2013-08-17 17:44:11 +04:00
c . add_valid ( " --disk %(EXISTIMG1)s " ) # Not specifying path=
c . add_valid ( " --disk %(NEWIMG1)s ,format=raw,size=.0000001 " ) # Not specifying path= but creating storage
2015-04-12 02:25:46 +03:00
c . add_valid ( " --disk %(COLLIDE)s --check path_in_use=off " ) # Colliding storage with --check
2013-08-17 17:44:11 +04:00
c . add_valid ( " --disk %(COLLIDE)s --force " ) # Colliding storage with --force
2018-06-12 19:26:13 +03:00
c . add_valid ( " --disk /dev/default-pool/sharevol.img,perms=sh " ) # Colliding shareable storage
2013-08-17 17:44:11 +04:00
c . add_valid ( " --disk path= %(EXISTIMG1)s ,device=cdrom --disk path= %(EXISTIMG1)s ,device=cdrom " ) # Two IDE cds
c . add_valid ( " --disk %(EXISTIMG1)s ,driver_name=qemu,driver_type=qcow2 " ) # Driver name and type options
2014-12-05 03:36:26 +03:00
c . add_valid ( " --disk /dev/zero " ) # Referencing a local unmanaged /dev node
2013-08-17 17:44:11 +04:00
c . add_valid ( " --disk pool=default,size=.00001 " ) # Building 'default' pool
2018-06-12 19:26:13 +03:00
c . add_valid ( " --disk /some/new/pool/dir/new,size=.1 " ) # autocreate the pool
2015-04-12 02:25:46 +03:00
c . add_valid ( " --disk %(NEWIMG1)s ,sparse=true,size=100000000 --check disk_size=off " ) # Don't warn about fully allocated file exceeding disk space
2017-09-06 10:13:44 +03:00
c . add_valid ( " --disk %(EXISTIMG1)s ,snapshot_policy=no " ) # Disable snasphot for disk
2013-08-17 17:44:11 +04:00
c . add_invalid ( " --file %(NEWIMG1)s --file-size 100000 --nonsparse " ) # Nonexisting file, size too big
c . add_invalid ( " --file %(NEWIMG1)s --file-size 100000 " ) # Huge file, sparse, but no prompting
c . add_invalid ( " --file %(NEWIMG1)s " ) # Nonexisting file, no size
c . add_invalid ( " --file %(EXISTIMG1)s --file %(EXISTIMG1)s --file %(EXISTIMG1)s --file %(EXISTIMG1)s --file %(EXISTIMG1)s " ) # Too many IDE
c . add_invalid ( " --disk pool=foopool,size=.0001 " ) # Specify a nonexistent pool
2018-06-12 19:26:13 +03:00
c . add_invalid ( " --disk vol=default-pool/foovol " ) # Specify a nonexistent volume
2019-07-02 21:07:16 +03:00
c . add_invalid ( " --disk vol=default-pool-no-slash " ) # Wrong vol= format
c . add_invalid ( " --disk perms=badformat " ) # Wrong perms= format
c . add_invalid ( " --disk size=badformat " ) # Wrong size= format
2018-06-12 19:26:13 +03:00
c . add_invalid ( " --disk pool=default-pool " ) # Specify a pool with no size
2013-08-17 17:44:11 +04:00
c . add_invalid ( " --disk path= %(EXISTIMG1)s ,perms=ro,size=.0001,cache=FOOBAR " ) # Unknown cache type
2014-02-09 01:36:45 +04:00
c . add_invalid ( " --disk path=/dev/foo/bar/baz,format=qcow2,size=.0000001 " ) # Unmanaged file using non-raw format
2018-06-12 19:26:13 +03:00
c . add_invalid ( " --disk path=/dev/disk-pool/newvol1.img,format=raw,size=.0000001 " ) # Managed disk using any format
2013-08-17 17:44:11 +04:00
c . add_invalid ( " --disk %(NEWIMG1)s " ) # Not specifying path= and non existent storage w/ no size
2014-02-05 01:16:39 +04:00
c . add_invalid ( " --disk %(NEWIMG1)s ,sparse=true,size=100000000000 " ) # Fail if fully allocated file would exceed disk space
2018-02-20 23:00:46 +03:00
c . add_invalid ( " --connect % (URI-TEST-FULL)s --disk %(COLLIDE)s " ) # Colliding storage without --force
c . add_invalid ( " --connect % (URI-TEST-FULL)s --disk %(COLLIDE)s --prompt " ) # Colliding storage with --prompt should still fail
c . add_invalid ( " --connect % (URI-TEST-FULL)s --disk /dev/default-pool/backingl3.img " ) # Colliding storage via backing store
2013-08-17 17:44:11 +04:00
c . add_invalid ( " --disk %(EXISTIMG1)s ,driver_name=foobar,driver_type=foobaz " ) # Unknown driver name and type options (as of 1.0.0)
2018-02-20 23:00:46 +03:00
c . add_invalid ( " --connect % (URI-TEST-FULL)s --disk source_pool=rbd-ceph,source_volume=vol1 " ) # Collision with existing VM, via source pool/volume
2019-05-15 23:26:23 +03:00
c . add_invalid ( " --disk source.pool=default-pool,source.volume=idontexist " ) # trying to lookup non-existent volume, hit specific error code
2015-09-06 20:42:07 +03:00
c . add_invalid ( " --disk size=1 --security model=foo,type=bar " ) # Libvirt will error on the invalid security params, which should trigger the code path to clean up the disk images we created.
2019-06-13 21:47:08 +03:00
c . add_invalid ( " --disk size=1 --file foobar " ) # --disk and --file collision
2013-08-17 17:44:11 +04:00
2014-12-10 17:33:02 +03:00
################################################
# Invalid devices that hit virtinst code paths #
################################################
2013-08-17 17:44:11 +04:00
2014-12-10 17:33:02 +03:00
c = vinst . add_category ( " invalid-devices " , " --noautoconsole --nodisks --pxe " )
2018-02-20 23:00:46 +03:00
c . add_invalid ( " --connect % (URI-TEST-FULL)s --host-device 1d6b:2 " ) # multiple USB devices with identical vendorId and productId
c . add_invalid ( " --connect % (URI-TEST-FULL)s --host-device pci_8086_2850_scsi_host_scsi_host " ) # Unsupported hostdev type
2013-08-17 17:44:11 +04:00
c . add_invalid ( " --host-device foobarhostdev " ) # Unknown hostdev
c . add_invalid ( " --host-device 300:400 " ) # Parseable hostdev, but unknown digits
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --graphics vnc,keymap=ZZZ " ) # Invalid keymap
c . add_invalid ( " --graphics vnc,port=-50 " ) # Invalid port
c . add_invalid ( " --graphics spice,tlsport=5 " ) # Invalid port
2019-06-13 21:47:08 +03:00
c . add_invalid ( " --vnc --sdl " ) # Multi graphics collision
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --serial unix " ) # Unix with no path
c . add_invalid ( " --channel pty,target_type=guestfwd " ) # --channel guestfwd without target_address
2015-02-18 23:16:48 +03:00
c . add_invalid ( " --boot uefi " ) # URI doesn't support UEFI bits
2015-04-23 00:06:35 +03:00
c . add_invalid ( " --connect % (URI-KVM)s --boot uefi,arch=ppc64 " ) # unsupported arch for UEFI
2018-02-23 02:21:51 +03:00
c . add_invalid ( " --features smm=on --machine pc " ) # smm=on doesn't work for machine=pc
2019-07-02 21:07:16 +03:00
c . add_invalid ( " --graphics type=vnc,keymap " , grep = " Option ' keymap ' had no value set. " )
2013-08-17 17:44:11 +04:00
2014-12-10 17:33:02 +03:00
########################
# Install option tests #
########################
c = vinst . add_category ( " nodisk-install " , " --nographics --noautoconsole --nodisks " )
2013-08-17 17:44:11 +04:00
c . add_valid ( " --hvm --cdrom %(EXISTIMG1)s " ) # Simple cdrom install
2019-06-14 18:24:10 +03:00
c . add_valid ( " --pxe --ram 16 " , grep = " Requested memory 16 MiB is abnormally low " ) # catch low memory error
c . add_valid ( " --os-variant winxp --ram 32 --cdrom %(EXISTIMG1)s " , grep = " 32 MiB is less than the recommended 64 MiB " ) # Windows. Catch memory warning
2014-12-10 17:33:02 +03:00
c . add_valid ( " --pxe --virt-type test " ) # Explicit virt-type
2018-05-21 22:42:50 +03:00
c . add_valid ( " --arch i686 --pxe " ) # Explicitly fullvirt + arch
2019-01-31 19:34:13 +03:00
c . add_valid ( " --location location= %(TREEDIR)s " ) # Directory tree URL install
2014-12-10 17:33:02 +03:00
c . add_valid ( " --location %(TREEDIR)s --initrd-inject virt-install --extra-args ks=file:/virt-install " ) # initrd-inject
2013-08-17 17:44:11 +04:00
c . add_valid ( " --hvm --location %(TREEDIR)s --extra-args console=ttyS0 " ) # Directory tree URL install with extra-args
c . add_valid ( " --paravirt --location %(TREEDIR)s " ) # Paravirt location
c . add_valid ( " --paravirt --location %(TREEDIR)s --os-variant none " ) # Paravirt location with --os-variant none
2014-12-10 17:33:02 +03:00
c . add_valid ( " --location %(TREEDIR)s --os-variant fedora12 " ) # URL install with manual os-variant
2019-06-13 23:02:58 +03:00
c . add_valid ( " --cdrom %(EXISTIMG2)s --os-variant win2k3 " ) # HVM windows install with disk
c . add_valid ( " --cdrom %(EXISTIMG2)s --os-variant win2k3 --print-step 2 " ) # HVM windows install, print 3rd stage XML
2014-12-10 17:33:02 +03:00
c . add_valid ( " --pxe --autostart " ) # --autostart flag
2018-10-12 22:40:40 +03:00
c . add_compare ( " --cdrom http://example.com/path/to/some.iso " , " cdrom-url " )
2014-12-10 17:33:02 +03:00
c . add_compare ( " --pxe --print-step all " , " simple-pxe " ) # Diskless PXE install
2019-06-08 03:55:11 +03:00
c . add_compare ( " --location ftp://example.com " , " fake-ftp " ) # fake ftp:// install using urlfetcher.py mocking
c . add_compare ( " --location https://foobar.com " , " fake-http " ) # fake https:// install using urlfetcher.py mocking
2019-06-14 03:26:26 +03:00
c . add_compare ( " --connect % (URI-KVM)s --install fedora26 " , " osinfo-url " ) # getting URL from osinfo
2019-06-10 23:54:40 +03:00
c . add_invalid ( " --pxe --virt-type bogus " ) # Bogus virt-type
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --pxe --arch bogus " ) # Bogus arch
2013-08-17 17:44:11 +04:00
c . add_invalid ( " --livecd " ) # LiveCD with no media
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --pxe --os-variant farrrrrrrge " ) # Bogus --os-variant
c . add_invalid ( " --pxe --boot menu=foobar " )
c . add_invalid ( " --cdrom %(EXISTIMG1)s --extra-args console=ttyS0 " ) # cdrom fail w/ extra-args
2014-09-23 22:14:21 +04:00
c . add_invalid ( " --hvm --boot kernel= %(TREEDIR)s /pxeboot/vmlinuz,initrd= %(TREEDIR)s /pxeboot/initrd.img,kernel_args= ' foo bar ' --initrd-inject virt-install " ) # initrd-inject with manual kernel/initrd
2019-02-01 02:07:09 +03:00
c . add_invalid ( " --disk none --location kernel=/dev/null,initrd=/dev/null " ) # --location with manual kernel/initrd, but not URL
2019-06-14 03:26:26 +03:00
c . add_invalid ( " --install winxp " , grep = " does not have a URL location " ) # no URL for winxp
c . add_invalid ( " --arch i686 --install fedora26 " , grep = " does not have a URL location for the i686 " ) # there's no URL for i686
2019-06-13 21:47:08 +03:00
c . add_invalid ( " -c foo --cdrom bar " , grep = " Cannot specify both -c " ) # check for ambiguous -c and --cdrom collision
c . add_invalid ( " -c qemu:///system " , grep = " looks like a libvirt URI " ) # error for the ambiguous -c vs --connect
2019-06-14 03:26:26 +03:00
c . add_invalid ( " --location / " , grep = " Error validating install location " ) # detect_distro failure
2019-06-14 03:56:16 +03:00
c . add_invalid ( " --os-variant foo://bar " , grep = " Unknown libosinfo ID " ) # bad full id
2013-04-24 00:16:30 +04:00
2014-12-10 17:33:02 +03:00
c = vinst . add_category ( " single-disk-install " , " --nographics --noautoconsole --disk %(EXISTIMG1)s " )
c . add_valid ( " --hvm --import " ) # FV Import install
2019-06-17 06:12:24 +03:00
c . add_valid ( " --hvm --install no_install=yes " ) # import install equivalent
2014-12-10 17:33:02 +03:00
c . add_valid ( " --hvm --import --prompt --force " ) # Working scenario w/ prompt shouldn't ask anything
c . add_valid ( " --paravirt --import " ) # PV Import install
2019-06-13 21:47:08 +03:00
c . add_valid ( " --paravirt --print-xml 1 " ) # print single XML, implied import install
2019-07-02 22:39:51 +03:00
c . add_valid ( " --hvm --import --wait 0 " , grep = " Treating --wait 0 as --noautoconsole " ) # --wait 0 is the same as --noautoconsole
2019-06-13 23:02:58 +03:00
c . add_compare ( " -c %(EXISTIMG2)s --os-variant win2k3 --vcpus cores=4 --controller usb,model=none " , " w2k3-cdrom " ) # HVM windows install with disk
2019-06-17 08:04:06 +03:00
c . add_compare ( " --connect % (URI-KVM)s --install fedora26 --disk size=20 " , " osinfo-url-with-disk " ) # filling in defaults, but with disk specified
2019-06-13 23:02:58 +03:00
c . add_invalid ( " --hvm --import --wait 2 " , grep = " exceeded specified time limit " ) # --wait positive number, but test suite hack
c . add_invalid ( " --hvm --import --wait -1 " , grep = " exceeded specified time limit " ) # --wait -1, but test suite hack
2019-06-17 05:46:39 +03:00
c . add_invalid ( " --hvm --import --wait " , grep = " exceeded specified time limit " ) # --wait aka --wait -1, but test suite hack
2019-06-13 23:02:58 +03:00
c . add_invalid ( " --connect test:///default --name foo --ram 64 --disk none --sdl --hvm --import " , use_default_args = False , grep = " exceeded specified time limit " ) # --sdl doesn't have a console callback, triggers implicit --wait -1
2015-04-05 00:10:45 +03:00
c . add_invalid ( " --paravirt --import --print-xml 2 " ) # PV Import install, no second XML step
2019-06-13 21:47:08 +03:00
c . add_invalid ( " --paravirt --import --print-xml 7 " ) # Invalid --print-xml arg
2019-06-12 00:19:01 +03:00
c . add_invalid ( " --location kernel=foo,initrd=bar " ) # location kernel/initrd without any url
c . add_invalid ( " --location http://example.com,kernel=foo " ) # location without kernel+initrd specified as pair
2014-12-10 17:33:02 +03:00
c = vinst . add_category ( " misc-install " , " --nographics --noautoconsole " )
2019-06-11 19:23:09 +03:00
c . add_compare ( " --connect %s " % ( utils . URIs . test_suite ) , " noargs-fail " , use_default_args = False ) # No arguments
2019-06-11 19:15:35 +03:00
c . add_compare ( " --connect %s --os-variant fedora26 " % ( utils . URIs . test_suite ) , " osvariant-noargs-fail " , use_default_args = False ) # No arguments
c . add_compare ( " --connect %s --os-variant fedora26 --pxe --print-xml " % ( utils . URIs . test_suite ) , " osvariant-defaults-pxe " , use_default_args = False ) # No arguments
2019-05-11 00:22:23 +03:00
c . add_valid ( " --panic help --disk=? --check=help " , grep = " path_in_use " ) # Make sure introspection doesn't blow up
2019-06-13 21:47:08 +03:00
c . add_valid ( " --connect test:///default --test-stub-command " , use_default_args = False ) # --test-stub-command
2018-10-13 19:55:34 +03:00
c . add_valid ( " --nodisks --pxe " , grep = " VM performance may suffer " ) # os variant warning
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --hvm --nodisks --pxe foobar " ) # Positional arguments error
c . add_invalid ( " --nodisks --pxe --name test " ) # Colliding name
2019-06-13 21:47:08 +03:00
c . add_compare ( " --os-type linux --cdrom %(EXISTIMG1)s --disk size=1 --disk %(EXISTIMG2)s ,device=cdrom " , " cdrom-double " ) # ensure --disk device=cdrom is ordered after --cdrom, this is important for virtio-win installs with a driver ISO
2019-03-26 17:13:37 +03:00
c . add_valid ( " --connect %s --pxe --disk size=1 " % utils . URIs . test_defaultpool_collision ) # testdriver already has a pool using the 'default' path, make sure we don't error
2014-12-10 17:33:02 +03:00
2019-06-11 22:18:47 +03:00
####################
# Unattended tests #
####################
c = vinst . add_category ( " unattended-install " , " --connect % (URI-KVM)s --nographics --noautoconsole --disk none " , prerun_check = no_osinfo_unattend_cb )
2019-07-03 17:01:28 +03:00
c . add_compare ( " --install fedora26 --unattended profile=desktop,admin-password-file= % (ADMIN-PASSWORD-FILE)s,user-password-file= % (USER-PASSWORD-FILE)s,product-key=1234 " , " osinfo-url-unattended " ) # unattended install for fedora, using initrd injection
c . add_compare ( " --cdrom % (ISO-WIN7)s --unattended profile=desktop,admin-password-file= % (ADMIN-PASSWORD-FILE)s " , " osinfo-win7-unattended " ) # unattended install for win7
c . add_compare ( " --os-variant fedora26 --unattended profile=jeos,admin-password-file= % (ADMIN-PASSWORD-FILE)s --location % (ISO-F26-NETINST)s " , " osinfo-netinst-unattended " ) # triggering the special netinst checking code
2019-06-11 22:18:47 +03:00
c . add_compare ( " --os-variant silverblue29 --location http://example.com " , " network-install-resources " ) # triggering network-install resources override
2019-06-14 03:26:26 +03:00
c . add_valid ( " --pxe --os-variant fedora26 --unattended " , grep = " Using unattended profile ' desktop ' " ) # filling in default 'desktop' profile
2019-06-11 22:18:47 +03:00
c . add_invalid ( " --os-variant fedora26 --unattended profile=jeos --location http://example.foo " , grep = " admin-password " ) # will trigger admin-password required error
c . add_invalid ( " --os-variant fedora26 --unattended profile=jeos --location http://example.foo " , grep = " admin-password " ) # will trigger admin-password required error
2019-07-03 17:01:28 +03:00
c . add_invalid ( " --os-variant debian9 --unattended profile=desktop,admin-password-file= % (ADMIN-PASSWORD-FILE)s --location http://example.foo " , grep = " user-password " ) # will trigger user-password required error
c . add_invalid ( " --os-variant debian9 --unattended profile=FRIBBER,admin-password-file= % (ADMIN-PASSWORD-FILE)s --location http://example.foo " , grep = " Available profiles " ) # will trigger unknown profile error
c . add_invalid ( " --os-variant fedora29 --unattended profile=desktop,admin-password-file= % (ADMIN-PASSWORD-FILE)s --cdrom % (ISO-F29-LIVE)s " , grep = " media does not support " ) # live media doesn't support installscript
2019-06-11 22:18:47 +03:00
c . add_invalid ( " --os-variant msdos --unattended profile=desktop --location http://example.com " ) # msdos doesn't support unattended install
2019-06-12 01:55:13 +03:00
c . add_invalid ( " --os-variant winxp --unattended profile=desktop --cdrom % (ISO-WIN7)s " ) # winxp doesn't support expected injection method 'cdrom'
c . add_invalid ( " --connect % (URI-TEST-REMOTE)s --os-variant win7 --cdrom %(EXISTIMG1)s --unattended " ) # --unattended method=cdrom rejected for remote connections
2019-06-11 22:18:47 +03:00
2014-12-10 17:33:02 +03:00
#############################
# Remote URI specific tests #
#############################
2015-04-23 00:06:35 +03:00
c = vinst . add_category ( " remote " , " --connect % (URI-TEST-REMOTE)s --nographics --noautoconsole " )
2014-12-10 17:33:02 +03:00
c . add_valid ( " --nodisks --pxe " ) # Simple pxe nodisks
c . add_valid ( " --pxe --disk /foo/bar/baz,size=.01 " ) # Creating any random path on the remote host
c . add_valid ( " --pxe --disk /dev/zde " ) # /dev file that we just pass through to the remote VM
2019-06-12 00:19:01 +03:00
c . add_valid ( " --cdrom %(EXISTIMG1)s --disk none --livecd --dry " ) # remote cdrom install
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --pxe --disk /foo/bar/baz " ) # File that doesn't exist after auto storage setup
c . add_invalid ( " --nodisks --location /tmp " ) # Use of --location
c . add_invalid ( " --file /foo/bar/baz --pxe " ) # Trying to use unmanaged storage without size argument
###########################
# QEMU/KVM specific tests #
###########################
2018-09-01 01:28:08 +03:00
c = vinst . add_category ( " kvm-generic " , " --connect % (URI-KVM)s --noautoconsole " )
2019-06-12 02:06:08 +03:00
c . add_compare ( " --os-variant fedora-unknown --file %(EXISTIMG1)s --location %(TREEDIR)s --extra-args console=ttyS0 --cpu host --channel none --console none --sound none --redirdev none --boot cmdline= ' foo bar baz ' " , " kvm-fedoralatest-url " , prerun_check = has_old_osinfo ) # Fedora Directory tree URL install with extra-args
2019-06-13 21:47:08 +03:00
c . add_compare ( " --test-media-detection %(TREEDIR)s --arch x86_64 --hvm " , " test-url-detection " ) # --test-media-detection
2019-06-14 03:56:16 +03:00
c . add_compare ( " --os-variant http://fedoraproject.org/fedora/20 --disk %(EXISTIMG1)s ,device=floppy --disk %(NEWIMG1)s ,size=.01,format=vmdk --location %(TREEDIR)s --extra-args console=ttyS0 --quiet " , " quiet-url " , prerun_check = has_old_osinfo ) # Quiet URL install should make no noise
2019-06-13 23:02:58 +03:00
c . add_compare ( " --cdrom %(EXISTIMG2)s --file %(EXISTIMG1)s --os-variant win2k3 --sound --controller usb " , " kvm-win2k3-cdrom " ) # HVM windows install with disk
2017-02-22 22:38:32 +03:00
c . add_compare ( " --os-variant ubuntusaucy --nodisks --boot cdrom --virt-type qemu --cpu Penryn --input tablet " , " qemu-plain " ) # plain qemu
2019-07-02 20:01:12 +03:00
c . add_compare ( " --os-variant fedora20 --nodisks --boot network --graphics default --arch i686 --rng none " , " qemu-32-on-64 " , prerun_check = has_old_osinfo ) # 32 on 64
2015-04-23 02:27:27 +03:00
# ppc64 tests
2016-06-07 17:32:18 +03:00
c . add_compare ( " --arch ppc64 --machine pseries --boot network --disk %(EXISTIMG1)s --disk device=cdrom --os-variant fedora20 --network none " , " ppc64-pseries-f20 " )
2014-12-10 17:33:02 +03:00
c . add_compare ( " --arch ppc64 --boot network --disk %(EXISTIMG1)s --os-variant fedora20 --network none " , " ppc64-machdefault-f20 " )
2018-02-23 02:21:51 +03:00
c . add_compare ( " --connect % (URI-KVM-PPC64LE)s --import --disk %(EXISTIMG1)s --os-variant fedora20 --panic default " , " ppc64le-kvm-import " )
2015-04-23 02:27:27 +03:00
2015-07-13 14:35:24 +03:00
# s390x tests
2019-05-16 20:18:12 +03:00
c . add_compare ( " --arch s390x --machine s390-ccw-virtio --connect % (URI-KVM-S390X)s --boot kernel=/kernel.img,initrd=/initrd.img --disk %(EXISTIMG1)s --disk %(EXISTIMG3)s ,device=cdrom --os-variant fedora21 " , " s390x-cdrom " , prerun_check = has_old_osinfo )
2018-12-14 00:39:43 +03:00
c . add_compare ( " --arch s390x --machine s390-ccw-virtio --connect " + utils . URIs . kvm_s390x_KVMIBM + " --boot kernel=/kernel.img,initrd=/initrd.img --disk %(EXISTIMG1)s --disk %(EXISTIMG3)s ,device=cdrom --os-variant fedora21 --watchdog diag288,action=reset --panic default --graphics vnc " , " s390x-cdrom-KVMIBM " )
2015-07-13 14:35:24 +03:00
2015-08-10 19:46:47 +03:00
# qemu:///session tests
2019-05-16 20:18:12 +03:00
c . add_compare ( " --connect " + utils . URIs . kvm_session + " --disk size=8 --os-variant fedora21 --cdrom %(EXISTIMG1)s " , " kvm-session-defaults " , prerun_check = has_old_osinfo )
2015-08-10 19:46:47 +03:00
# misc KVM config tests
2019-05-16 20:18:12 +03:00
c . add_compare ( " --disk none --location % (ISO-NO-OS)s,kernel=frib.img,initrd=/frob.img " , " location-manual-kernel " , prerun_check = missing_isoinfo ) # --location with an unknown ISO but manually specified kernel paths
c . add_compare ( " --disk %(EXISTIMG1)s --location %(ISOTREE)s --nonetworks " , " location-iso " , prerun_check = missing_isoinfo ) # Using --location iso mounting
2018-10-13 00:15:20 +03:00
c . add_compare ( " --disk %(EXISTIMG1)s --cdrom %(ISOLABEL)s " , " cdrom-centos-label " ) # Using --cdrom with centos CD label, should use virtio etc.
2019-06-12 00:34:18 +03:00
c . add_compare ( " --disk %(EXISTIMG1)s --install bootdev=network --os-variant rhel5.4 " , " kvm-rhel5 " ) # RHEL5 defaults
2019-06-13 00:25:56 +03:00
c . add_compare ( " --disk %(EXISTIMG1)s --install kernel= % (ISO-WIN7)s,initrd= %(ISOLABEL)s ,kernel_args= ' foo bar ' --os-variant rhel6.4 " , " kvm-rhel6 " ) # RHEL6 defaults. ISO paths are just to point at existing files
2019-06-14 04:27:31 +03:00
c . add_compare ( " --disk %(EXISTIMG1)s --location https://example.com --install kernel_args= ' test overwrite ' ,kernel_args_overwrite=yes --os-variant rhel7.0 " , " kvm-rhel7 " , precompare_check = no_osinfo_unattend_cb ) # RHEL7 defaults
2019-05-16 20:18:12 +03:00
c . add_compare ( " --connect " + utils . URIs . kvm_nodomcaps + " --disk %(EXISTIMG1)s --pxe --os-variant rhel7.0 " , " kvm-cpu-default-fallback " , prerun_check = has_old_osinfo ) # No domcaps, so mode=host-model isn't safe, so we fallback to host-model-only
2018-10-14 00:47:31 +03:00
c . add_compare ( " --connect " + utils . URIs . kvm_nodomcaps + " --cpu host-copy --disk none --pxe " , " kvm-hostcopy-fallback " ) # No domcaps so need to use capabilities for CPU host-copy
2019-05-16 20:18:12 +03:00
c . add_compare ( " --disk %(EXISTIMG1)s --pxe --os-variant centos7.0 " , " kvm-centos7 " , prerun_check = has_old_osinfo ) # Centos 7 defaults
c . add_compare ( " --disk %(EXISTIMG1)s --pxe --os-variant centos7.0 " , " kvm-centos7 " , prerun_check = has_old_osinfo ) # Centos 7 defaults
c . add_compare ( " --disk %(EXISTIMG1)s --cdrom %(EXISTIMG2)s --os-variant win10 " , " kvm-win10 " , prerun_check = has_old_osinfo ) # win10 defaults
c . add_compare ( " --os-variant win7 --cdrom %(EXISTIMG2)s --boot loader_type=pflash,loader=CODE.fd,nvram_template=VARS.fd --disk %(EXISTIMG1)s " , " win7-uefi " , prerun_check = has_old_osinfo ) # no HYPER-V with UEFI
2019-06-13 00:25:56 +03:00
c . add_compare ( " --arch i686 --boot uefi --install kernel=http://example.com/httpkernel,initrd=ftp://example.com/ftpinitrd --disk none " , " kvm-i686-uefi " ) # i686 uefi. piggy back it for --install testing too
2015-04-23 02:27:27 +03:00
c . add_compare ( " --machine q35 --cdrom %(EXISTIMG2)s --disk %(EXISTIMG1)s " , " q35-defaults " ) # proper q35 disk defaults
2018-10-13 19:40:22 +03:00
c . add_compare ( " --disk size=1 --os-variant openbsd4.9 " , " openbsd-defaults " ) # triggers net fallback scenario
2019-05-16 20:18:12 +03:00
c . add_compare ( " --connect " + utils . URIs . kvm_remote + " --import --disk %(EXISTIMG1)s --os-variant fedora21 --pm suspend_to_disk=yes " , " f21-kvm-remote " , prerun_check = has_old_osinfo )
2015-11-03 19:15:26 +03:00
2018-06-12 19:26:13 +03:00
c . add_valid ( " --arch aarch64 --nodisks --pxe --connect " + utils . URIs . kvm_nodomcaps ) # attempt to default to aarch64 UEFI, but it fails, but should only print warnings
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --disk none --boot network --machine foobar " ) # Unknown machine type
c . add_invalid ( " --nodisks --boot network --arch mips --virt-type kvm " ) # Invalid domain type for arch
c . add_invalid ( " --nodisks --boot network --paravirt --arch mips " ) # Invalid arch/virt combo
2018-06-12 20:49:25 +03:00
c . add_invalid ( " --disk none --location nfs:example.com/fake --nonetworks " ) # Using --location nfs, no longer supported
2014-12-10 17:33:02 +03:00
2019-06-11 18:41:57 +03:00
c = vinst . add_category ( " kvm-x86_64-launch-security " , " --disk none --noautoconsole " )
c . add_compare ( " --boot uefi --machine q35 --launchSecurity type=sev,reducedPhysBits=1,policy=0x0001,cbitpos=47,dhCert=BASE64CERT,session=BASE64SESSION --connect " + utils . URIs . kvm_amd_sev , " x86_64-launch-security-sev-full " ) # Full cmdline
2019-06-11 18:41:59 +03:00
c . add_compare ( " --boot uefi --machine q35 --launchSecurity sev --connect " + utils . URIs . kvm_amd_sev , " x86_64-launch-security-sev " ) # Fill in platform data from domcaps
2019-06-11 18:41:58 +03:00
c . add_valid ( " --boot uefi --machine q35 --launchSecurity sev,reducedPhysBits=1,cbitpos=47 --connect " + utils . URIs . kvm_amd_sev ) # Default policy == 0x0003 will be used
2019-06-11 18:41:57 +03:00
c . add_invalid ( " --launchSecurity policy=0x0001 --connect " + utils . URIs . kvm_amd_sev ) # Missing launchSecurity 'type'
2019-06-11 18:42:00 +03:00
c . add_invalid ( " --launchSecurity sev --connect " + utils . URIs . kvm_amd_sev ) # Fail if loader isn't UEFI
c . add_invalid ( " --boot uefi --launchSecurity sev --connect " + utils . URIs . kvm_amd_sev ) # Fail if machine type isn't Q35
c . add_invalid ( " --boot uefi --machine q35 --launchSecurity sev,policy=0x0001 --connect " + utils . URIs . kvm_q35 ) # Fail with no SEV capabilities
2019-06-11 18:41:57 +03:00
2018-09-01 01:28:08 +03:00
c = vinst . add_category ( " kvm-q35 " , " --noautoconsole --connect " + utils . URIs . kvm_q35 )
2017-02-06 15:46:06 +03:00
c . add_compare ( " --boot uefi --disk none " , " boot-uefi " )
2014-12-10 17:33:02 +03:00
2019-05-16 20:18:12 +03:00
c = vinst . add_category ( " kvm-arm " , " --connect % (URI-KVM)s --noautoconsole " , precompare_check = " 3.3.0 " ) # required qemu-xhci from libvirt 3.3.0
2018-09-01 01:28:08 +03:00
# armv7l tests
c . add_compare ( " --arch armv7l --machine vexpress-a9 --boot kernel=/f19-arm.kernel,initrd=/f19-arm.initrd,dtb=/f19-arm.dtb,extra_args= \" console=ttyAMA0 rw root=/dev/mmcblk0p3 \" --disk %(EXISTIMG1)s --nographics " , " arm-vexpress-plain " )
c . add_compare ( " --arch armv7l --machine virt --boot kernel=/f19-arm.kernel,initrd=/f19-arm.initrd,kernel_args= \" console=ttyAMA0,1234 rw root=/dev/vda3 \" --disk %(EXISTIMG1)s --nographics --os-variant fedora20 " , " arm-virt-f20 " )
c . add_compare ( " --arch armv7l --boot kernel=/f19-arm.kernel,initrd=/f19-arm.initrd,kernel_args= \" console=ttyAMA0,1234 rw root=/dev/vda3 \" ,extra_args=foo --disk %(EXISTIMG1)s --os-variant fedora20 " , " arm-defaultmach-f20 " )
c . add_compare ( " --connect % (URI-KVM-ARMV7L)s --disk %(EXISTIMG1)s --import --os-variant fedora20 " , " arm-kvm-import " )
# aarch64 tests
c . add_compare ( " --arch aarch64 --machine virt --boot kernel=/f19-arm.kernel,initrd=/f19-arm.initrd,kernel_args= \" console=ttyAMA0,1234 rw root=/dev/vda3 \" --disk %(EXISTIMG1)s " , " aarch64-machvirt " )
c . add_compare ( " --arch aarch64 --boot kernel=/f19-arm.kernel,initrd=/f19-arm.initrd,kernel_args= \" console=ttyAMA0,1234 rw root=/dev/vda3 \" --disk %(EXISTIMG1)s " , " aarch64-machdefault " )
2019-05-15 22:46:08 +03:00
c . add_compare ( " --arch aarch64 --cdrom %(EXISTIMG2)s --boot loader=CODE.fd,nvram.template=VARS.fd --disk %(EXISTIMG1)s --cpu none --events on_crash=preserve,on_reboot=destroy,on_poweroff=restart " , " aarch64-cdrom " )
2019-06-09 23:39:15 +03:00
c . add_compare ( " --connect % (URI-KVM-AARCH64)s --disk %(EXISTIMG1)s --import --os-variant fedora21 --panic default " , " aarch64-kvm-import " ) # the --panic is a no-op
2018-09-01 01:28:08 +03:00
c . add_compare ( " --connect % (URI-KVM-AARCH64)s --disk size=1 --os-variant fedora22 --features gic_version=host --network network=default,address.type=pci --controller type=scsi,model=virtio-scsi,address.type=pci " , " aarch64-kvm-gic " )
2019-07-12 22:58:22 +03:00
c . add_compare ( " --connect % (URI-KVM-AARCH64)s --arch aarch64 --disk none --pxe --boot firmware=efi " , " aarch64-firmware-no-override " )
2018-09-01 01:28:08 +03:00
2019-03-20 18:52:31 +03:00
# Simple headless guests for various architectures
c = vinst . add_category ( " kvm-headless " , " --os-variant fedora29 --import --disk %(EXISTIMG1)s --network default --graphics none " )
c . add_compare ( " --connect % (URI-KVM-AARCH64)s --arch aarch64 " , " aarch64-headless " )
c . add_compare ( " --connect % (URI-KVM-PPC64LE)s --arch ppc64le " , " ppc64-headless " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --connect % (URI-QEMU-RISCV64)s --arch riscv64 " , " riscv64-headless " , precompare_check = " 5.3.0 " )
2019-03-20 18:52:31 +03:00
c . add_compare ( " --connect % (URI-KVM-S390X)s --arch s390x " , " s390x-headless " )
c . add_compare ( " --connect % (URI-KVM)s --arch x86_64 " , " x86_64-headless " )
2019-03-20 18:52:32 +03:00
# Simple guests with graphics for various architectures
c = vinst . add_category ( " kvm-graphics " , " --os-variant fedora29 --import --disk %(EXISTIMG1)s --network default --graphics vnc " )
c . add_compare ( " --connect % (URI-KVM-AARCH64)s --arch aarch64 " , " aarch64-graphics " )
c . add_compare ( " --connect % (URI-KVM-PPC64LE)s --arch ppc64le " , " ppc64-graphics " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --connect % (URI-QEMU-RISCV64)s --arch riscv64 " , " riscv64-graphics " , precompare_check = " 5.3.0 " , )
2019-03-20 18:52:32 +03:00
c . add_compare ( " --connect % (URI-KVM-S390X)s --arch s390x " , " s390x-graphics " )
c . add_compare ( " --connect % (URI-KVM)s --arch x86_64 " , " x86_64-graphics " )
2018-09-01 01:28:08 +03:00
2014-12-10 17:33:02 +03:00
######################
# LXC specific tests #
######################
2018-06-12 19:26:13 +03:00
c = vinst . add_category ( " lxc " , " --name foolxc --memory 64 --noautoconsole --connect " + utils . URIs . lxc )
2019-06-09 23:39:15 +03:00
c . add_invalid ( " --filesystem /,not/abs " ) # filesystem target is not absolute
2014-12-10 17:33:02 +03:00
c . add_compare ( " " , " default " )
2019-02-03 23:38:48 +03:00
c . add_compare ( " --os-variant fedora27 " , " default-f27 " )
2014-12-10 17:33:02 +03:00
c . add_compare ( " --filesystem /source,/ " , " fs-default " )
c . add_compare ( " --init /usr/bin/httpd " , " manual-init " )
######################
# Xen specific tests #
######################
2018-06-12 19:26:13 +03:00
c = vinst . add_category ( " xen " , " --noautoconsole --connect " + utils . URIs . xen )
2015-09-22 18:26:13 +03:00
c . add_valid ( " --disk %(EXISTIMG1)s --location %(TREEDIR)s --paravirt --graphics none " ) # Xen PV install headless
2014-12-10 17:33:02 +03:00
c . add_compare ( " --disk %(EXISTIMG1)s --import " , " xen-default " ) # Xen default
2019-06-09 23:39:15 +03:00
c . add_compare ( " --disk %(EXISTIMG1)s --location %(TREEDIR)s --paravirt --controller xenbus,maxGrantFrames=64 --input default " , " xen-pv " , precompare_check = " 5.3.0 " ) # Xen PV
2018-06-12 19:26:13 +03:00
c . add_compare ( " --disk /iscsi-pool/diskvol1 --cdrom %(EXISTIMG1)s --livecd --hvm " , " xen-hvm " ) # Xen HVM
2019-06-17 06:12:24 +03:00
c . add_compare ( " --disk /iscsi-pool/diskvol1 --cdrom %(EXISTIMG1)s --install no_install=yes --hvm " , " xen-hvm " ) # Ensure --livecd and --install no_install are essentially identical
2014-12-10 17:33:02 +03:00
2013-04-24 00:16:30 +04:00
2017-02-21 17:28:00 +03:00
#####################
# VZ specific tests #
#####################
2018-06-12 19:26:13 +03:00
c = vinst . add_category ( " vz " , " --noautoconsole --connect " + utils . URIs . vz )
2017-04-27 20:11:13 +03:00
c . add_valid ( " --container " ) # validate the special define+start logic
2019-06-12 00:19:01 +03:00
c . add_valid ( " --hvm --cdrom %(EXISTIMG1)s --disk none " ) # hit more install vz logic
c . add_valid ( " --hvm --import --disk %(EXISTIMG1)s --noreboot " ) # hit more install vz logic
2019-06-13 21:47:08 +03:00
c . add_invalid ( " --container --transient " ) # vz doesn't support --transient
2019-05-14 18:25:52 +03:00
c . add_compare ( """
- - container
- - filesystem type = template , source = centos - 7 - x86_64 , target = " / "
- - network network = " Bridged "
2017-02-21 17:28:00 +03:00
""" , " vz-ct-template " )
2014-12-10 17:33:02 +03:00
#####################################
# Device option back compat testing #
#####################################
c = vinst . add_category ( " device-back-compat " , " --nodisks --pxe --noautoconsole " )
c . add_valid ( " --sdl " ) # SDL
c . add_valid ( " --vnc --keymap ja --vncport 5950 --vnclisten 1.2.3.4 " ) # VNC w/ lots of options
c . add_valid ( " --sound " ) # --sound with no option back compat
c . add_valid ( " --mac 22:22:33:44:55:AF " ) # Just a macaddr
c . add_valid ( " --bridge mybr0 --mac 22:22:33:44:55:AF " ) # Old bridge w/ mac
c . add_valid ( " --network bridge:mybr0,model=e1000 " ) # --network bridge:
c . add_valid ( " --network network:default --mac RANDOM " ) # VirtualNetwork with a random macaddr
c . add_valid ( " --vnc --keymap=local " ) # --keymap local
2017-09-04 19:40:34 +03:00
c . add_valid ( " --panic 0x505 " ) # ISA panic with iobase specified
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --graphics vnc --vnclisten 1.2.3.4 " ) # mixing old and new
c . add_invalid ( " --network=FOO " ) # Nonexistent network
c . add_invalid ( " --mac 1234 " ) # Invalid mac
c . add_invalid ( " --network user --bridge foo0 " ) # Mixing bridge and network
2018-02-20 23:00:46 +03:00
c . add_invalid ( " --connect % (URI-TEST-FULL)s --mac 22:22:33:12:34:AB " ) # Colliding macaddr
2014-12-10 17:33:02 +03:00
c = vinst . add_category ( " storage-back-compat " , " --pxe --noautoconsole " )
c . add_valid ( " --file %(EXISTIMG1)s --nonsparse --file-size 4 " ) # Existing file, other opts
c . add_valid ( " --file %(EXISTIMG1)s " ) # Existing file, no opts
2015-04-12 02:25:46 +03:00
c . add_valid ( " --file %(EXISTIMG1)s --file %(EXISTIMG1)s " ) # Multiple existing files
2014-12-10 17:33:02 +03:00
c . add_valid ( " --file %(NEWIMG1)s --file-size .00001 --nonsparse " ) # Nonexistent file
2018-10-13 18:50:49 +03:00
c = vinst . add_category ( " console-tests " , " --nodisks " )
c . add_valid ( " --pxe " , grep = " testsuite console command: [ ' virt-viewer ' " ) # mock default graphics+virt-viewer usage
2019-07-02 21:07:16 +03:00
c . add_valid ( " --pxe --graphics spice,gl=on " , grep = " --attach " ) # using virt-viewer --attach option for gl
2018-10-13 18:50:49 +03:00
c . add_valid ( " --pxe --destroy-on-exit " , grep = " Restarting guest. \n " ) # destroy-on-exit
c . add_valid ( " --pxe --transient --destroy-on-exit " , grep = " Domain creation completed. " ) # destroy-on-exit + transient
c . add_valid ( " --pxe --graphics vnc --noreboot " , grep = " testsuite console command: [ ' virt-viewer ' " ) # mock virt-viewer waiting, with noreboot magic
c . add_valid ( " --nographics --cdrom %(EXISTIMG1)s " ) # console warning about cdrom + nographics
2019-06-17 07:07:29 +03:00
c . add_valid ( " --nographics --console none --location %(TREEDIR)s " , grep = " No --console device added " ) # console warning about nographics + --console none
c . add_valid ( " --nographics --console none --location %(TREEDIR)s " , grep = " Directory tree installs typically " ) # warning about directory trees not working well
2018-10-13 18:50:49 +03:00
c . add_valid ( " --pxe --nographics --transient " , grep = " testsuite console command: [ ' virsh ' " ) # --transient handling
2014-12-10 17:33:02 +03:00
##################
# virt-xml tests #
##################
2013-04-24 00:16:30 +04:00
2019-05-16 20:18:12 +03:00
vixml = App ( " virt-xml " )
2014-01-19 19:37:14 +04:00
c = vixml . add_category ( " misc " , " " )
c . add_valid ( " --help " ) # basic --help test
2014-02-05 21:32:53 +04:00
c . add_valid ( " --sound=? --tpm=? " ) # basic introspection test
2019-06-16 23:00:17 +03:00
c . add_valid ( " test-state-shutoff --edit --update --boot menu=on " , grep = " The VM is not running " ) # --update with inactive VM, should work but warn
2019-06-17 00:01:32 +03:00
c . add_valid ( " test-state-shutoff --edit --boot menu=on " , grep = " XML did not change after domain define " ) # menu=on is discarded because <bootloader> is specified
2019-06-14 19:10:00 +03:00
c . add_valid ( " test-for-virtxml --edit --graphics password=foo --update --confirm " , input_text = " no \n no \n " ) # prompt exiting
c . add_valid ( " test-for-virtxml --edit --cpu host-passthrough --no-define --start --confirm " , input_text = " no " ) # transient prompt exiting
2019-06-16 22:13:54 +03:00
c . add_valid ( " test-for-virtxml --edit --metadata name=test-for-virtxml " , grep = " requested changes will have no effect " )
2019-06-14 19:10:00 +03:00
c . add_invalid ( " test --edit 2 --events on_poweroff=destroy " , grep = " ' --edit 2 ' doesn ' t make sense with --events " )
c . add_invalid ( " test --os-variant fedora26 --edit --cpu host-passthrough " , grep = " --os-variant is not supported " )
c . add_invalid ( " test-for-virtxml --os-variant fedora26 --remove-device --disk 1 " , grep = " --os-variant is not supported " )
c . add_invalid ( " --build-xml --os-variant fedora26 --disk path=foo " , grep = " --os-variant is not supported " )
2019-06-16 23:00:17 +03:00
c . add_invalid ( " domain-idontexist --edit --cpu host-passthrough --start " , grep = " Could not find domain " )
c . add_invalid ( " test-state-shutoff --edit --update --boot menu=on --start " , grep = " Cannot mix --update " )
2019-06-14 19:10:00 +03:00
c . add_invalid ( " test --edit --update --events on_poweroff=destroy " , grep = " Don ' t know how to --update for --events " )
c . add_invalid ( " --edit --cpu host-passthrough --confirm " , input_file = ( XMLDIR + " /virtxml-stdin-edit.xml " ) , grep = " Can ' t use --confirm with stdin " )
c . add_invalid ( " --edit --cpu host-passthrough --update " , input_file = ( XMLDIR + " /virtxml-stdin-edit.xml " ) , grep = " Can ' t use --update with stdin " )
c . add_invalid ( " --edit --cpu host-passthrough " , grep = " A domain must be specified " )
c . add_invalid ( " test-state-shutoff --cpu mode=idontexist --start --edit --no-define --confirm " , grep = " Failed starting domain " , input_text = " yes " )
c . add_invalid ( " test --cpu host-passthrough " , grep = " One of --edit, " ) # conflicting --edit options
c . add_invalid ( " test --edit --add-device --disk path=foo " , grep = " Conflicting options --edit, --add-device " )
c . add_invalid ( " test --edit 0 --disk path= " , grep = " Invalid --edit option ' 0 ' " )
2014-01-26 03:16:16 +04:00
c . add_invalid ( " test --edit --hostdev driver_name=vfio " ) # Guest has no hostdev to edit
c . add_invalid ( " test --edit --cpu host-passthrough --boot hd,network " ) # Specified more than 1 option
c . add_invalid ( " test --edit " ) # specified no edit option
2018-05-21 22:42:50 +03:00
c . add_invalid ( " test --edit 2 --cpu host-passthrough " ) # specifying --edit number where it doesn't make sense
2015-04-22 02:37:01 +03:00
c . add_invalid ( " test-for-virtxml --edit 5 --tpm /dev/tpm " ) # device edit out of range
2019-06-14 19:10:00 +03:00
c . add_invalid ( " test-for-virtxml --add-device --host-device 0x04b3:0x4485 --update --confirm " , input_text = " yes " ) # test driver doesn't support attachdevice...
c . add_invalid ( " test-for-virtxml --remove-device --host-device 1 --update --confirm " , input_text = " foo \n yes \n " ) # test driver doesn't support detachdevice...
2019-07-02 21:07:16 +03:00
c . add_invalid ( " test-for-virtxml --edit --graphics password=foo,keymap= --update --confirm " , input_text = " yes " ) # test driver doesn't support updatdevice...
2014-01-26 05:14:42 +04:00
c . add_invalid ( " --build-xml --memory 10,maxmemory=20 " ) # building XML for option that doesn't support it
2019-07-02 21:07:16 +03:00
c . add_invalid ( " test-state-shutoff --edit sparse=no --disk path=blah " , grep = " Don ' t know how to match device type ' disk ' property ' sparse ' " )
2019-02-26 12:56:42 +03:00
c . add_invalid ( " test --edit --boot network,cdrom --define --no-define " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " test --print-xml --edit --vcpus 7 " , " print-xml " ) # test --print-xml
2018-06-12 19:26:13 +03:00
c . add_compare ( " --edit --cpu host-passthrough " , " stdin-edit " , input_file = ( XMLDIR + " /virtxml-stdin-edit.xml " ) ) # stdin test
2014-02-06 04:09:26 +04:00
c . add_compare ( " --build-xml --cpu pentium3,+x2apic " , " build-cpu " )
2019-05-15 22:52:16 +03:00
c . add_compare ( " --build-xml --tpm path=/dev/tpm " , " build-tpm " )
2019-05-15 23:00:37 +03:00
c . add_compare ( " --build-xml --blkiotune weight=100,device0.path=/dev/sdf,device.weight=200 " , " build-blkiotune " )
2019-07-02 21:07:16 +03:00
c . add_compare ( " --build-xml --idmap clearxml=no,uid.start=0,uid.target=1000,uid.count=10,gid.start=0,gid.target=1000,gid.count=10 " , " build-idmap " )
2019-06-15 04:33:50 +03:00
c . add_compare ( " --connect % (URI-KVM)s --build-xml --disk %(EXISTIMG1)s " , " build-disk-plain " )
c . add_compare ( " --connect % (URI-KVM)s test-many-devices --build-xml --disk %(EXISTIMG1)s " , " build-disk-domain " )
2019-03-21 20:34:52 +03:00
c . add_compare ( " 4a64cc71-19c4-2fd0-2323-3050941ea3c3 --edit --boot network,cdrom " , " edit-bootorder " ) # basic bootorder test, also using UUID lookup
2019-06-14 19:10:00 +03:00
c . add_compare ( " --confirm 1 --edit --cpu host-passthrough " , " prompt-response " , input_text = " yes " ) # prompt response, also using domid lookup
2018-06-12 19:26:13 +03:00
c . add_compare ( " --edit --print-diff --qemu-commandline clearxml=yes " , " edit-clearxml-qemu-commandline " , input_file = ( XMLDIR + " /virtxml-qemu-commandline-clear.xml " ) )
2018-09-13 22:51:03 +03:00
c . add_compare ( " --connect % (URI-KVM)s test-hyperv-uefi --edit --boot uefi " , " hyperv-uefi-collision " )
2014-01-26 03:16:16 +04:00
2018-02-20 23:00:46 +03:00
c = vixml . add_category ( " simple edit diff " , " test-for-virtxml --edit --print-diff --define " )
2018-10-01 02:12:19 +03:00
c . add_compare ( """ --metadata name=foo-my-new-name,os_name=fedora13,uuid=12345678-12F4-1234-1234-123456789AFA,description= " hey this is my
2014-01-25 05:03:30 +04:00
new
2014-02-06 04:09:26 +04:00
very , very = new desc \\\' " ,title= " This is my,funky=new title " " " " , " edit-simple-metadata " )
2018-10-01 02:12:19 +03:00
c . add_compare ( """ --metadata os_full_id=http://fedoraproject.org/fedora/23 """ , " edit-metadata-full-os " )
2014-05-29 05:46:24 +04:00
c . add_compare ( " --events on_poweroff=destroy,on_reboot=restart,on_crash=preserve " , " edit-simple-events " )
2017-03-06 04:45:33 +03:00
c . add_compare ( " --qemu-commandline= ' -foo bar,baz= \" wib wob \" ' " , " edit-simple-qemu-commandline " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --memory 500,maxmemory=1000,hugepages=off " , " edit-simple-memory " )
c . add_compare ( " --vcpus 10,maxvcpus=20,cores=5,sockets=4,threads=1 " , " edit-simple-vcpus " )
c . add_compare ( " --cpu model=pentium2,+x2apic,forbid=pbe " , " edit-simple-cpu " )
2019-06-09 11:48:08 +03:00
c . add_compare ( " --numatune memory.nodeset=1-5,7,memory.mode=strict,memory.placement=auto " , " edit-simple-numatune " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --blkiotune weight=500,device_path=/dev/sdf,device_weight=600 " , " edit-simple-blkiotune " )
2018-09-01 01:28:08 +03:00
c . add_compare ( " --idmap uid_start=0,uid_target=2000,uid_count=30,gid_start=0,gid_target=3000,gid_count=40 " , " edit-simple-idmap " )
2019-05-15 22:46:08 +03:00
c . add_compare ( " --boot loader=foo.bar,useserial=on,init=/bin/bash,nvram=/test/nvram.img,os_type=hvm,domain_type=test,loader.readonly=on,loader.secure=no,machine= " , " edit-simple-boot " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --security label=foo,bar,baz,UNKNOWN=val,relabel=on " , " edit-simple-security " )
c . add_compare ( " --features eoi=on,hyperv_relaxed=off,acpi= " , " edit-simple-features " )
2019-05-13 02:00:47 +03:00
c . add_compare ( " --clock offset=localtime,hpet_present=yes,kvmclock_present=no,kvmclock_tickpolicy=foo,rtc_tickpolicy=merge " , " edit-simple-clock " )
2019-05-15 22:51:54 +03:00
c . add_compare ( " --pm suspend_to_mem.enabled=yes,suspend_to_disk.enabled=no " , " edit-simple-pm " )
2019-05-15 23:26:23 +03:00
c . add_compare ( " --disk /dev/zero,perms=ro,source.startupPolicy=optional " , " edit-simple-disk " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --disk path= " , " edit-simple-disk-remove-path " )
c . add_compare ( " --network source=br0,type=bridge,model=virtio,mac= " , " edit-simple-network " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --graphics tlsport=5902,keymap=ja " , " edit-simple-graphics " )
c . add_compare ( " --graphics listen=none " , " edit-graphics-listen-none " )
2016-06-11 23:44:54 +03:00
c . add_compare ( " --controller index=15,model=lsilogic " , " edit-simple-controller " )
2015-04-05 03:01:03 +03:00
c . add_compare ( " --controller index=15,model=lsilogic " , " edit-simple-controller " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --smartcard type=spicevmc " , " edit-simple-smartcard " )
c . add_compare ( " --redirdev type=spicevmc,server=example.com:12345 " , " edit-simple-redirdev " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --tpm backend.device.path=,backend.type=emulator,backend.version=2.0 " , " edit-simple-tpm " )
2019-05-15 22:54:28 +03:00
c . add_compare ( " --vsock model=virtio,cid.address=,cid.auto=on " , " edit-simple-vsock " )
2019-05-16 00:21:26 +03:00
c . add_compare ( " --rng rate_bytes=3333,rate_period=4444,backend.source.connect_host=,backend.source.connect_service=,backend.source.host=,backend.source.service=,backend.source.bind_host=,backend.source.bind_service=,backend.source.mode=,backend.type=unix,backend.source.mode=connect,backend.source.path=/tmp/unix,backend.source.seclabel.model=dac,backend.source.seclabel.label=foo,backend.source.seclabel.relabel=yes " , " edit-simple-rng " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --watchdog action=reset " , " edit-simple-watchdog " )
c . add_compare ( " --memballoon model=none " , " edit-simple-memballoon " )
c . add_compare ( " --serial pty " , " edit-simple-serial " )
c . add_compare ( " --parallel unix,path=/some/other/log " , " edit-simple-parallel " )
c . add_compare ( " --channel null " , " edit-simple-channel " )
2015-06-09 00:22:58 +03:00
c . add_compare ( " --console name=foo.bar.baz " , " edit-simple-console " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --filesystem /1/2/3,/4/5/6,mode=mapped " , " edit-simple-filesystem " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --video cirrus " , " edit-simple-video " )
c . add_compare ( " --sound pcspk " , " edit-simple-soundhw " )
2019-05-15 23:03:26 +03:00
c . add_compare ( " --host-device 0x04b3:0x4485,driver_name=vfio,type=usb " , " edit-simple-host-device " )
2014-01-19 19:37:14 +04:00
2018-02-20 23:00:46 +03:00
c = vixml . add_category ( " edit selection " , " test-for-virtxml --print-diff --define " )
2014-01-19 19:37:14 +04:00
c . add_invalid ( " --edit target=vvv --disk /dev/null " ) # no match found
2016-06-15 00:29:54 +03:00
c . add_invalid ( " --edit seclabel2.model=dac --disk /dev/null " ) # no match found
c . add_valid ( " --edit seclabel.model=dac --disk /dev/null " ) # match found
2019-05-16 20:18:12 +03:00
c . add_compare ( " --edit 3 --sound pcspk " , " edit-pos-num " )
c . add_compare ( " --edit -1 --video qxl " , " edit-neg-num " )
2019-05-15 23:03:26 +03:00
c . add_compare ( " --edit all --host-device driver.name=vfio " , " edit-all " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --edit ich6 --sound pcspk " , " edit-select-sound-model " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --edit target=hda --disk /dev/null " , " edit-select-disk-target " )
c . add_compare ( " --edit /tmp/foobar2 --disk shareable=off,readonly=on " , " edit-select-disk-path " )
c . add_compare ( " --edit mac=00:11:7f:33:44:55 --network target=nic55 " , " edit-select-network-mac " )
2019-02-26 12:56:40 +03:00
c . add_compare ( " --edit target=hda --disk boot_order=1 " , " edit-select-disk-bootorder " )
2019-05-11 00:57:04 +03:00
c . add_compare ( " --edit path=/dev/null --disk path=,target=fdb,boot_order=12 " , " edit-disk-unset " ) # --disk matching, using empty value to unset path
2019-06-13 13:55:07 +03:00
c . add_compare ( " --edit --memballoon none " , " edit-disable-memballoon " )
2019-02-26 12:56:40 +03:00
2019-02-26 12:56:44 +03:00
c = vixml . add_category ( " edit and start selection " , " test-state-shutoff --print-diff --start " )
c . add_compare ( " --define --edit target=vda --disk boot_order=1 " , " start-select-disk-bootorder " )
c . add_invalid ( " --define --no-define --edit target=vda --disk boot_order=1 " )
c . add_compare ( " --edit target=vda --disk boot_order=1 " , " start-select-disk-bootorder2 " )
c . add_compare ( " --no-define --edit target=vda --disk boot_order=1 " , " start-select-disk-bootorder2 " )
2019-02-26 12:56:40 +03:00
c = vixml . add_category ( " edit selection 2 " , " test-collide --print-diff --define " )
c . add_compare ( " --edit target=hda --disk boot_order=1 " , " edit-select-disk-bootorder2 " )
2014-01-19 19:37:14 +04:00
2018-02-20 23:00:46 +03:00
c = vixml . add_category ( " edit clear " , " test-for-virtxml --print-diff --define " )
2014-01-26 05:20:55 +04:00
c . add_invalid ( " --edit --memory 200,clearxml=yes " ) # clear isn't wired up for memory
2017-01-17 19:47:46 +03:00
c . add_compare ( " --edit --disk path=/foo/bar,size=2,target=fda,bus=fdc,device=floppy,clearxml=yes " , " edit-clear-disk " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --edit --cpu host-passthrough,clearxml=yes " , " edit-clear-cpu " )
c . add_compare ( " --edit --clock offset=utc,clearxml=yes " , " edit-clear-clock " )
2016-05-20 21:45:24 +03:00
c . add_compare ( " --edit --video clearxml=yes,model=virtio,accel3d=yes " , " edit-video-virtio " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --edit --graphics clearxml=yes,type=spice,gl=on,listen=none " , " edit-graphics-spice-gl " )
2014-01-26 00:44:14 +04:00
2018-02-20 23:00:46 +03:00
c = vixml . add_category ( " add/rm devices " , " test-for-virtxml --print-diff --define " )
2015-05-04 01:08:10 +03:00
c . add_valid ( " --add-device --security model=dac " ) # --add-device works for seclabel
c . add_invalid ( " --add-device --pm suspend_to_disk=yes " ) # --add-device without a device
2014-01-26 02:06:31 +04:00
c . add_invalid ( " --remove-device --clock utc " ) # --remove-device without a dev
2018-02-20 23:00:46 +03:00
c . add_compare ( " --add-device --host-device usb_device_4b3_4485_noserial " , " add-host-device " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --add-device --sound pcspk " , " add-sound " )
c . add_compare ( " --add-device --disk %(EXISTIMG1)s ,bus=virtio,target=vdf " , " add-disk-basic " )
c . add_compare ( " --add-device --disk %(EXISTIMG1)s " , " add-disk-notarget " ) # filling in acceptable target
c . add_compare ( " --add-device --disk %(NEWIMG1)s ,size=.01 " , " add-disk-create-storage " )
2019-01-22 18:28:38 +03:00
c . add_compare ( " --add-device --disk size=.01 " , " add-disk-default-storage " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --remove-device --sound ich6 " , " remove-sound-model " )
2015-04-22 02:37:01 +03:00
c . add_compare ( " --remove-device --disk 3 " , " remove-disk-index " )
2014-02-06 04:09:26 +04:00
c . add_compare ( " --remove-device --disk /dev/null " , " remove-disk-path " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --remove-device --video all " , " remove-video-all " )
c . add_compare ( " --remove-device --host-device 0x04b3:0x4485 " , " remove-hostdev-name " )
2019-06-13 13:55:07 +03:00
c . add_compare ( " --remove-device --memballoon all " , " remove-memballoon " )
2014-01-26 00:44:14 +04:00
2019-02-26 12:56:44 +03:00
c = vixml . add_category ( " add/rm devices and start " , " test-state-shutoff --print-diff --start " )
c . add_invalid ( " --add-device --pm suspend_to_disk=yes " ) # --add-device without a device
c . add_invalid ( " --remove-device --clock utc " ) # --remove-device without a dev
# one test in combination with --define
c . add_compare ( " --define --add-device --host-device usb_device_4b3_4485_noserial " , " add-host-device-start " )
# all other test cases without
c . add_compare ( " --add-device --disk %(EXISTIMG1)s ,bus=virtio,target=vdf " , " add-disk-basic-start " )
c . add_compare ( " --add-device --disk %(NEWIMG1)s ,size=.01 " , " add-disk-create-storage-start " )
c . add_compare ( " --remove-device --disk /dev/null " , " remove-disk-path-start " )
2019-01-08 20:24:50 +03:00
c = vixml . add_category ( " add/rm devices OS KVM " , " --connect % (URI-KVM)s test --print-diff --define " )
c . add_compare ( " --add-device --disk %(EXISTIMG1)s " , " kvm-add-disk-os-from-xml " ) # Guest OS (none) from XML
c . add_compare ( " --add-device --disk %(EXISTIMG1)s --os-variant fedora28 " , " kvm-add-disk-os-from-cmdline " ) # Guest OS (fedora) provided on command line
c . add_compare ( " --add-device --network default " , " kvm-add-network-os-from-xml " ) # Guest OS information taken from the guest XML
2019-06-14 03:56:16 +03:00
c . add_compare ( " --add-device --network default --os-variant http://fedoraproject.org/fedora/28 " , " kvm-add-network-os-from-cmdline " ) # Guest OS information provided on the command line
2014-01-19 19:37:14 +04:00
2013-04-24 00:16:30 +04:00
2014-12-10 17:33:02 +03:00
####################
# virt-clone tests #
####################
2013-04-24 00:16:30 +04:00
2018-06-12 19:26:13 +03:00
_CLONE_UNMANAGED = " %s /clone-disk.xml " % XMLDIR
_CLONE_MANAGED = " %s /clone-disk-managed.xml " % XMLDIR
_CLONE_NOEXIST = " %s /clone-disk-noexist.xml " % XMLDIR
2019-06-16 20:42:08 +03:00
_CLONE_NVRAM = " %s /clone-nvram-auto.xml " % XMLDIR
2018-06-12 19:26:13 +03:00
2013-04-24 00:16:30 +04:00
vclon = App ( " virt-clone " )
2015-04-23 00:06:35 +03:00
c = vclon . add_category ( " remote " , " --connect % (URI-TEST-REMOTE)s " )
2013-08-17 17:44:11 +04:00
c . add_valid ( " -o test --auto-clone " ) # Auto flag, no storage
2018-06-12 19:26:13 +03:00
c . add_valid ( " --original-xml " + _CLONE_MANAGED + " --auto-clone " ) # Auto flag w/ managed storage
c . add_invalid ( " --original-xml " + _CLONE_UNMANAGED + " --auto-clone " ) # Auto flag w/ local storage, which is invalid for remote connection
2019-06-11 01:13:31 +03:00
c . add_invalid ( " --original-xml " + _CLONE_UNMANAGED + " --auto-clone " ) # Auto flag w/ local storage, which is invalid for remote connection
2013-08-17 17:44:11 +04:00
c = vclon . add_category ( " misc " , " " )
2019-05-16 20:18:12 +03:00
c . add_compare ( " --connect % (URI-KVM)s -o test-clone --auto-clone --clone-running " , " clone-auto1 " )
c . add_compare ( " --connect % (URI-TEST-FULL)s -o test-clone-simple --name newvm --auto-clone --clone-running " , " clone-auto2 " )
2019-06-16 20:42:08 +03:00
c . add_valid ( " --connect % (URI-KVM)s --original-xml " + _CLONE_NVRAM + " --auto-clone --clone-running " ) # hits a particular nvram code path
2019-06-11 01:13:31 +03:00
c . add_valid ( " -o test --auto-clone --uuid 12345678-12F4-1234-1234-123456789AFA --reflink --mac 12:34:56:1A:B2:C3 " ) # Auto flag, no storage
2018-06-12 19:26:13 +03:00
c . add_valid ( " --original-xml " + _CLONE_MANAGED + " --auto-clone " ) # Auto flag w/ managed storage
c . add_valid ( " --original-xml " + _CLONE_UNMANAGED + " --auto-clone " ) # Auto flag w/ local storage
2019-06-15 23:15:01 +03:00
c . add_valid ( " --connect % (URI-TEST-FULL)s -o test-clone --auto-clone --clone-running --nonsparse " ) # Auto flag, actual VM, skip state check
2018-02-20 23:00:46 +03:00
c . add_valid ( " --connect % (URI-TEST-FULL)s -o test-clone-simple -n newvm --preserve-data --file %(EXISTIMG1)s " ) # Preserve data shouldn't complain about existing volume
2018-06-12 19:26:13 +03:00
c . add_valid ( " -n clonetest --original-xml " + _CLONE_UNMANAGED + " --file %(EXISTIMG3)s --file %(EXISTIMG4)s --check path_exists=off " ) # Skip existing file check
2014-12-10 17:33:02 +03:00
c . add_invalid ( " --auto-clone " ) # Just the auto flag
2019-06-11 01:13:31 +03:00
c . add_invalid ( " -o test --file foo " ) # Didn't specify new name
2019-06-15 23:15:01 +03:00
c . add_invalid ( " -o test --auto-clone -n test " ) # new name raises error
2018-02-20 23:00:46 +03:00
c . add_invalid ( " --connect % (URI-TEST-FULL)s -o test-many-devices --auto-clone " ) # VM is running, but --clone-running isn't passed
c . add_invalid ( " --connect % (URI-TEST-FULL)s -o test-clone-simple -n newvm --file %(EXISTIMG1)s --clone-running " ) # Should complain about overwriting existing file
2019-06-15 23:15:01 +03:00
c . add_invalid ( " --connect % (URI-TEST-REMOTE)s -o test-clone-simple --auto-clone --file /dev/default-pool/testvol9.img --check all=off " , grep = " Clone onto existing storage volume " ) # hit a specific error message
2013-08-17 17:44:11 +04:00
c = vclon . add_category ( " general " , " -n clonetest " )
2016-08-19 10:53:43 +03:00
c . add_valid ( " -o test --auto-clone " ) # Auto flag, no storage
2014-02-09 01:36:45 +04:00
c . add_valid ( " -o test --file %(NEWCLONEIMG1)s --file %(NEWCLONEIMG2)s " ) # Nodisk, but with spurious files passed
c . add_valid ( " -o test --file %(NEWCLONEIMG1)s --file %(NEWCLONEIMG2)s --prompt " ) # Working scenario w/ prompt shouldn't ask anything
2018-06-12 19:26:13 +03:00
c . add_valid ( " --original-xml " + _CLONE_UNMANAGED + " --file %(NEWCLONEIMG1)s --file %(NEWCLONEIMG2)s " ) # XML File with 2 disks
2019-06-16 21:38:55 +03:00
c . add_valid ( " --original-xml " + _CLONE_UNMANAGED + " --file %(NEWCLONEIMG1)s --skip-copy=hda " ) # XML w/ disks, skipping one disk target
2018-06-12 19:26:13 +03:00
c . add_valid ( " --original-xml " + _CLONE_UNMANAGED + " --file virt-install --file %(EXISTIMG1)s --preserve " ) # XML w/ disks, overwriting existing files with --preserve
c . add_valid ( " --original-xml " + _CLONE_UNMANAGED + " --file %(NEWCLONEIMG1)s --file %(NEWCLONEIMG2)s --file %(NEWCLONEIMG3)s --force-copy=hdc " ) # XML w/ disks, force copy a readonly target
c . add_valid ( " --original-xml " + _CLONE_UNMANAGED + " --file %(NEWCLONEIMG1)s --file %(NEWCLONEIMG2)s --force-copy=fda " ) # XML w/ disks, force copy a target with no media
c . add_valid ( " --original-xml " + _CLONE_MANAGED + " --file %(NEWIMG1)s " ) # XML w/ managed storage, specify managed path
2019-07-03 02:38:09 +03:00
c . add_valid ( " --original-xml " + _CLONE_MANAGED + " --file %(NEWIMG1)s --reflink " ) # XML w/ managed storage, specify managed path
2018-06-12 19:26:13 +03:00
c . add_valid ( " --original-xml " + _CLONE_NOEXIST + " --file %(EXISTIMG1)s --preserve " ) # XML w/ managed storage, specify managed path across pools# Libvirt test driver doesn't support cloning across pools# XML w/ non-existent storage, with --preserve
2018-02-20 23:00:46 +03:00
c . add_valid ( " --connect % (URI-TEST-FULL)s -o test -n test-clone --auto-clone --replace " ) # Overwriting existing VM
2013-08-17 17:44:11 +04:00
c . add_invalid ( " -o test foobar " ) # Positional arguments error
c . add_invalid ( " -o idontexist " ) # Non-existent vm name
c . add_invalid ( " -o idontexist --auto-clone " ) # Non-existent vm name with auto flag,
c . add_invalid ( " -o test -n test " ) # Colliding new name
2018-06-12 19:26:13 +03:00
c . add_invalid ( " --original-xml " + _CLONE_UNMANAGED + " " ) # XML file with several disks, but non specified
c . add_invalid ( " --original-xml " + _CLONE_UNMANAGED + " --file virt-install --file %(EXISTIMG1)s " ) # XML w/ disks, overwriting existing files with no --preserve
c . add_invalid ( " --original-xml " + _CLONE_UNMANAGED + " --file %(NEWCLONEIMG1)s --file %(NEWCLONEIMG2)s --force-copy=hdc " ) # XML w/ disks, force copy but not enough disks passed
c . add_invalid ( " --original-xml " + _CLONE_MANAGED + " --file /tmp/clonevol " ) # XML w/ managed storage, specify unmanaged path (should fail)
c . add_invalid ( " --original-xml " + _CLONE_NOEXIST + " --file %(EXISTIMG1)s " ) # XML w/ non-existent storage, WITHOUT --preserve
2019-02-28 19:53:58 +03:00
c . add_valid ( " --original-xml " + _CLONE_MANAGED + " --auto-clone --force-copy fda " ) # force copy empty floppy drive
2013-04-24 00:16:30 +04:00
2014-12-10 17:33:02 +03:00
######################
# virt-convert tests #
######################
2018-06-12 19:26:13 +03:00
_OVF_IMG = " %s /tests/virtconv-files/ovf_input/test1.ovf " % os . getcwd ( )
_VMX_IMG = " %s /tests/virtconv-files/vmx_input/test1.vmx " % os . getcwd ( )
2014-12-10 17:33:02 +03:00
vconv = App ( " virt-convert " )
2018-09-01 01:28:08 +03:00
c = vconv . add_category ( " misc " , " --connect % (URI-KVM)s --dry " )
2019-06-11 01:13:31 +03:00
c . add_valid ( _VMX_IMG + " --disk-format qcow2 " ) # hits some more code paths than print-xml
2018-06-12 19:26:13 +03:00
c . add_invalid ( _VMX_IMG + " --input-format foo " ) # invalid input format
2014-12-10 17:33:02 +03:00
c . add_invalid ( " %(EXISTIMG1)s " ) # invalid input file
2018-06-12 19:26:13 +03:00
c . add_compare ( _VMX_IMG + " --disk-format qcow2 --print-xml " , " vmx-compare " )
c . add_compare ( _OVF_IMG + " --disk-format none --destination /tmp --print-xml " , " ovf-compare " )
2014-12-10 17:33:02 +03:00
2018-12-18 22:20:57 +03:00
#################################
# argparse/autocomplete testing #
#################################
ARGCOMPLETE_CMDS = [ ]
def _add_argcomplete_cmd ( line , grep , nogrep = None ) :
env = {
" _ARGCOMPLETE " : " 1 " ,
" COMP_TYPE " : " 9 " ,
" COMP_POINT " : str ( len ( line ) ) ,
" COMP_LINE " : line ,
" _ARGCOMPLETE_COMP_WORDBREAKS " : " \" ' ><;|&(: " ,
}
2019-05-16 20:18:12 +03:00
2019-01-30 19:55:40 +03:00
def have_argcomplete ( ) :
if not argcomplete :
return " argcomplete not installed "
2019-05-16 20:18:12 +03:00
cmd = Command ( line , grep = grep , nogrep = nogrep , env = env , need_conn = False ,
prerun_check = have_argcomplete )
2018-12-18 22:20:57 +03:00
ARGCOMPLETE_CMDS . append ( cmd )
2019-05-16 20:18:12 +03:00
2018-12-18 22:20:57 +03:00
_add_argcomplete_cmd ( " virt-install --di " , " --disk " )
_add_argcomplete_cmd ( " virt-install --disk " , " driver.copy_on_read= " ) # will list all --disk subprops
_add_argcomplete_cmd ( " virt-install --disk a " , " address.base " )
_add_argcomplete_cmd ( " virt-install --disk address.u " , " address.unit " )
_add_argcomplete_cmd ( " virt-install --disk address.unit=foo,sg " , " sgio " )
2019-05-15 20:06:29 +03:00
_add_argcomplete_cmd ( " virt-install --disk path=fooo, " , " driver.cache " ) # will list all --disk subprops
_add_argcomplete_cmd ( " virt-install --disk source.seclab " , " source.seclabel.relabel " ) # completer should strip out regexes from results
2019-01-07 03:01:35 +03:00
_add_argcomplete_cmd ( " virt-install --check d " , " disk_size " )
2019-02-08 00:26:04 +03:00
_add_argcomplete_cmd ( " virt-install --location k " , " kernel " )
2019-06-12 23:56:37 +03:00
_add_argcomplete_cmd ( " virt-install --install i " , " initrd " )
2018-12-18 22:20:57 +03:00
_add_argcomplete_cmd ( " virt-install --test-stub " , None ,
nogrep = " --test-stub-command " )
2019-02-22 11:40:08 +03:00
_add_argcomplete_cmd ( " virt-install --unattended " , " profile= " ) # will list all --unattended subprops
2019-07-03 17:01:28 +03:00
_add_argcomplete_cmd ( " virt-install --unattended a " , " admin-password-file= " )
2018-12-18 22:20:57 +03:00
_add_argcomplete_cmd ( " virt-clone --preserve " , " --preserve-data " )
_add_argcomplete_cmd ( " virt-xml --sound mode " , " model " )
_add_argcomplete_cmd ( " virt-convert --dest " , " --destination " )
2013-04-24 00:16:30 +04:00
2019-07-02 19:55:53 +03:00
##############
# Misc tests #
##############
class CLIMiscTests ( unittest . TestCase ) :
@utils.run_without_testsuite_hacks
def test_virtinstall_no_testsuite ( self ) :
"""
Run virt - install stub command without the testsuite hacks , to test
some code paths like proper logging etc .
"""
cmd = Command (
" virt-install --connect %s "
" --test-stub-command --noautoconsole " %
( utils . URIs . test_suite ) )
cmd . run ( self )
2013-03-18 01:06:52 +04:00
#########################
# Test runner functions #
#########################
newidx = 0
curtest = 0
2013-04-13 22:34:52 +04:00
2013-03-18 01:06:52 +04:00
def setup ( ) :
"""
Create initial test files / dirs
"""
2018-10-13 00:15:20 +03:00
for i in exist_files :
open ( i , " a " )
2013-03-18 01:06:52 +04:00
def cleanup ( ) :
"""
Cleanup temporary files used for testing
"""
for i in clean_files :
2019-07-17 23:54:59 +03:00
if os . path . exists ( i ) :
os . unlink ( i )
2013-03-18 01:06:52 +04:00
2013-04-13 22:34:52 +04:00
2013-03-18 01:06:52 +04:00
class CLITests ( unittest . TestCase ) :
def setUp ( self ) :
global curtest
curtest + = 1
# Only run this for first test
if curtest == 1 :
setup ( )
def tearDown ( self ) :
# Only run this on the last test
if curtest == newidx :
cleanup ( )
2013-04-13 22:34:52 +04:00
2013-03-18 01:06:52 +04:00
def maketest ( cmd ) :
2013-08-17 21:50:36 +04:00
def cmdtemplate ( self , _cmdobj ) :
2013-08-18 16:59:19 +04:00
_cmdobj . run ( self )
2013-03-18 01:06:52 +04:00
return lambda s : cmdtemplate ( s , cmd )
2015-04-23 00:35:39 +03:00
_cmdlist = [ ]
2013-04-24 00:16:30 +04:00
_cmdlist + = vinst . cmds
_cmdlist + = vclon . cmds
_cmdlist + = vconv . cmds
2014-01-19 19:37:14 +04:00
_cmdlist + = vixml . cmds
2018-12-18 22:20:57 +03:00
_cmdlist + = ARGCOMPLETE_CMDS
2013-04-24 00:16:30 +04:00
2016-06-11 22:52:08 +03:00
# Generate numbered names like testCLI%d
2013-03-18 01:06:52 +04:00
for _cmd in _cmdlist :
newidx + = 1
2016-06-11 22:52:08 +03:00
_name = " testCLI %.4d " % newidx
if _cmd . compare_file :
_base = os . path . splitext ( os . path . basename ( _cmd . compare_file ) ) [ 0 ]
_name + = _base . replace ( " - " , " _ " )
else :
_name + = _cmd . app . replace ( " - " , " _ " )
2014-02-01 23:17:03 +04:00
setattr ( CLITests , _name , maketest ( _cmd ) )
2013-03-18 01:06:52 +04:00
atexit . register ( cleanup )