add an env var ROCKSDB_TESTS_FROM to control where to start from a list of tests

Summary:
Sometimes, I got a test failure. After fixing that, I want to resume
db_test from that test. ROCKSDB_TESTS_FROM is for this purpose.

Test Plan: as title

Reviewers: yhchiang, rven, igor, sdong

Reviewed By: sdong

Subscribers: dhruba, leveldb

Differential Revision: https://reviews.facebook.net/D27807
main
Lei Jin 10 years ago
parent e130e88bc6
commit 97451f837e
  1. 25
      util/testharness.cc
  2. 8
      util/testharness.h

@ -41,18 +41,29 @@ bool RegisterTest(const char* base, const char* name, void (*func)()) {
int RunAllTests() { int RunAllTests() {
port::InstallStackTraceHandler(); port::InstallStackTraceHandler();
const char* matcher = getenv("ROCKSDB_TESTS"); const char* one_matcher = getenv("ROCKSDB_TESTS");
const char* from_matcher = getenv("ROCKSDB_TESTS_FROM");
int num = 0; int num = 0;
bool tests_on = (one_matcher == nullptr && from_matcher == nullptr);
if (tests != nullptr) { if (tests != nullptr) {
for (unsigned int i = 0; i < tests->size(); i++) { for (unsigned int i = 0; i < tests->size(); i++) {
const Test& t = (*tests)[i]; const Test& t = (*tests)[i];
if (matcher != nullptr) { if (tests_on == false) {
std::string name = t.base; if (one_matcher != nullptr || from_matcher != nullptr) {
name.push_back('.'); std::string name = t.base;
name.append(t.name); name.push_back('.');
if (strstr(name.c_str(), matcher) == nullptr) { name.append(t.name);
continue; if (from_matcher != nullptr &&
strstr(name.c_str(), from_matcher) != nullptr) {
tests_on = true;
}
if (!tests_on) {
if (one_matcher == nullptr ||
strstr(name.c_str(), one_matcher) == nullptr) {
continue;
}
}
} }
} }
fprintf(stderr, "==== Test %s.%s\n", t.base, t.name); fprintf(stderr, "==== Test %s.%s\n", t.base, t.name);

@ -21,9 +21,11 @@ namespace rocksdb {
namespace test { namespace test {
// Run some of the tests registered by the TEST() macro. If the // Run some of the tests registered by the TEST() macro. If the
// environment variable "ROCKSDB_TESTS" is not set, runs all tests. // environment variable "ROCKSDB_TESTS" and "ROCKSDB_TESTS_FROM"
// Otherwise, runs only the tests whose name contains the value of // are not set, runs all tests. Otherwise, run all tests after
// "ROCKSDB_TESTS" as a substring. E.g., suppose the tests are: // ROCKSDB_TESTS_FROM and those specified by ROCKSDB_TESTS.
// Partial name match also works for ROCKSDB_TESTS and
// ROCKSDB_TESTS_FROM. E.g., suppose the tests are:
// TEST(Foo, Hello) { ... } // TEST(Foo, Hello) { ... }
// TEST(Foo, World) { ... } // TEST(Foo, World) { ... }
// ROCKSDB_TESTS=Hello will run the first test // ROCKSDB_TESTS=Hello will run the first test

Loading…
Cancel
Save