db_test: fix a data race in SpecialEnv

Summary: db_test's test class SpecialEnv has a thread unsafe variable rnd_ but it can be accessed by multiple threads. It is complained by TSAN. Protect it by a mutex.

Test Plan: Run the test

Reviewers: yhchiang, rven, igor

Reviewed By: igor

Subscribers: leveldb, dhruba

Differential Revision: https://reviews.facebook.net/D32895
main
sdong 10 years ago
parent fe9f691194
commit 53ae09c398
  1. 7
      db/db_test.cc

@ -133,6 +133,7 @@ static std::string Key(int i) {
class SpecialEnv : public EnvWrapper { class SpecialEnv : public EnvWrapper {
public: public:
Random rnd_; Random rnd_;
port::Mutex rnd_mutex_; // Lock to pretect rnd_
// sstable Sync() calls are blocked while this pointer is non-nullptr. // sstable Sync() calls are blocked while this pointer is non-nullptr.
std::atomic<bool> delay_sstable_sync_; std::atomic<bool> delay_sstable_sync_;
@ -294,7 +295,11 @@ class SpecialEnv : public EnvWrapper {
}; };
if (non_writeable_rate_.load(std::memory_order_acquire) > 0) { if (non_writeable_rate_.load(std::memory_order_acquire) > 0) {
auto random_number = rnd_.Uniform(100); uint32_t random_number;
{
MutexLock l(&rnd_mutex_);
random_number = rnd_.Uniform(100);
}
if (random_number < non_writeable_rate_.load()) { if (random_number < non_writeable_rate_.load()) {
return Status::IOError("simulated random write error"); return Status::IOError("simulated random write error");
} }

Loading…
Cancel
Save