4 # Copyright (c) 2018 Vojtech Horky
7 # Redistribution and use in source and binary forms, with or without
8 # modification, are permitted provided that the following conditions
11 # - Redistributions of source code must retain the above copyright
12 # notice, this list of conditions and the following disclaimer.
13 # - Redistributions in binary form must reproduce the above copyright
14 # notice, this list of conditions and the following disclaimer in the
15 # documentation and/or other materials provided with the distribution.
16 # - The name of the author may not be used to endorse or promote products
17 # derived from this software without specific prior written permission.
19 # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
20 # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
21 # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22 # IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
23 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
24 # NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
28 # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37 from htest
.vm
.controller
import VMManager
38 from htest
.vm
.qemu
import QemuVMController
39 from htest
.tasks
import *
41 args
= argparse
.ArgumentParser(description
='HelenOS VM tests')
42 args
.add_argument('--headless',
46 help='Do not show any VM windows.'
48 args
.add_argument('--scenario',
49 metavar
='FILENAME.yml',
51 default
='scenarios/base/pcut.yml',
54 args
.add_argument('--arch',
55 metavar
='ARCHITECTURE',
58 help='Emulated architecture identification.'
60 args
.add_argument('--memory',
66 help='Amount of memory for the virtual machine.'
68 args
.add_argument('--image',
72 help='HelenOS boot image (e.g. ISO file).'
74 args
.add_argument('--pass',
76 dest
='pass_thru_options',
79 help='Extra options to pass through to the emulator'
81 args
.add_argument('--vterm-dump',
82 metavar
='FILENAME.txt',
85 help='Where to store full vterm dump.'
87 args
.add_argument('--last-screenshot',
88 metavar
='FILENAME.png',
89 dest
='last_screenshot',
91 help='Where to store last screenshot.'
93 args
.add_argument('--debug',
97 help='Print debugging messages'
100 config
= args
.parse_args()
103 config
.logging_level
= logging
.DEBUG
105 config
.logging_level
= logging
.INFO
108 format
='[%(asctime)s %(name)-16s %(levelname)7s] %(message)s',
109 level
=config
.logging_level
112 logger
= logging
.getLogger('main')
114 with
open(config
.scenario
, 'r') as f
:
116 scenario
= yaml
.load(f
)
117 except yaml
.YAMLError
as ex
:
121 if config
.memory
< 8:
122 logger
.error("Specify at least 8MB of memory.")
126 for ctl
in [ QemuVMController
]:
127 if ctl
.is_supported(config
.architecture
):
130 if controller
is None:
131 logger
.error("Unsupported architecture {}.".format(config
.architecture
))
134 vmm
= VMManager(controller
, config
.architecture
, config
.boot_image
, config
.memory
, config
.headless
, config
.pass_thru_options
)
137 for t
in scenario
['tasks']:
140 k
= list(set(t
.keys()) - set(['name', 'machine']))
142 raise Exception("Unknown task ({})!".format(k
))
150 raise Exception("Unknown task!")
151 task_classname
= 'ScenarioTask' + task_name
.title().replace('-', '_')
152 task_class
= globals()[task_classname
]
153 task_inst
= task_class(t
[task_name
])
154 if not ('machine' in t
):
156 machine
= vmm
.get(t
['machine'])
158 if t
['machine'] is None:
159 t
['machine'] = 'default'
160 logger
.debug("Creating new machine {}.".format(t
['machine']))
161 machine
= vmm
.create(t
['machine'])
162 task_inst
.set_machine(machine
)
163 scenario_tasks
.append(task_inst
)
167 for t
in scenario_tasks
:
169 except Exception as ex
:
173 vmm
.terminate(config
.vterm_dump
, config
.last_screenshot
)