2018-05-17 07:31:43 +02:00
|
|
|
#include <gmock/gmock.h>
|
2018-05-19 07:29:41 +02:00
|
|
|
#include <csignal>
|
2018-05-17 07:31:43 +02:00
|
|
|
#include "cpp-utils/assert/backtrace.h"
|
|
|
|
|
|
|
|
using std::string;
|
|
|
|
using testing::HasSubstr;
|
|
|
|
|
|
|
|
TEST(BacktraceTest, ContainsExecutableName) {
|
|
|
|
string backtrace = cpputils::backtrace();
|
|
|
|
EXPECT_THAT(backtrace, HasSubstr("cpp-utils-test"));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(BacktraceTest, ContainsTopLevelLine) {
|
|
|
|
string backtrace = cpputils::backtrace();
|
|
|
|
EXPECT_THAT(backtrace, HasSubstr("BacktraceTest"));
|
|
|
|
EXPECT_THAT(backtrace, HasSubstr("ContainsTopLevelLine"));
|
|
|
|
}
|
2018-05-17 07:42:03 +02:00
|
|
|
|
|
|
|
namespace {
|
2018-07-09 04:34:08 +02:00
|
|
|
void nullptr_access() {
|
|
|
|
cpputils::showBacktraceOnCrash();
|
|
|
|
int* ptr = nullptr;
|
|
|
|
*ptr = 5;
|
|
|
|
}
|
2018-05-19 07:29:41 +02:00
|
|
|
}
|
2018-07-09 04:34:08 +02:00
|
|
|
|
|
|
|
#if defined(_MSC_VER)
|
|
|
|
#include <Windows.h>
|
|
|
|
namespace {
|
|
|
|
void raise_sigsegv() {
|
|
|
|
cpputils::showBacktraceOnCrash();
|
|
|
|
::RaiseException(EXCEPTION_ACCESS_VIOLATION, EXCEPTION_NONCONTINUABLE, 0, NULL);
|
|
|
|
}
|
|
|
|
void raise_sigill() {
|
|
|
|
cpputils::showBacktraceOnCrash();
|
|
|
|
::RaiseException(EXCEPTION_ILLEGAL_INSTRUCTION, EXCEPTION_NONCONTINUABLE, 0, NULL);
|
|
|
|
}
|
|
|
|
void raise_code(DWORD exception_code) {
|
|
|
|
cpputils::showBacktraceOnCrash();
|
|
|
|
::RaiseException(exception_code, EXCEPTION_NONCONTINUABLE, 0, NULL);
|
|
|
|
}
|
2018-05-17 07:42:03 +02:00
|
|
|
}
|
2018-07-09 04:34:08 +02:00
|
|
|
#else
|
|
|
|
namespace {
|
|
|
|
void raise_sigsegv() {
|
|
|
|
cpputils::showBacktraceOnCrash();
|
|
|
|
::raise(SIGSEGV);
|
|
|
|
}
|
|
|
|
void raise_sigabrt() {
|
|
|
|
cpputils::showBacktraceOnCrash();
|
|
|
|
::raise(SIGABRT);
|
|
|
|
}
|
|
|
|
void raise_sigill() {
|
|
|
|
cpputils::showBacktraceOnCrash();
|
|
|
|
::raise(SIGILL);
|
|
|
|
}
|
2018-05-17 07:42:03 +02:00
|
|
|
}
|
2018-07-09 04:34:08 +02:00
|
|
|
#endif
|
2018-05-17 07:42:03 +02:00
|
|
|
|
2018-05-19 07:29:41 +02:00
|
|
|
TEST(BacktraceTest, ShowBacktraceOnNullptrAccess) {
|
2018-05-17 07:42:03 +02:00
|
|
|
EXPECT_DEATH(
|
2018-07-09 04:34:08 +02:00
|
|
|
nullptr_access(),
|
|
|
|
"ShowBacktraceOnNullptrAccess_Test::TestBody"
|
2018-05-17 07:42:03 +02:00
|
|
|
);
|
|
|
|
}
|
2018-05-19 07:29:41 +02:00
|
|
|
|
|
|
|
TEST(BacktraceTest, ShowBacktraceOnSigSegv) {
|
|
|
|
EXPECT_DEATH(
|
2018-07-09 04:34:08 +02:00
|
|
|
raise_sigsegv(),
|
|
|
|
"ShowBacktraceOnSigSegv_Test::TestBody"
|
2018-05-19 07:29:41 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2018-07-09 04:34:08 +02:00
|
|
|
TEST(BacktraceTest, ShowBacktraceOnSigIll) {
|
|
|
|
EXPECT_DEATH(
|
|
|
|
raise_sigill(),
|
|
|
|
"ShowBacktraceOnSigIll_Test::TestBody"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined(_MSC_VER)
|
2018-05-19 07:29:41 +02:00
|
|
|
TEST(BacktraceTest, ShowBacktraceOnSigAbrt) {
|
|
|
|
EXPECT_DEATH(
|
2018-07-09 04:34:08 +02:00
|
|
|
raise_sigabrt(),
|
|
|
|
"ShowBacktraceOnSigAbrt_Test::TestBody"
|
2018-05-19 07:29:41 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2018-07-09 04:34:08 +02:00
|
|
|
TEST(BacktraceTest, ShowBacktraceOnSigAbrt_ShowsCorrectSignalName) {
|
|
|
|
EXPECT_DEATH(
|
|
|
|
raise_sigabrt(),
|
|
|
|
"SIGABRT"
|
|
|
|
);
|
2018-05-19 07:29:41 +02:00
|
|
|
}
|
2018-07-09 04:34:08 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(_MSC_VER)
|
|
|
|
constexpr const char* sigsegv_message = "SIGSEGV";
|
|
|
|
constexpr const char* sigill_message = "SIGILL";
|
|
|
|
#else
|
|
|
|
constexpr const char* sigsegv_message = "EXCEPTION_ACCESS_VIOLATION";
|
|
|
|
constexpr const char* sigill_message = "EXCEPTION_ILLEGAL_INSTRUCTION";
|
|
|
|
#endif
|
2018-05-19 07:29:41 +02:00
|
|
|
|
|
|
|
TEST(BacktraceTest, ShowBacktraceOnSigSegv_ShowsCorrectSignalName) {
|
2018-07-09 04:34:08 +02:00
|
|
|
EXPECT_DEATH(
|
|
|
|
raise_sigsegv(),
|
|
|
|
sigsegv_message
|
|
|
|
);
|
2018-05-19 07:29:41 +02:00
|
|
|
}
|
|
|
|
|
2018-07-09 04:34:08 +02:00
|
|
|
TEST(BacktraceTest, ShowBacktraceOnSigIll_ShowsCorrectSignalName) {
|
2018-05-19 07:29:41 +02:00
|
|
|
EXPECT_DEATH(
|
2018-07-09 04:34:08 +02:00
|
|
|
raise_sigill(),
|
|
|
|
sigill_message
|
2018-05-19 07:29:41 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2018-07-09 04:34:08 +02:00
|
|
|
#if defined(_MSC_VER)
|
|
|
|
TEST(BacktraceTest, UnknownCode_ShowsCorrectSignalName) {
|
|
|
|
EXPECT_DEATH(
|
|
|
|
raise_code(0x12345678),
|
|
|
|
"UNKNOWN_CODE\\(0x12345678\\)"
|
|
|
|
);
|
2018-05-19 07:29:41 +02:00
|
|
|
}
|
2018-07-09 04:34:08 +02:00
|
|
|
#endif
|