// Copyright (c) 2011-present, Facebook, Inc. All rights reserved. // This source code is licensed under both the GPLv2 (found in the // COPYING file in the root directory) and Apache 2.0 License // (found in the LICENSE.Apache file in the root 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. #pragma once #ifdef OS_AIX #include "gtest/gtest.h" #else #include #endif // A "skipped" test has a specific meaning in Facebook infrastructure: the // test is in good shape and should be run, but something about the // compilation or execution environment means the test cannot be run. // Specifically, there is a hole in intended testing if any // parameterization of a test (e.g. Foo/FooTest.Bar/42) is skipped for all // tested build configurations/platforms/etc. // // If GTEST_SKIP is available, use it. Otherwise, define skip as success. // // The GTEST macros do not seem to print the message, even with -verbose, // so these print to stderr. Note that these do not exit the test themselves; // calling code should 'return' or similar from the test. #ifdef GTEST_SKIP_ #define ROCKSDB_GTEST_SKIP(m) \ do { \ fputs("SKIPPED: " m "\n", stderr); \ GTEST_SKIP_(m); \ } while (false) /* user ; */ #else #define ROCKSDB_GTEST_SKIP(m) \ do { \ fputs("SKIPPED: " m "\n", stderr); \ GTEST_SUCCESS_("SKIPPED: " m); \ } while (false) /* user ; */ #endif // We add "bypass" as an alternative to ROCKSDB_GTEST_SKIP that is allowed to // be a permanent condition, e.g. for intentionally omitting or disabling some // parameterizations for some tests. (Use _DISABLED at the end of the test // name to disable an entire test.) #define ROCKSDB_GTEST_BYPASS(m) \ do { \ fputs("BYPASSED: " m "\n", stderr); \ GTEST_SUCCESS_("BYPASSED: " m); \ } while (false) /* user ; */ #include #include "rocksdb/env.h" namespace ROCKSDB_NAMESPACE { namespace test { // Return the directory to use for temporary storage. std::string TmpDir(Env* env = Env::Default()); // A path unique within the thread std::string PerThreadDBPath(std::string name); std::string PerThreadDBPath(Env* env, std::string name); std::string PerThreadDBPath(std::string dir, std::string name); // Return a randomization seed for this run. Typically returns the // same number on repeated invocations of this binary, but automated // runs may be able to vary the seed. int RandomSeed(); ::testing::AssertionResult AssertStatus(const char* s_expr, const Status& s); #define ASSERT_OK(s) \ ASSERT_PRED_FORMAT1(ROCKSDB_NAMESPACE::test::AssertStatus, s) #define ASSERT_NOK(s) ASSERT_FALSE((s).ok()) #define EXPECT_OK(s) \ EXPECT_PRED_FORMAT1(ROCKSDB_NAMESPACE::test::AssertStatus, s) #define EXPECT_NOK(s) EXPECT_FALSE((s).ok()) } // namespace test } // namespace ROCKSDB_NAMESPACE