Improve SimpleWriteTimeoutTest to avoid false alarm.

Summary:
SimpleWriteTimeoutTest has two parts: 1) insert two large key/values
to make memtable full and expect both of them are successful; 2) insert
another key / value and expect it to be timed-out.  Previously we also
set a timeout in the first step, but this might sometimes cause
false alarm.

This diff makes the first two writes run without timeout setting.

Test Plan:
export ROCKSDB_TESTS=Time
make db_test

Reviewers: sdong, ljin

Reviewed By: ljin

Subscribers: leveldb

Differential Revision: https://reviews.facebook.net/D19461
main
Yueh-Hsuan Chiang 11 years ago
parent 8d9a46fcd1
commit 7b85c1e900
  1. 3
      db/db_test.cc

@ -7012,13 +7012,14 @@ TEST(DBTest, SimpleWriteTimeoutTest) {
options.min_write_buffer_number_to_merge = 3; options.min_write_buffer_number_to_merge = 3;
options.max_total_wal_size = std::numeric_limits<uint64_t>::max(); options.max_total_wal_size = std::numeric_limits<uint64_t>::max();
WriteOptions write_opt = WriteOptions(); WriteOptions write_opt = WriteOptions();
write_opt.timeout_hint_us = 500; write_opt.timeout_hint_us = 0;
DestroyAndReopen(&options); DestroyAndReopen(&options);
// fill the two write buffer // fill the two write buffer
ASSERT_OK(Put(Key(1), Key(1) + std::string(100000, 'v'), write_opt)); ASSERT_OK(Put(Key(1), Key(1) + std::string(100000, 'v'), write_opt));
ASSERT_OK(Put(Key(2), Key(2) + std::string(100000, 'v'), write_opt)); ASSERT_OK(Put(Key(2), Key(2) + std::string(100000, 'v'), write_opt));
// As the only two write buffers are full in this moment, the third // As the only two write buffers are full in this moment, the third
// Put is expected to be timed-out. // Put is expected to be timed-out.
write_opt.timeout_hint_us = 300;
ASSERT_TRUE( ASSERT_TRUE(
Put(Key(3), Key(3) + std::string(100000, 'v'), write_opt).IsTimedOut()); Put(Key(3), Key(3) + std::string(100000, 'v'), write_opt).IsTimedOut());
} }

Loading…
Cancel
Save