Summary: TickersNameMap is not consistent with Tickers enum. this cause us to report wrong statistics and sometimes to access TickersNameMap outside it's boundary causing crashes (in Fb303 statistics) Test Plan: added new unit test Reviewers: sdong, kradhakrishnan Reviewed By: kradhakrishnan Subscribers: andrewkr, dhruba Differential Revision: https://reviews.facebook.net/D61083main
parent
16e225f70d
commit
f8061a237e
@ -0,0 +1,35 @@ |
|||||||
|
// Copyright (c) 2011-present, 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.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include "port/stack_trace.h" |
||||||
|
#include "util/testharness.h" |
||||||
|
#include "util/testutil.h" |
||||||
|
|
||||||
|
#include "rocksdb/statistics.h" |
||||||
|
|
||||||
|
namespace rocksdb { |
||||||
|
|
||||||
|
class StatisticsTest : public testing::Test {}; |
||||||
|
|
||||||
|
// Sanity check to make sure that contents and order of TickersNameMap
|
||||||
|
// match Tickers enum
|
||||||
|
TEST_F(StatisticsTest, Sanity) { |
||||||
|
EXPECT_EQ(static_cast<size_t>(Tickers::TICKER_ENUM_MAX), |
||||||
|
TickersNameMap.size()); |
||||||
|
|
||||||
|
for (uint32_t t = 0; t < Tickers::TICKER_ENUM_MAX; t++) { |
||||||
|
auto pair = TickersNameMap[static_cast<size_t>(t)]; |
||||||
|
ASSERT_EQ(pair.first, t) << "Miss match at " << pair.second; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
} // namespace rocksdb
|
||||||
|
|
||||||
|
int main(int argc, char** argv) { |
||||||
|
rocksdb::port::InstallStackTraceHandler(); |
||||||
|
::testing::InitGoogleTest(&argc, argv); |
||||||
|
return RUN_ALL_TESTS(); |
||||||
|
} |
Loading…
Reference in new issue