46b3076c91
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
85 lines
2.0 KiB
C++
85 lines
2.0 KiB
C++
// Copyright (c) 2013, Facebook, Inc. All rights reserved.
|
|
// This source code is licensed under the BSD-style license found in the
|
|
// LICENSE file in the root directory of this source tree. An additional grant
|
|
// of patent rights can be found in the PATENTS file in the same directory.
|
|
//
|
|
// Copyright (c) 2011 The LevelDB Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file. See the AUTHORS file for names of contributors.
|
|
|
|
#include "util/testharness.h"
|
|
#include <string>
|
|
#include <stdlib.h>
|
|
#include <sys/stat.h>
|
|
#include <sys/types.h>
|
|
#include "port/stack_trace.h"
|
|
|
|
namespace rocksdb {
|
|
namespace test {
|
|
|
|
namespace {
|
|
struct Test {
|
|
const char* base;
|
|
const char* name;
|
|
void (*func)();
|
|
};
|
|
std::vector<Test>* tests;
|
|
}
|
|
|
|
bool RegisterTest(const char* base, const char* name, void (*func)()) {
|
|
if (tests == nullptr) {
|
|
tests = new std::vector<Test>;
|
|
}
|
|
Test t;
|
|
t.base = base;
|
|
t.name = name;
|
|
t.func = func;
|
|
tests->push_back(t);
|
|
return true;
|
|
}
|
|
|
|
int RunAllTests() {
|
|
port::InstallStackTraceHandler();
|
|
|
|
const char* matcher = getenv("ROCKSDB_TESTS");
|
|
|
|
int num = 0;
|
|
if (tests != nullptr) {
|
|
for (unsigned int i = 0; i < tests->size(); i++) {
|
|
const Test& t = (*tests)[i];
|
|
if (matcher != nullptr) {
|
|
std::string name = t.base;
|
|
name.push_back('.');
|
|
name.append(t.name);
|
|
if (strstr(name.c_str(), matcher) == nullptr) {
|
|
continue;
|
|
}
|
|
}
|
|
fprintf(stderr, "==== Test %s.%s\n", t.base, t.name);
|
|
(*t.func)();
|
|
++num;
|
|
}
|
|
}
|
|
fprintf(stderr, "==== PASSED %d tests\n", num);
|
|
return 0;
|
|
}
|
|
|
|
std::string TmpDir() {
|
|
std::string dir;
|
|
Status s = Env::Default()->GetTestDirectory(&dir);
|
|
ASSERT_TRUE(s.ok()) << s.ToString();
|
|
return dir;
|
|
}
|
|
|
|
int RandomSeed() {
|
|
const char* env = getenv("TEST_RANDOM_SEED");
|
|
int result = (env != nullptr ? atoi(env) : 301);
|
|
if (result <= 0) {
|
|
result = 301;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
} // namespace test
|
|
} // namespace rocksdb
|