Skip to content

Commit

Permalink
tests/pvpanic: Make the pvpanic test independent of global_qtest
Browse files Browse the repository at this point in the history
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 <[email protected]>
Signed-off-by: Thomas Huth <[email protected]>
  • Loading branch information
huth committed Dec 17, 2018
1 parent ac16ab7 commit 791a289
Showing 1 changed file with 8 additions and 6 deletions.
14 changes: 8 additions & 6 deletions tests/pvpanic-test.c
Original file line number Diff line number Diff line change
Expand Up @@ -15,20 +15,25 @@ 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"));
data = qdict_get_qdict(response, "data");
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)
Expand All @@ -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;
}

0 comments on commit 791a289

Please sign in to comment.