db_stress: wait for compaction to finish after open with failure injection (#8270)
Summary: When injecting in DB open, error can happen in background threads, causing DB open succeed, but DB is soon made read-only and subsequence writes will fail, which is not expected. To prevent it from happening, wait for compaction to finish before serving the traffic. If there is a failure, reopen. Pull Request resolved: https://github.com/facebook/rocksdb/pull/8270 Test Plan: Run the test. Reviewed By: ajkr Differential Revision: D28230537 fbshipit-source-id: e2e97888904f9b9bb50c35ccf95b88c2319ef5c3
This commit is contained in:
parent
e19908cba6
commit
7f3a0f5bc6
@ -2468,6 +2468,16 @@ void StressTest::Open() {
|
||||
#ifndef NDEBUG
|
||||
if (ingest_meta_error) {
|
||||
fault_fs_guard->DisableMetadataWriteErrorInjection();
|
||||
if (s.ok()) {
|
||||
// Ingested errors might happen in background compactions. We
|
||||
// wait for all compactions to finish to make sure DB is in
|
||||
// clean state before executing queries.
|
||||
s = static_cast_with_check<DBImpl>(db_->GetRootDB())
|
||||
->TEST_WaitForCompact(true);
|
||||
if (!s.ok()) {
|
||||
delete db_;
|
||||
}
|
||||
}
|
||||
if (!s.ok()) {
|
||||
// After failure to opening a DB due to IO error, retry should
|
||||
// successfully open the DB with correct data if no IO error shows
|
||||
|
Loading…
Reference in New Issue
Block a user