Improve the robustness of PartialCompactionFailure test again.

Summary:
Improve the robustness of PartialCompactionFailure test again.

Test Plan:
./db_test
main
Yueh-Hsuan Chiang 10 years ago
parent 60fa7d1365
commit fb3f8ffe5e
  1. 25
      db/db_test.cc

@ -9061,18 +9061,6 @@ TEST(DBTest, PartialCompactionFailure) {
options.max_bytes_for_level_multiplier = 2; options.max_bytes_for_level_multiplier = 2;
options.compression = kNoCompression; options.compression = kNoCompression;
// The number of NewWritableFiles calls required by each operation.
const int kNumInitialNewWritableFiles = 4;
const int kNumLevel0FlushNewWritableFiles =
options.level0_file_num_compaction_trigger * 2;
const int kNumLevel1NewWritableFiles =
options.level0_file_num_compaction_trigger + 1;
// This setting will make one of the file-creation fail
// in the first L0 -> L1 compaction while making sure
// all flushes succeeed.
env_->periodic_non_writable_ =
kNumInitialNewWritableFiles + kNumLevel0FlushNewWritableFiles +
kNumLevel1NewWritableFiles - 2;
options.env = env_; options.env = env_;
DestroyAndReopen(&options); DestroyAndReopen(&options);
@ -9080,7 +9068,7 @@ TEST(DBTest, PartialCompactionFailure) {
const int kNumKeys = const int kNumKeys =
options.level0_file_num_compaction_trigger * options.level0_file_num_compaction_trigger *
(options.max_write_buffer_number - 1) * (options.max_write_buffer_number - 1) *
kKeysPerBuffer * 0.95; kKeysPerBuffer;
Random rnd(301); Random rnd(301);
std::vector<std::string> keys; std::vector<std::string> keys;
@ -9096,6 +9084,15 @@ TEST(DBTest, PartialCompactionFailure) {
ASSERT_GE(NumTableFilesAtLevel(0), ASSERT_GE(NumTableFilesAtLevel(0),
options.level0_file_num_compaction_trigger); options.level0_file_num_compaction_trigger);
auto previous_num_level0_files = NumTableFilesAtLevel(0); auto previous_num_level0_files = NumTableFilesAtLevel(0);
// The number of NewWritableFiles calls required by each operation.
const int kNumLevel1NewWritableFiles =
options.level0_file_num_compaction_trigger + 1;
// This setting will make one of the file-creation fail
// in the first L0 -> L1 compaction while making sure
// all flushes succeeed.
env_->periodic_non_writable_ = kNumLevel1NewWritableFiles - 2;
// Expect compaction to fail here as one file will fail its // Expect compaction to fail here as one file will fail its
// creation. // creation.
dbfull()->TEST_WaitForCompact(); dbfull()->TEST_WaitForCompact();
@ -9109,6 +9106,8 @@ TEST(DBTest, PartialCompactionFailure) {
ASSERT_EQ(values[k], Get(keys[k])); ASSERT_EQ(values[k], Get(keys[k]));
} }
env_->periodic_non_writable_ = 0;
// Make sure RocksDB will not get into corrupted state. // Make sure RocksDB will not get into corrupted state.
Reopen(&options); Reopen(&options);

Loading…
Cancel
Save