summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJens Freimann <jfreimann@redhat.com>2017-08-08 22:38:59 +0200
committerMichael S. Tsirkin <mst@redhat.com>2017-08-09 04:22:14 +0300
commit24dd1e17696fbd11b3df50718dddcbdfe2c45f24 (patch)
treea47e36f4fe6dad3c0361032ff552ebb0ce9eb1b6
parent2566378d6d13bf4d28c7770bdbda5f7682594bbe (diff)
downloadqemu-24dd1e17696fbd11b3df50718dddcbdfe2c45f24.tar.gz
libqtest: always set up signal handler for SIGABRT
Currently abort handlers only work for the first test function in a testcase, because the list of abort handlers is not properly cleared when qtest_quit() is called. qtest_quit() only deletes the kill_qemu_hook but doesn't completely clear the abrt_hooks list. The effect is that abrt_hooks.is_setup is never set to false and in a following test the abrt_hooks list is not initialized and setup_sigabrt_handler() is not called. One way to solve this is to clear the list in qtest_quit(), but that means only asserts between qtest_start and qtest_quit will be catched by the abort handler. We can make abort handlers work in all cases if we always setup the signal handler for SIGABRT in qtest_init. Signed-off-by: Jens Freimann <jfreimann@redhat.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
-rw-r--r--tests/libqtest.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/tests/libqtest.c b/tests/libqtest.c
index 4a5492a603..b9a1f180e1 100644
--- a/tests/libqtest.c
+++ b/tests/libqtest.c
@@ -140,8 +140,8 @@ void qtest_add_abrt_handler(GHookFunc fn, const void *data)
/* Only install SIGABRT handler once */
if (!abrt_hooks.is_setup) {
g_hook_list_init(&abrt_hooks, sizeof(GHook));
- setup_sigabrt_handler();
}
+ setup_sigabrt_handler();
hook = g_hook_alloc(&abrt_hooks);
hook->func = fn;