2 QEMU Object Model testing tools.
4 usage: qom [-h] {set,get,list,tree} ...
6 Query and manipulate QOM data
9 -h, --help show this help message and exit
13 set Set a QOM property value
14 get Get a QOM property value
15 list List QOM properties at a given path
16 tree Show QOM tree from a given path
19 # Copyright John Snow 2020, for Red Hat, Inc.
20 # Copyright IBM, Corp. 2011
23 # John Snow <jsnow@redhat.com>
24 # Anthony Liguori <aliguori@amazon.com>
26 # This work is licensed under the terms of the GNU GPL, version 2 or later.
27 # See the COPYING file in the top-level directory.
29 # Based on ./scripts/qmp/qom-[set|get|tree|list]
34 from . import QMPResponseError
35 from .qom_common
import QOMCommand
38 class QOMSet(QOMCommand
):
40 QOM Command - Set a property to a given value.
42 usage: qom-set [-h] [--socket SOCKET] <path>.<property> <value>
44 Set a QOM property value
47 <path>.<property> QOM path and property, separated by a period '.'
48 <value> new QOM property value
51 -h, --help show this help message and exit
52 --socket SOCKET, -s SOCKET
53 QMP socket path or address (addr:port). May also be
54 set via QMP_SOCKET environment variable.
57 help = 'Set a QOM property value'
60 def configure_parser(cls
, parser
: argparse
.ArgumentParser
) -> None:
61 super().configure_parser(parser
)
62 cls
.add_path_prop_arg(parser
)
67 help='new QOM property value'
70 def __init__(self
, args
: argparse
.Namespace
):
71 super().__init
__(args
)
72 self
.path
, self
.prop
= args
.path_prop
.rsplit('.', 1)
73 self
.value
= args
.value
76 rsp
= self
.qmp
.command(
86 class QOMGet(QOMCommand
):
88 QOM Command - Get a property's current value.
90 usage: qom-get [-h] [--socket SOCKET] <path>.<property>
92 Get a QOM property value
95 <path>.<property> QOM path and property, separated by a period '.'
98 -h, --help show this help message and exit
99 --socket SOCKET, -s SOCKET
100 QMP socket path or address (addr:port). May also be
101 set via QMP_SOCKET environment variable.
104 help = 'Get a QOM property value'
107 def configure_parser(cls
, parser
: argparse
.ArgumentParser
) -> None:
108 super().configure_parser(parser
)
109 cls
.add_path_prop_arg(parser
)
111 def __init__(self
, args
: argparse
.Namespace
):
112 super().__init
__(args
)
114 tmp
= args
.path_prop
.rsplit('.', 1)
115 except ValueError as err
:
116 raise ValueError('Invalid format for <path>.<property>') from err
120 def run(self
) -> int:
121 rsp
= self
.qmp
.command(
126 if isinstance(rsp
, dict):
127 for key
, value
in rsp
.items():
128 print(f
"{key}: {value}")
134 class QOMList(QOMCommand
):
136 QOM Command - List the properties at a given path.
138 usage: qom-list [-h] [--socket SOCKET] <path>
140 List QOM properties at a given path
142 positional arguments:
146 -h, --help show this help message and exit
147 --socket SOCKET, -s SOCKET
148 QMP socket path or address (addr:port). May also be
149 set via QMP_SOCKET environment variable.
152 help = 'List QOM properties at a given path'
155 def configure_parser(cls
, parser
: argparse
.ArgumentParser
) -> None:
156 super().configure_parser(parser
)
164 def __init__(self
, args
: argparse
.Namespace
):
165 super().__init
__(args
)
166 self
.path
= args
.path
168 def run(self
) -> int:
169 rsp
= self
.qom_list(self
.path
)
172 print(f
"{item.name}/")
174 print(f
"@{item.name}/")
180 class QOMTree(QOMCommand
):
182 QOM Command - Show the full tree below a given path.
184 usage: qom-tree [-h] [--socket SOCKET] [<path>]
186 Show QOM tree from a given path
188 positional arguments:
192 -h, --help show this help message and exit
193 --socket SOCKET, -s SOCKET
194 QMP socket path or address (addr:port). May also be
195 set via QMP_SOCKET environment variable.
198 help = 'Show QOM tree from a given path'
201 def configure_parser(cls
, parser
: argparse
.ArgumentParser
) -> None:
202 super().configure_parser(parser
)
212 def __init__(self
, args
: argparse
.Namespace
):
213 super().__init
__(args
)
214 self
.path
= args
.path
216 def _list_node(self
, path
: str) -> None:
218 items
= self
.qom_list(path
)
223 rsp
= self
.qmp
.command('qom-get', path
=path
,
225 print(f
" {item.name}: {rsp} ({item.type})")
226 except QMPResponseError
as err
:
227 print(f
" {item.name}: <EXCEPTION: {err!s}> ({item.type})")
234 self
._list
_node
(f
"{path}/{item.name}")
236 def run(self
) -> int:
237 self
._list
_node
(self
.path
)
242 """QOM script main entry point."""
243 parser
= argparse
.ArgumentParser(
244 description
='Query and manipulate QOM data'
246 subparsers
= parser
.add_subparsers(
247 title
='QOM commands',
251 for command
in QOMCommand
.__subclasses
__():
252 command
.register(subparsers
)
254 args
= parser
.parse_args()
256 if args
.command
is None:
257 parser
.error('Command not specified.')
260 cmd_class
= args
.cmd_class
261 assert isinstance(cmd_class
, type(QOMCommand
))
262 return cmd_class
.command_runner(args
)