summaryrefslogtreecommitdiffstats
path: root/base
diff options
context:
space:
mode:
Diffstat (limited to 'base')
-rw-r--r--base/test_suite.h14
1 files changed, 14 insertions, 0 deletions
diff --git a/base/test_suite.h b/base/test_suite.h
index 236c3ed..e616b80 100644
--- a/base/test_suite.h
+++ b/base/test_suite.h
@@ -13,6 +13,7 @@
#include "base/base_paths.h"
#include "base/command_line.h"
#include "base/debug_on_start.h"
+#include "base/debug_util.h"
#include "base/file_path.h"
#include "base/icu_util.h"
#include "base/logging.h"
@@ -34,6 +35,13 @@
#include <gtk/gtk.h>
#endif
+#if defined(OS_POSIX)
+static void TestSuiteCrashHandler(int signal) {
+ StackTrace().PrintBacktrace();
+ _exit(1);
+}
+#endif
+
class TestSuite {
public:
TestSuite(int argc, char** argv) {
@@ -124,6 +132,12 @@ class TestSuite {
action.sa_flags = 0;
sigemptyset(&action.sa_mask);
CHECK(sigaction(SIGPIPE, &action, NULL) == 0);
+
+ // TODO(phajdan.jr): Catch other crashy signals, like SIGABRT.
+ CHECK(signal(SIGSEGV, &TestSuiteCrashHandler) != SIG_ERR);
+ CHECK(signal(SIGILL, &TestSuiteCrashHandler) != SIG_ERR);
+ CHECK(signal(SIGBUS, &TestSuiteCrashHandler) != SIG_ERR);
+ CHECK(signal(SIGFPE, &TestSuiteCrashHandler) != SIG_ERR);
#endif // OS_POSIX
#if defined(OS_WIN)