update unit tests.

This commit is contained in:
bowang 2022-05-13 00:42:10 -07:00
parent 91da17d383
commit 255825463d
3 changed files with 87 additions and 15 deletions

View File

@ -137,6 +137,8 @@ class CompactionJob {
IOStatus io_status_; IOStatus io_status_;
private: private:
friend class CompactionJobTestBase;
// Generates a histogram representing potential divisions of key ranges from // Generates a histogram representing potential divisions of key ranges from
// the input. It adds the starting and/or ending keys of certain input files // the input. It adds the starting and/or ending keys of certain input files
// to the working set and then finds the approximate size of data in between // to the working set and then finds the approximate size of data in between

View File

@ -321,7 +321,8 @@ class CompactionJobTestBase : public testing::Test {
const std::vector<SequenceNumber>& snapshots = {}, const std::vector<SequenceNumber>& snapshots = {},
SequenceNumber earliest_write_conflict_snapshot = kMaxSequenceNumber, SequenceNumber earliest_write_conflict_snapshot = kMaxSequenceNumber,
int output_level = 1, bool verify = true, int output_level = 1, bool verify = true,
uint64_t expected_oldest_blob_file_number = kInvalidBlobFileNumber) { uint64_t expected_oldest_blob_file_number = kInvalidBlobFileNumber,
bool check_get_priority = false) {
auto cfd = versions_->GetColumnFamilySet()->GetDefault(); auto cfd = versions_->GetColumnFamilySet()->GetDefault();
size_t num_input_files = 0; size_t num_input_files = 0;
@ -390,6 +391,58 @@ class CompactionJobTestBase : public testing::Test {
expected_oldest_blob_file_number); expected_oldest_blob_file_number);
} }
} }
if (check_get_priority) {
CheckGetRateLimiterPriority(compaction_job);
}
}
void CheckGetRateLimiterPriority(CompactionJob& compaction_job) {
// When the state from WriteController is normal.
ASSERT_EQ(
compaction_job.GetRateLimiterPriority(RateLimiter::OpType::kWrite),
Env::IO_LOW);
ASSERT_EQ(compaction_job.GetRateLimiterPriority(RateLimiter::OpType::kRead),
Env::IO_LOW);
WriteController* write_controller =
compaction_job.versions_->GetColumnFamilySet()->write_controller();
{
// When the state from WriteController is CompactionPressure.
std::unique_ptr<WriteControllerToken> compaction_pressure_token =
write_controller->GetCompactionPressureToken();
ASSERT_EQ(
compaction_job.GetRateLimiterPriority(RateLimiter::OpType::kWrite),
Env::IO_HIGH);
ASSERT_EQ(
compaction_job.GetRateLimiterPriority(RateLimiter::OpType::kRead),
Env::IO_HIGH);
}
{
// When the state from WriteController is Delayed.
std::unique_ptr<WriteControllerToken> delay_token =
write_controller->GetDelayToken(1000000);
ASSERT_EQ(
compaction_job.GetRateLimiterPriority(RateLimiter::OpType::kWrite),
Env::IO_USER);
ASSERT_EQ(
compaction_job.GetRateLimiterPriority(RateLimiter::OpType::kRead),
Env::IO_USER);
}
{
// When the state from WriteController is Stopped.
std::unique_ptr<WriteControllerToken> stop_token =
write_controller->GetStopToken();
ASSERT_EQ(
compaction_job.GetRateLimiterPriority(RateLimiter::OpType::kWrite),
Env::IO_USER);
ASSERT_EQ(
compaction_job.GetRateLimiterPriority(RateLimiter::OpType::kRead),
Env::IO_USER);
}
} }
std::shared_ptr<Env> env_guard_; std::shared_ptr<Env> env_guard_;
@ -1288,6 +1341,17 @@ TEST_F(CompactionJobTest, ResultSerialization) {
} }
} }
TEST_F(CompactionJobTest, GetRateLimiterPriority) {
NewDB();
auto expected_results = CreateTwoFiles(false);
auto cfd = versions_->GetColumnFamilySet()->GetDefault();
auto files = cfd->current()->storage_info()->LevelFiles(0);
ASSERT_EQ(2U, files.size());
RunCompaction({files}, expected_results, {}, kMaxSequenceNumber, 1, true,
kInvalidBlobFileNumber, true);
}
class CompactionJobTimestampTest : public CompactionJobTestBase { class CompactionJobTimestampTest : public CompactionJobTestBase {
public: public:
CompactionJobTimestampTest() CompactionJobTimestampTest()

View File

@ -581,20 +581,26 @@ TEST_F(FlushJobTest, GetRateLimiterPriority) {
WriteController* write_controller = WriteController* write_controller =
flush_job.versions_->GetColumnFamilySet()->write_controller(); flush_job.versions_->GetColumnFamilySet()->write_controller();
// When the state from WriteController is Delayed.
std::unique_ptr<WriteControllerToken> delay_token = {
write_controller->GetDelayToken(1000000); // When the state from WriteController is Delayed.
ASSERT_EQ(flush_job.GetRateLimiterPriority(RateLimiter::OpType::kWrite), std::unique_ptr<WriteControllerToken> delay_token =
Env::IO_USER); write_controller->GetDelayToken(1000000);
ASSERT_EQ(flush_job.GetRateLimiterPriority(RateLimiter::OpType::kRead), ASSERT_EQ(flush_job.GetRateLimiterPriority(RateLimiter::OpType::kWrite),
Env::IO_USER); Env::IO_USER);
// When the state from WriteController is Stopped. ASSERT_EQ(flush_job.GetRateLimiterPriority(RateLimiter::OpType::kRead),
std::unique_ptr<WriteControllerToken> stop_token = Env::IO_USER);
write_controller->GetStopToken(); }
ASSERT_EQ(flush_job.GetRateLimiterPriority(RateLimiter::OpType::kWrite),
Env::IO_USER); {
ASSERT_EQ(flush_job.GetRateLimiterPriority(RateLimiter::OpType::kRead), // When the state from WriteController is Stopped.
Env::IO_USER); std::unique_ptr<WriteControllerToken> stop_token =
write_controller->GetStopToken();
ASSERT_EQ(flush_job.GetRateLimiterPriority(RateLimiter::OpType::kWrite),
Env::IO_USER);
ASSERT_EQ(flush_job.GetRateLimiterPriority(RateLimiter::OpType::kRead),
Env::IO_USER);
}
} }
class FlushJobTimestampTest : public FlushJobTestBase { class FlushJobTimestampTest : public FlushJobTestBase {