summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Huth2018-11-05 16:30:43 +0100
committerThomas Huth2018-12-17 15:36:40 +0100
commit791a289badd77a9c920c59609ce0a4f5b1ed5f5e (patch)
treefb7c3dc59851aa12a013139222c3e2971d8ddbb2
parenttests/vmgenid: Make test independent of global_qtest (diff)
downloadqemu-791a289badd77a9c920c59609ce0a4f5b1ed5f5e.tar.gz
qemu-791a289badd77a9c920c59609ce0a4f5b1ed5f5e.tar.xz
qemu-791a289badd77a9c920c59609ce0a4f5b1ed5f5e.zip
tests/pvpanic: Make the pvpanic test independent of global_qtest
We want to get rid of global_qtest in the long run, thus do not use the wrappers like inb() and outb() here anymore. Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Thomas Huth <thuth@redhat.com>
-rw-r--r--tests/pvpanic-test.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/tests/pvpanic-test.c b/tests/pvpanic-test.c
index 7461a7254f..ff9176adf3 100644
--- a/tests/pvpanic-test.c
+++ b/tests/pvpanic-test.c
@@ -15,13 +15,16 @@ static void test_panic(void)
{
uint8_t val;
QDict *response, *data;
+ QTestState *qts;
- val = inb(0x505);
+ qts = qtest_init("-device pvpanic");
+
+ val = qtest_inb(qts, 0x505);
g_assert_cmpuint(val, ==, 1);
- outb(0x505, 0x1);
+ qtest_outb(qts, 0x505, 0x1);
- response = qmp_receive();
+ response = qtest_qmp_receive(qts);
g_assert(qdict_haskey(response, "event"));
g_assert_cmpstr(qdict_get_str(response, "event"), ==, "GUEST_PANICKED");
g_assert(qdict_haskey(response, "data"));
@@ -29,6 +32,8 @@ static void test_panic(void)
g_assert(qdict_haskey(data, "action"));
g_assert_cmpstr(qdict_get_str(data, "action"), ==, "pause");
qobject_unref(response);
+
+ qtest_quit(qts);
}
int main(int argc, char **argv)
@@ -38,10 +43,7 @@ int main(int argc, char **argv)
g_test_init(&argc, &argv, NULL);
qtest_add_func("/pvpanic/panic", test_panic);
- qtest_start("-device pvpanic");
ret = g_test_run();
- qtest_end();
-
return ret;
}