@ -1868,126 +1868,6 @@ TEST_F(ColumnFamilyTest, SameCFManualAutomaticCompactionsLevel) {
}
}
}
}
// This test checks for automatic getting a conflict if there is a
// manual which has not yet been scheduled.
// The manual compaction waits in NotScheduled
// We generate more files and then trigger an automatic compaction
// This will wait because there is an unscheduled manual compaction.
// Once the conflict is hit, the manual compaction starts and ends
// Then another automatic will start and end.
TEST_F ( ColumnFamilyTest , SameCFManualAutomaticConflict ) {
Open ( ) ;
CreateColumnFamilies ( { " one " } ) ;
ColumnFamilyOptions default_cf , one ;
db_options_ . max_open_files = 20 ; // only 10 files in file cache
db_options_ . max_background_compactions = 3 ;
default_cf . compaction_style = kCompactionStyleLevel ;
default_cf . num_levels = 3 ;
default_cf . write_buffer_size = 64 < < 10 ; // 64KB
default_cf . target_file_size_base = 30 < < 10 ;
default_cf . max_compaction_bytes = default_cf . target_file_size_base * 1100 ;
BlockBasedTableOptions table_options ;
table_options . no_block_cache = true ;
default_cf . table_factory . reset ( NewBlockBasedTableFactory ( table_options ) ) ;
one . compaction_style = kCompactionStyleUniversal ;
one . num_levels = 1 ;
// trigger compaction if there are >= 4 files
one . level0_file_num_compaction_trigger = 4 ;
one . write_buffer_size = 120000 ;
Reopen ( { default_cf , one } ) ;
// make sure all background compaction jobs can be scheduled
auto stop_token =
dbfull ( ) - > TEST_write_controler ( ) . GetCompactionPressureToken ( ) ;
// SETUP column family "one" -- universal style
for ( int i = 0 ; i < one . level0_file_num_compaction_trigger - 2 ; + + i ) {
PutRandomData ( 1 , 10 , 12000 , true ) ;
PutRandomData ( 1 , 1 , 10 , true ) ;
WaitForFlush ( 1 ) ;
AssertFilesPerLevel ( ToString ( i + 1 ) , 1 ) ;
}
bool cf_1_1 = true ;
bool cf_1_2 = true ;
rocksdb : : SyncPoint : : GetInstance ( ) - > LoadDependency (
{ { " DBImpl::BackgroundCompaction()::Conflict " ,
" ColumnFamilyTest::ManualAutoCon:7 " } ,
{ " ColumnFamilyTest::ManualAutoCon:9 " ,
" ColumnFamilyTest::ManualAutoCon:8 " } ,
{ " ColumnFamilyTest::ManualAutoCon:2 " ,
" ColumnFamilyTest::ManualAutoCon:6 " } ,
{ " ColumnFamilyTest::ManualAutoCon:4 " ,
" ColumnFamilyTest::ManualAutoCon:5 " } ,
{ " ColumnFamilyTest::ManualAutoCon:1 " ,
" ColumnFamilyTest::ManualAutoCon:2 " } ,
{ " ColumnFamilyTest::ManualAutoCon:1 " ,
" ColumnFamilyTest::ManualAutoCon:3 " } } ) ;
rocksdb : : SyncPoint : : GetInstance ( ) - > SetCallBack (
" DBImpl::BackgroundCompaction:NonTrivial:AfterRun " , [ & ] ( void * arg ) {
if ( cf_1_1 ) {
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:4 " ) ;
cf_1_1 = false ;
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:3 " ) ;
} else if ( cf_1_2 ) {
cf_1_2 = false ;
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:2 " ) ;
}
} ) ;
rocksdb : : SyncPoint : : GetInstance ( ) - > SetCallBack (
" DBImpl::RunManualCompaction:NotScheduled " , [ & ] ( void * arg ) {
InstrumentedMutex * mutex = static_cast < InstrumentedMutex * > ( arg ) ;
mutex - > Unlock ( ) ;
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:9 " ) ;
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:7 " ) ;
mutex - > Lock ( ) ;
} ) ;
rocksdb : : SyncPoint : : GetInstance ( ) - > EnableProcessing ( ) ;
rocksdb : : port : : Thread threads ( [ & ] {
CompactRangeOptions compact_options ;
compact_options . exclusive_manual_compaction = false ;
ASSERT_OK (
db_ - > CompactRange ( compact_options , handles_ [ 1 ] , nullptr , nullptr ) ) ;
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:6 " ) ;
} ) ;
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:8 " ) ;
WaitForFlush ( 1 ) ;
// Add more L0 files and force automatic compaction
for ( int i = 0 ; i < one . level0_file_num_compaction_trigger ; + + i ) {
PutRandomData ( 1 , 10 , 12000 , true ) ;
PutRandomData ( 1 , 1 , 10 , true ) ;
WaitForFlush ( 1 ) ;
AssertFilesPerLevel ( ToString ( one . level0_file_num_compaction_trigger + i ) ,
1 ) ;
}
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:5 " ) ;
// Add more L0 files and force automatic compaction
for ( int i = 0 ; i < one . level0_file_num_compaction_trigger ; + + i ) {
PutRandomData ( 1 , 10 , 12000 , true ) ;
PutRandomData ( 1 , 1 , 10 , true ) ;
WaitForFlush ( 1 ) ;
}
TEST_SYNC_POINT ( " ColumnFamilyTest::ManualAutoCon:1 " ) ;
threads . join ( ) ;
WaitForCompaction ( ) ;
// VERIFY compaction "one"
ASSERT_LE ( NumTableFilesAtLevel ( 0 , 1 ) , 3 ) ;
// Compare against saved keys
std : : set < std : : string > : : iterator key_iter = keys_ . begin ( ) ;
while ( key_iter ! = keys_ . end ( ) ) {
ASSERT_NE ( " NOT_FOUND " , Get ( 1 , * key_iter ) ) ;
key_iter + + ;
}
}
// In this test, we generate enough files to trigger automatic compactions.
// In this test, we generate enough files to trigger automatic compactions.
// The automatic compaction waits in NonTrivial:AfterRun
// The automatic compaction waits in NonTrivial:AfterRun
// We generate more files and then trigger an automatic compaction
// We generate more files and then trigger an automatic compaction