@ -3810,6 +3810,59 @@ TEST_F(DBTest, TrivialMoveOneFile) { 
			
		
	
		
			
				
					  rocksdb : : SyncPoint : : GetInstance ( ) - > DisableProcessing ( ) ;   
			
		
	
		
			
				
					}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					TEST_F ( DBTest ,  TrivialMoveToLastLevelWithFiles )  {  
			
		
	
		
			
				
					  int32_t  trivial_move  =  0 ;   
			
		
	
		
			
				
					  int32_t  non_trivial_move  =  0 ;   
			
		
	
		
			
				
					  rocksdb : : SyncPoint : : GetInstance ( ) - > SetCallBack (   
			
		
	
		
			
				
					      " DBImpl::BackgroundCompaction:TrivialMove " ,   
			
		
	
		
			
				
					      [ & ] ( void *  arg )  {  trivial_move + + ;  } ) ;   
			
		
	
		
			
				
					  rocksdb : : SyncPoint : : GetInstance ( ) - > SetCallBack (   
			
		
	
		
			
				
					      " DBImpl::BackgroundCompaction:NonTrivial " ,   
			
		
	
		
			
				
					      [ & ] ( void *  arg )  {  non_trivial_move + + ;  } ) ;   
			
		
	
		
			
				
					  rocksdb : : SyncPoint : : GetInstance ( ) - > EnableProcessing ( ) ;   
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  Options  options ;   
			
		
	
		
			
				
					  options . write_buffer_size  =  100000000 ;   
			
		
	
		
			
				
					  options  =  CurrentOptions ( options ) ;   
			
		
	
		
			
				
					  DestroyAndReopen ( options ) ;   
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  int32_t  value_size  =  10  *  1024 ;   // 10 KB
   
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  Random  rnd ( 301 ) ;   
			
		
	
		
			
				
					  std : : vector < std : : string >  values ;   
			
		
	
		
			
				
					  // File with keys [ 0 => 99 ]
   
			
		
	
		
			
				
					  for  ( int  i  =  0 ;  i  <  100 ;  i + + )  {   
			
		
	
		
			
				
					    values . push_back ( RandomString ( & rnd ,  value_size ) ) ;   
			
		
	
		
			
				
					    ASSERT_OK ( Put ( Key ( i ) ,  values [ i ] ) ) ;   
			
		
	
		
			
				
					  }   
			
		
	
		
			
				
					  ASSERT_OK ( Flush ( ) ) ;   
			
		
	
		
			
				
					  ASSERT_EQ ( " 1 " ,  FilesPerLevel ( 0 ) ) ;   
			
		
	
		
			
				
					  ASSERT_OK ( db_ - > CompactRange ( nullptr ,  nullptr ,  true ,  3 ) ) ;   
			
		
	
		
			
				
					  ASSERT_EQ ( " 0,0,0,1 " ,  FilesPerLevel ( 0 ) ) ;   
			
		
	
		
			
				
					  // Compaction did L0=>L1 (trivial move) then moved L1 files to L3
   
			
		
	
		
			
				
					  ASSERT_EQ ( trivial_move ,  1 ) ;   
			
		
	
		
			
				
					  ASSERT_EQ ( non_trivial_move ,  0 ) ;   
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  // File with keys [ 100 => 199]
   
			
		
	
		
			
				
					  for  ( int  i  =  100 ;  i  <  200 ;  i + + )  {   
			
		
	
		
			
				
					    values . push_back ( RandomString ( & rnd ,  value_size ) ) ;   
			
		
	
		
			
				
					    ASSERT_OK ( Put ( Key ( i ) ,  values [ i ] ) ) ;   
			
		
	
		
			
				
					  }   
			
		
	
		
			
				
					  ASSERT_OK ( Flush ( ) ) ;   
			
		
	
		
			
				
					  ASSERT_EQ ( " 1,0,0,1 " ,  FilesPerLevel ( 0 ) ) ;   
			
		
	
		
			
				
					  ASSERT_OK ( db_ - > CompactRange ( nullptr ,  nullptr ) ) ;   
			
		
	
		
			
				
					  ASSERT_EQ ( " 0,0,0,2 " ,  FilesPerLevel ( 0 ) ) ;   
			
		
	
		
			
				
					  // Compaction did L0=>L1 L1=>L2 L2=>L3 (3 trivial moves)
   
			
		
	
		
			
				
					  ASSERT_EQ ( trivial_move ,  4 ) ;   
			
		
	
		
			
				
					  ASSERT_EQ ( non_trivial_move ,  0 ) ;   
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  for  ( int  i  =  0 ;  i  <  200 ;  i + + )  {   
			
		
	
		
			
				
					    ASSERT_EQ ( Get ( Key ( i ) ) ,  values [ i ] ) ;   
			
		
	
		
			
				
					  }   
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  rocksdb : : SyncPoint : : GetInstance ( ) - > DisableProcessing ( ) ;   
			
		
	
		
			
				
					}  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					TEST_F ( DBTest ,  TrivialMoveNonOverlappingFiles )  {  
			
		
	
		
			
				
					  int32_t  trivial_move  =  0 ;   
			
		
	
		
			
				
					  int32_t  non_trivial_move  =  0 ;