From 342ba8089528ac1ed4636f2c320b4508151b1f0b Mon Sep 17 00:00:00 2001 From: sdong Date: Tue, 8 Sep 2015 18:31:36 -0700 Subject: [PATCH] Make DBTest.OptimizeFiltersForHits more deterministic Summary: This commit makes DBTest.OptimizeFiltersForHits more deterministic by: (1) make key inserts more random (2) make sure L0 has one file (3) make file size smaller compared to level target so L1 will cover more range. Test Plan: Run the test many times. Reviewers: rven, IslamAbdelRahman, kradhakrishnan, igor, anthony Reviewed By: anthony Subscribers: leveldb, dhruba Differential Revision: https://reviews.facebook.net/D46461 --- db/db_test.cc | 49 +++++++++++++++++++++++++++++++++++-------------- 1 file changed, 35 insertions(+), 14 deletions(-) diff --git a/db/db_test.cc b/db/db_test.cc index 9fb606f5a8..b2f1b53f36 100644 --- a/db/db_test.cc +++ b/db/db_test.cc @@ -7613,8 +7613,9 @@ TEST_F(DBTest, DontDeleteMovedFile) { TEST_F(DBTest, OptimizeFiltersForHits) { Options options = CurrentOptions(); - options.write_buffer_size = 256 * 1024; - options.target_file_size_base = 256 * 1024; + options.write_buffer_size = 64 * 1024; + options.arena_block_size = 4 * 1024; + options.target_file_size_base = 64 * 1024; options.level0_file_num_compaction_trigger = 2; options.level0_slowdown_writes_trigger = 2; options.level0_stop_writes_trigger = 4; @@ -7622,7 +7623,9 @@ TEST_F(DBTest, OptimizeFiltersForHits) { options.max_write_buffer_number = 2; options.max_background_compactions = 8; options.max_background_flushes = 8; + options.compression = kNoCompression; options.compaction_style = kCompactionStyleLevel; + options.level_compaction_dynamic_level_bytes = true; BlockBasedTableOptions bbto; bbto.filter_policy.reset(NewBloomFilterPolicy(10, true)); bbto.whole_key_filtering = true; @@ -7632,16 +7635,37 @@ TEST_F(DBTest, OptimizeFiltersForHits) { CreateAndReopenWithCF({"mypikachu"}, options); int numkeys = 200000; - for (int i = 0; i < 20; i += 2) { - for (int j = i; j < numkeys; j += 20) { - ASSERT_OK(Put(1, Key(j), "val")); + + // Generate randomly shuffled keys, so the updates are almost + // random. + std::vector keys; + keys.reserve(numkeys); + for (int i = 0; i < numkeys; i += 2) { + keys.push_back(i); + } + std::random_shuffle(std::begin(keys), std::end(keys)); + + int num_inserted = 0; + for (int key : keys) { + ASSERT_OK(Put(1, Key(key), "val")); + if (++num_inserted % 1000 == 0) { + dbfull()->TEST_WaitForFlushMemTable(); + dbfull()->TEST_WaitForCompact(); } } - - + ASSERT_OK(Put(1, Key(0), "val")); + ASSERT_OK(Put(1, Key(numkeys), "val")); ASSERT_OK(Flush(1)); dbfull()->TEST_WaitForCompact(); + if (NumTableFilesAtLevel(0, 1) == 0) { + // No Level 0 file. Create one. + ASSERT_OK(Put(1, Key(0), "val")); + ASSERT_OK(Put(1, Key(numkeys), "val")); + ASSERT_OK(Flush(1)); + dbfull()->TEST_WaitForCompact(); + } + for (int i = 1; i < numkeys; i += 2) { ASSERT_EQ(Get(1, Key(i)), "NOT_FOUND"); } @@ -7650,13 +7674,10 @@ TEST_F(DBTest, OptimizeFiltersForHits) { ASSERT_EQ(0, TestGetTickerCount(options, GET_HIT_L1)); ASSERT_EQ(0, TestGetTickerCount(options, GET_HIT_L2_AND_UP)); - // When the skip_filters_on_last_level is ON, the last level which has - // most of the keys does not use bloom filters. We end up using - // bloom filters in a very small number of cases. Without the flag. - // this number would be close to 150000 (all the key at the last level) + - // some use in the upper levels - // - ASSERT_GT(90000, TestGetTickerCount(options, BLOOM_FILTER_USEFUL)); + // Now we have three sorted run, L0, L5 and L6 with most files in L6 have + // no blooom filter. Most keys be checked bloom filters twice. + ASSERT_GT(TestGetTickerCount(options, BLOOM_FILTER_USEFUL), 65000 * 2); + ASSERT_LT(TestGetTickerCount(options, BLOOM_FILTER_USEFUL), 120000 * 2); for (int i = 0; i < numkeys; i += 2) { ASSERT_EQ(Get(1, Key(i)), "val");