Better stack trace in MAC

Summary:
Now this gives us the real deal stack trace:

    Assertion failed: (false), function GetProperty, file db/db_impl.cc, line 4072.
    Received signal 6 (Abort trap: 6)
    #0   0x7fff57ce39b9
    #1   abort (in libsystem_c.dylib) + 125
    #2   basename (in libsystem_c.dylib) + 0
    #3   rocksdb::DBImpl::GetProperty(rocksdb::ColumnFamilyHandle*, rocksdb::Slice const&, std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> >*) (in db_test) (db_impl.cc:4072)
    #4   rocksdb::_Test_Empty::_Run() (in db_test) (testharness.h:68)
    #5   rocksdb::_Test_Empty::_RunIt() (in db_test) (db_test.cc:1005)
    #6   rocksdb::test::RunAllTests() (in db_test) (testharness.cc:60)
    #7   main (in db_test) (db_test.cc:6697)
    #8   start (in libdyld.dylib) + 1

Test Plan: added artificial assert, saw great stack trace

Reviewers: haobo, dhruba, ljin

Reviewed By: haobo

CC: leveldb

Differential Revision: https://reviews.facebook.net/D18309
main
Igor Canadi 11 years ago
parent a82c492a95
commit 46b3076c91
  1. 26
      port/stack_trace.cc
  2. 3
      util/testharness.cc

@ -70,19 +70,23 @@ void PrintStackTraceLine(const char* symbol, void* frame) {
#elif OS_MACOSX #elif OS_MACOSX
void PrintStackTraceLine(const char* symbol, void* frame) { void PrintStackTraceLine(const char* symbol, void* frame) {
if (symbol) { static int pid = getpid();
char filename[64], function[512], plus[2], line[10]; // out source to atos, for the address translation
sscanf(symbol, "%*s %64s %*s %512s %2s %10s", filename, function, plus, const int kLineMax = 256;
line); char cmd[kLineMax];
int status; snprintf(cmd, kLineMax, "xcrun atos %p -p %d 2>&1", frame, pid);
char* demangled = abi::__cxa_demangle(function, 0, 0, &status); auto f = popen(cmd, "r");
fprintf(stderr, "%s %s %s %s", filename, if (f) {
(status == 0) ? demangled : function, plus, line); char line[kLineMax];
if (demangled) { while (fgets(line, sizeof(line), f)) {
free(demangled); line[strlen(line) - 1] = 0; // remove newline
fprintf(stderr, "%s\t", line);
} }
pclose(f);
} else if (symbol) {
fprintf(stderr, "%s ", symbol);
} }
fprintf(stderr, " %p", frame);
fprintf(stderr, "\n"); fprintf(stderr, "\n");
} }

@ -8,12 +8,11 @@
// found in the LICENSE file. See the AUTHORS file for names of contributors. // found in the LICENSE file. See the AUTHORS file for names of contributors.
#include "util/testharness.h" #include "util/testharness.h"
#include "port/stack_trace.h"
#include <string> #include <string>
#include <stdlib.h> #include <stdlib.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/types.h> #include <sys/types.h>
#include "port/stack_trace.h"
namespace rocksdb { namespace rocksdb {
namespace test { namespace test {

Loading…
Cancel
Save