mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-09 02:24:58 -06:00
qapi: Implement deprecated-input=reject for QMP commands
This policy rejects deprecated input, and thus permits "testing the future". Implement it for QMP commands: make deprecated ones fail. Example: when QEMU is run with -compat deprecated-input=reject, then {"execute": "query-cpus"} fails like this {"error": {"class": "CommandNotFound", "desc": "Deprecated command query-cpus disabled by policy"}} When the deprecated command is removed, the error will change to {"error": {"class": "CommandNotFound", "desc": "The command query-cpus has not been found"}} Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Message-Id: <20210318155519.1224118-10-armbru@redhat.com>
This commit is contained in:
parent
130d482422
commit
d2032598c4
4 changed files with 45 additions and 3 deletions
|
@ -281,6 +281,28 @@ static void test_dispatch_cmd_io(void)
|
|||
qobject_unref(ret3);
|
||||
}
|
||||
|
||||
static void test_dispatch_cmd_deprecated(void)
|
||||
{
|
||||
const char *cmd = "{ 'execute': 'test-command-features1' }";
|
||||
QDict *ret;
|
||||
|
||||
memset(&compat_policy, 0, sizeof(compat_policy));
|
||||
|
||||
/* accept */
|
||||
ret = qobject_to(QDict, do_qmp_dispatch(false, cmd));
|
||||
assert(ret && qdict_size(ret) == 0);
|
||||
qobject_unref(ret);
|
||||
|
||||
compat_policy.has_deprecated_input = true;
|
||||
compat_policy.deprecated_input = COMPAT_POLICY_INPUT_ACCEPT;
|
||||
ret = qobject_to(QDict, do_qmp_dispatch(false, cmd));
|
||||
assert(ret && qdict_size(ret) == 0);
|
||||
qobject_unref(ret);
|
||||
|
||||
compat_policy.deprecated_input = COMPAT_POLICY_INPUT_REJECT;
|
||||
do_qmp_dispatch_error(false, ERROR_CLASS_COMMAND_NOT_FOUND, cmd);
|
||||
}
|
||||
|
||||
static void test_dispatch_cmd_ret_deprecated(void)
|
||||
{
|
||||
const char *cmd = "{ 'execute': 'test-features0' }";
|
||||
|
@ -379,6 +401,8 @@ int main(int argc, char **argv)
|
|||
g_test_add_func("/qmp/dispatch_cmd_io", test_dispatch_cmd_io);
|
||||
g_test_add_func("/qmp/dispatch_cmd_success_response",
|
||||
test_dispatch_cmd_success_response);
|
||||
g_test_add_func("/qmp/dispatch_cmd_deprecated",
|
||||
test_dispatch_cmd_deprecated);
|
||||
g_test_add_func("/qmp/dispatch_cmd_ret_deprecated",
|
||||
test_dispatch_cmd_ret_deprecated);
|
||||
g_test_add_func("/qmp/dealloc_types", test_dealloc_types);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue