diff --git a/db/compaction/compaction.cc b/db/compaction/compaction.cc index 181df406d2c..4667ab1379a 100644 --- a/db/compaction/compaction.cc +++ b/db/compaction/compaction.cc @@ -545,10 +545,8 @@ std::unique_ptr Compaction::CreateCompactionFilter( context.is_full_compaction = is_full_compaction_; context.is_manual_compaction = is_manual_compaction_; context.is_bottommost_level = bottommost_level_; - context.start_key = - (start == nullptr) ? GetSmallestUserKey() : ExtractUserKey(*start); - context.end_key = - (end == nullptr) ? GetLargestUserKey() : ExtractUserKey(*end); + context.start_key = (start == nullptr) ? GetSmallestUserKey() : *start; + context.end_key = (end == nullptr) ? GetLargestUserKey() : *end; context.is_end_key_inclusive = (end == nullptr); for (auto l = inputs_.begin(); l != inputs_.end(); ++l) { for (auto f = l->files.begin(); f != l->files.end(); ++f) { diff --git a/db/compaction/compaction_service_test.cc b/db/compaction/compaction_service_test.cc index 5a4ff7799c5..b99bdaaaeb7 100644 --- a/db/compaction/compaction_service_test.cc +++ b/db/compaction/compaction_service_test.cc @@ -546,6 +546,59 @@ TEST_P(CompactionServiceTest, CompactionFilter) { ASSERT_GE(my_cs->GetCompactionNum(), 1); } +class EmptyFilter : public CompactionFilter { + public: + bool Filter(int /*level*/, const Slice& /*key*/, const Slice& /*value*/, + std::string* /*new_value*/, + bool* /*value_changed*/) const override { + return false; + } + + const char* Name() const override { return "EmptyFilter"; } +}; + +class EmptyFilterFactory : public CompactionFilterFactory { + public: + explicit EmptyFilterFactory() : compaction_filter_created_(false) {} + + std::unique_ptr CreateCompactionFilter( + const CompactionFilter::Context&) override { + compaction_filter_created_ = true; + return std::unique_ptr(new EmptyFilter()); + } + + bool compaction_filter_created() const { return compaction_filter_created_; } + + const char* Name() const override { return "EmptyFilterFactory"; } + bool compaction_filter_created_; +}; + +TEST_P(CompactionServiceTest, SubCompactionWithFilterFactory) { + EmptyFilterFactory* filter = new EmptyFilterFactory(); + Options options = CurrentOptions(); + options.compaction_filter_factory.reset(filter); + options.max_subcompactions = 10; + options.target_file_size_base = 1 << 10; // 1KB + options.disable_auto_compactions = true; + ReopenWithCompactionService(&options); + + GenerateTestData(); + VerifyTestData(); + + auto my_cs = GetCompactionService(); + int compaction_num_before = my_cs->GetCompactionNum(); + + auto cro = CompactRangeOptions(); + cro.max_subcompactions = 10; + Status s = db_->CompactRange(cro, nullptr, nullptr); + ASSERT_OK(s); + VerifyTestData(); + int compaction_num = my_cs->GetCompactionNum() - compaction_num_before; + // make sure there's sub-compaction by checking the compaction number + ASSERT_GE(compaction_num, 2); + ASSERT_TRUE(filter->compaction_filter_created()); +} + TEST_P(CompactionServiceTest, Snapshot) { Options options = CurrentOptions(); ReopenWithCompactionService(&options);