Skip to content

Commit

Permalink
Do no rely on clock to wait for error recovery.
Browse files Browse the repository at this point in the history
  • Loading branch information
cbi42 committed Sep 21, 2023
1 parent 4b6b4bf commit de7feb1
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 26 deletions.
25 changes: 10 additions & 15 deletions db/db_flush_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -3235,7 +3235,7 @@ TEST_F(DBFlushTest, NonAtomicFlushRollbackPendingFlushes) {
SyncPoint::GetInstance()->LoadDependency(
{{"Let mem1 flush start", "Mem1 flush starts"},
{"DBImpl::BGWorkFlush:done", "Wait for mem1 flush to finish"},
{"StartRecoverFromRetryableBGIOError::in_progress",
{"RecoverFromRetryableBGIOError:RecoverSuccess",
"Wait for error recover"}});
// Need first flush to wait for the second flush to finish
SyncPoint::GetInstance()->EnableProcessing();
Expand All @@ -3247,7 +3247,6 @@ TEST_F(DBFlushTest, NonAtomicFlushRollbackPendingFlushes) {
ASSERT_OK(Put(Key(3), "val3"));

TEST_SYNC_POINT("Wait for error recover");
dbfull()->TEST_WaitForErrorRecovery();
ASSERT_EQ(1, NumTableFilesAtLevel(0));
}

Expand Down Expand Up @@ -3305,18 +3304,15 @@ TEST_F(DBFlushTest, AbortNonAtomicFlushWhenBGError) {
TEST_SYNC_POINT("Mem2 flush waits until rollback");
}
});
SyncPoint::GetInstance()->LoadDependency({
{"Let mem1 flush start", "Mem1 flush starts"},
{"DBImpl::BGWorkFlush:done", "Wait for mem1 flush to finish"},
{"StartRecoverFromRetryableBGIOError::in_progress",
"Wait for error recover"},
{"Let mem2 flush start", "Mem2 flush starts"},
{"Mem2 flush starts writing table",
"Wait for mem2 to start writing table"},
{"RollbackMemtableFlush", "Mem2 flush waits until rollback"}
// The following events occur while Flush for mem2 is writing output file
// without mutex.
});
SyncPoint::GetInstance()->LoadDependency(
{{"Let mem1 flush start", "Mem1 flush starts"},
{"DBImpl::BGWorkFlush:done", "Wait for mem1 flush to finish"},
{"Let mem2 flush start", "Mem2 flush starts"},
{"Mem2 flush starts writing table",
"Wait for mem2 to start writing table"},
{"RollbackMemtableFlush", "Mem2 flush waits until rollback"},
{"RecoverFromRetryableBGIOError:RecoverSuccess",
"Wait for error recover"}});
// Need first flush to wait for the second flush to finish
SyncPoint::GetInstance()->EnableProcessing();
ASSERT_OK(Put(Key(1), "val1"));
Expand All @@ -3330,7 +3326,6 @@ TEST_F(DBFlushTest, AbortNonAtomicFlushWhenBGError) {
ASSERT_OK(Put(Key(4), "val4"));

TEST_SYNC_POINT("Wait for error recover");
dbfull()->TEST_WaitForErrorRecovery();
// Recovery flush writes 3 memtables together into 1 file.
ASSERT_EQ(1, NumTableFilesAtLevel(0));
SyncPoint::GetInstance()->ClearAllCallBacks();
Expand Down
2 changes: 0 additions & 2 deletions db/db_impl/db_impl.h
Original file line number Diff line number Diff line change
Expand Up @@ -1088,8 +1088,6 @@ class DBImpl : public DB {

Status TEST_SwitchMemtable(ColumnFamilyData* cfd = nullptr);

void TEST_WaitForErrorRecovery();

// Force current memtable contents to be flushed.
Status TEST_FlushMemTable(bool wait = true, bool allow_write_stall = false,
ColumnFamilyHandle* cfh = nullptr);
Expand Down
9 changes: 0 additions & 9 deletions db/db_impl/db_impl_debug.cc
Original file line number Diff line number Diff line change
Expand Up @@ -134,15 +134,6 @@ Status DBImpl::TEST_SwitchMemtable(ColumnFamilyData* cfd) {
return s;
}

void DBImpl::TEST_WaitForErrorRecovery() {
InstrumentedMutexLock l(&mutex_);
while (error_handler_.IsRecoveryInProgress()) {
// 0.5 seconds
bg_cv_.TimedWait(immutable_db_options_.clock->NowMicros() +
1000 * 1000 * 0.5);
}
}

Status DBImpl::TEST_FlushMemTable(bool wait, bool allow_write_stall,
ColumnFamilyHandle* cfh) {
FlushOptions fo;
Expand Down

0 comments on commit de7feb1

Please sign in to comment.