@ -214,6 +214,8 @@ class ColumnFamilyTest {
}
}
int CountLiveLogFiles ( ) {
int CountLiveLogFiles ( ) {
int micros_wait_for_log_deletion = 20000 ;
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
int ret = 0 ;
int ret = 0 ;
VectorLogPtr wal_files ;
VectorLogPtr wal_files ;
Status s ;
Status s ;
@ -467,7 +469,6 @@ TEST(ColumnFamilyTest, FlushTest) {
TEST ( ColumnFamilyTest , LogDeletionTest ) {
TEST ( ColumnFamilyTest , LogDeletionTest ) {
column_family_options_ . write_buffer_size = 100000 ; // 100KB
column_family_options_ . write_buffer_size = 100000 ; // 100KB
Open ( ) ;
Open ( ) ;
int micros_wait_for_log_deletion = 20000 ;
CreateColumnFamilies ( { " one " , " two " , " three " , " four " } ) ;
CreateColumnFamilies ( { " one " , " two " , " three " , " four " } ) ;
// Each bracket is one log file. if number is in (), it means
// Each bracket is one log file. if number is in (), it means
// we don't need it anymore (it's been flushed)
// we don't need it anymore (it's been flushed)
@ -480,63 +481,52 @@ TEST(ColumnFamilyTest, LogDeletionTest) {
PutRandomData ( 1 , 1000 , 100 ) ;
PutRandomData ( 1 , 1000 , 100 ) ;
WaitForFlush ( 1 ) ;
WaitForFlush ( 1 ) ;
// [0, (1)] [1]
// [0, (1)] [1]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 2 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 2 ) ;
PutRandomData ( 0 , 1 , 100 ) ;
PutRandomData ( 0 , 1 , 100 ) ;
// [0, (1)] [0, 1]
// [0, (1)] [0, 1]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 2 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 2 ) ;
PutRandomData ( 2 , 1 , 100 ) ;
PutRandomData ( 2 , 1 , 100 ) ;
// [0, (1)] [0, 1, 2]
// [0, (1)] [0, 1, 2]
PutRandomData ( 2 , 1000 , 100 ) ;
PutRandomData ( 2 , 1000 , 100 ) ;
WaitForFlush ( 2 ) ;
WaitForFlush ( 2 ) ;
// [0, (1)] [0, 1, (2)] [2]
// [0, (1)] [0, 1, (2)] [2]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 3 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 3 ) ;
PutRandomData ( 2 , 1000 , 100 ) ;
PutRandomData ( 2 , 1000 , 100 ) ;
WaitForFlush ( 2 ) ;
WaitForFlush ( 2 ) ;
// [0, (1)] [0, 1, (2)] [(2)] [2]
// [0, (1)] [0, 1, (2)] [(2)] [2]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 4 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 4 ) ;
PutRandomData ( 3 , 1 , 100 ) ;
PutRandomData ( 3 , 1 , 100 ) ;
// [0, (1)] [0, 1, (2)] [(2)] [2, 3]
// [0, (1)] [0, 1, (2)] [(2)] [2, 3]
PutRandomData ( 1 , 1 , 100 ) ;
PutRandomData ( 1 , 1 , 100 ) ;
// [0, (1)] [0, 1, (2)] [(2)] [1, 2, 3]
// [0, (1)] [0, 1, (2)] [(2)] [1, 2, 3]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 4 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 4 ) ;
PutRandomData ( 1 , 1000 , 100 ) ;
PutRandomData ( 1 , 1000 , 100 ) ;
WaitForFlush ( 1 ) ;
WaitForFlush ( 1 ) ;
// [0, (1)] [0, (1), (2)] [(2)] [(1), 2, 3] [1]
// [0, (1)] [0, (1), (2)] [(2)] [(1), 2, 3] [1]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 5 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 5 ) ;
PutRandomData ( 0 , 1000 , 100 ) ;
PutRandomData ( 0 , 1000 , 100 ) ;
WaitForFlush ( 0 ) ;
WaitForFlush ( 0 ) ;
// [(0), (1)] [(0), (1), (2)] [(2)] [(1), 2, 3] [1, (0)] [0]
// [(0), (1)] [(0), (1), (2)] [(2)] [(1), 2, 3] [1, (0)] [0]
// delete obsolete logs -->
// delete obsolete logs -->
// [(1), 2, 3] [1, (0)] [0]
// [(1), 2, 3] [1, (0)] [0]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 3 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 3 ) ;
PutRandomData ( 0 , 1000 , 100 ) ;
PutRandomData ( 0 , 1000 , 100 ) ;
WaitForFlush ( 0 ) ;
WaitForFlush ( 0 ) ;
// [(1), 2, 3] [1, (0)], [(0)] [0]
// [(1), 2, 3] [1, (0)], [(0)] [0]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 4 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 4 ) ;
PutRandomData ( 1 , 1000 , 100 ) ;
PutRandomData ( 1 , 1000 , 100 ) ;
WaitForFlush ( 1 ) ;
WaitForFlush ( 1 ) ;
// [(1), 2, 3] [(1), (0)] [(0)] [0, (1)] [1]
// [(1), 2, 3] [(1), (0)] [(0)] [0, (1)] [1]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 5 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 5 ) ;
PutRandomData ( 2 , 1000 , 100 ) ;
PutRandomData ( 2 , 1000 , 100 ) ;
WaitForFlush ( 2 ) ;
WaitForFlush ( 2 ) ;
// [(1), (2), 3] [(1), (0)] [(0)] [0, (1)] [1, (2)], [2]
// [(1), (2), 3] [(1), (0)] [(0)] [0, (1)] [1, (2)], [2]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 6 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 6 ) ;
PutRandomData ( 3 , 1000 , 100 ) ;
PutRandomData ( 3 , 1000 , 100 ) ;
WaitForFlush ( 3 ) ;
WaitForFlush ( 3 ) ;
// [(1), (2), (3)] [(1), (0)] [(0)] [0, (1)] [1, (2)], [2, (3)] [3]
// [(1), (2), (3)] [(1), (0)] [(0)] [0, (1)] [1, (2)], [2, (3)] [3]
// delete obsolete logs -->
// delete obsolete logs -->
// [0, (1)] [1, (2)], [2, (3)] [3]
// [0, (1)] [1, (2)], [2, (3)] [3]
env_ - > SleepForMicroseconds ( micros_wait_for_log_deletion ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 4 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 4 ) ;
Close ( ) ;
Close ( ) ;
}
}
@ -566,9 +556,9 @@ TEST(ColumnFamilyTest, DifferentWriteBufferSizes) {
Reopen ( { default_cf , one , two , three } ) ;
Reopen ( { default_cf , one , two , three } ) ;
int micros_wait_for_flush = 30 0000;
int micros_wait_for_flush = 1 0000;
PutRandomData ( 0 , 100 , 1000 ) ;
PutRandomData ( 0 , 100 , 1000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 0 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 1 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 1 ) ;
PutRandomData ( 1 , 200 , 1000 ) ;
PutRandomData ( 1 , 200 , 1000 ) ;
@ -596,15 +586,15 @@ TEST(ColumnFamilyTest, DifferentWriteBufferSizes) {
AssertNumberOfImmutableMemtables ( { 0 , 1 , 2 , 3 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 1 , 2 , 3 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 7 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 7 ) ;
PutRandomData ( 0 , 100 , 1000 ) ;
PutRandomData ( 0 , 100 , 1000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 0 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 1 , 2 , 3 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 1 , 2 , 3 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 8 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 8 ) ;
PutRandomData ( 2 , 100 , 10000 ) ;
PutRandomData ( 2 , 100 , 10000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 2 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 1 , 0 , 3 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 1 , 0 , 3 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 9 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 9 ) ;
PutRandomData ( 3 , 90 , 1000 ) ;
PutRandomData ( 3 , 90 , 1000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 3 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 1 , 0 , 0 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 1 , 0 , 0 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 10 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 10 ) ;
PutRandomData ( 3 , 90 , 1000 ) ;
PutRandomData ( 3 , 90 , 1000 ) ;
@ -612,23 +602,23 @@ TEST(ColumnFamilyTest, DifferentWriteBufferSizes) {
AssertNumberOfImmutableMemtables ( { 0 , 1 , 0 , 1 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 1 , 0 , 1 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 11 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 11 ) ;
PutRandomData ( 1 , 200 , 1000 ) ;
PutRandomData ( 1 , 200 , 1000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 1 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 1 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 1 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 5 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 5 ) ;
PutRandomData ( 3 , 90 * 6 , 1000 ) ;
PutRandomData ( 3 , 90 * 6 , 1000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 3 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 12 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 12 ) ;
PutRandomData ( 0 , 100 , 1000 ) ;
PutRandomData ( 0 , 100 , 1000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 0 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 12 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 12 ) ;
PutRandomData ( 2 , 3 * 100 , 10000 ) ;
PutRandomData ( 2 , 3 * 100 , 10000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 2 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 12 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 12 ) ;
PutRandomData ( 1 , 2 * 200 , 1000 ) ;
PutRandomData ( 1 , 2 * 200 , 1000 ) ;
env_ - > SleepForMicroseconds ( micros_wait_for_flush ) ;
WaitForFlush ( 1 ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
AssertNumberOfImmutableMemtables ( { 0 , 0 , 0 , 0 } ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 7 ) ;
ASSERT_EQ ( CountLiveLogFiles ( ) , 7 ) ;
Close ( ) ;
Close ( ) ;