Commit 791a289b authored by Thomas Huth's avatar Thomas Huth
Browse files

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: default avatarEric Blake <eblake@redhat.com>
Signed-off-by: default avatarThomas Huth <thuth@redhat.com>
parent ac16ab75
Loading
Loading
Loading
Loading
+8 −6
Original line number Diff line number Diff line
@@ -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;
}