@ -1267,12 +1267,12 @@ TEST_P(SeqAdvanceConcurrentTest, SeqAdvanceConcurrentTest) { 
			
		
	
		
		
			
				
					
					    assert ( db  ! =  nullptr ) ;      assert ( db  ! =  nullptr ) ;   
			
		
	
		
		
			
				
					
					    db_impl  =  reinterpret_cast < DBImpl * > ( db - > GetRootDB ( ) ) ;      db_impl  =  reinterpret_cast < DBImpl * > ( db - > GetRootDB ( ) ) ;   
			
		
	
		
		
			
				
					
					    seq  =  db_impl - > TEST_GetLastVisibleSequence ( ) ;      seq  =  db_impl - > TEST_GetLastVisibleSequence ( ) ;   
			
		
	
		
		
			
				
					
					    ASSERT_EQ  ( exp_seq ,  seq ) ;      ASSERT_L E ( exp_seq ,  seq ) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    // Check if flush preserves the last sequence number
      // Check if flush preserves the last sequence number
   
			
		
	
		
		
			
				
					
					    db_impl - > Flush ( fopt ) ;      db_impl - > Flush ( fopt ) ;   
			
		
	
		
		
			
				
					
					    seq  =  db_impl - > GetLatestSequenceNumber ( ) ;      seq  =  db_impl - > GetLatestSequenceNumber ( ) ;   
			
		
	
		
		
			
				
					
					    ASSERT_EQ  ( exp_seq ,  seq ) ;      ASSERT_L E ( exp_seq ,  seq ) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    // Check if recovery after flush preserves the last sequence number
      // Check if recovery after flush preserves the last sequence number
   
			
		
	
		
		
			
				
					
					    db_impl - > FlushWAL ( true ) ;      db_impl - > FlushWAL ( true ) ;   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1280,7 +1280,7 @@ TEST_P(SeqAdvanceConcurrentTest, SeqAdvanceConcurrentTest) { 
			
		
	
		
		
			
				
					
					    assert ( db  ! =  nullptr ) ;      assert ( db  ! =  nullptr ) ;   
			
		
	
		
		
			
				
					
					    db_impl  =  reinterpret_cast < DBImpl * > ( db - > GetRootDB ( ) ) ;      db_impl  =  reinterpret_cast < DBImpl * > ( db - > GetRootDB ( ) ) ;   
			
		
	
		
		
			
				
					
					    seq  =  db_impl - > GetLatestSequenceNumber ( ) ;      seq  =  db_impl - > GetLatestSequenceNumber ( ) ;   
			
		
	
		
		
			
				
					
					    ASSERT_EQ  ( exp_seq ,  seq ) ;      ASSERT_L E ( exp_seq ,  seq ) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1425,17 +1425,63 @@ TEST_P(WritePreparedTransactionTest, BasicRecoveryTest) { 
			
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					// After recovery the commit map is empty while the max is set. The code would
 // After recovery the commit map is empty while the max is set. The code would
  
			
		
	
		
		
			
				
					
					// go through a different path which requires a separate test.
 // go through a different path which requires a separate test. Test that the
  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					// committed data before the restart is visible to all snapshots.
  
			
		
	
		
		
			
				
					
					TEST_P ( WritePreparedTransactionTest ,  IsInSnapshotEmptyMapTest )  { TEST_P ( WritePreparedTransactionTest ,  IsInSnapshotEmptyMapTest )  {  
			
		
	
		
		
			
				
					
					  WritePreparedTxnDB *  wp_db  =  dynamic_cast < WritePreparedTxnDB * > ( db ) ;    for  ( bool  end_with_prepare  :  { false ,  true } )  {   
			
				
				
			
		
	
		
		
			
				
					
					  wp_db - > max_evicted_seq_  =  100 ;      ReOpen ( ) ;   
			
				
				
			
		
	
		
		
			
				
					
					  ASSERT_FALSE ( wp_db - > IsInSnapshot ( 50 ,  40 ) ) ;      WriteOptions  woptions ;   
			
				
				
			
		
	
		
		
			
				
					
					  ASSERT_TRUE ( wp_db - > IsInSnapshot ( 50 ,  50 ) ) ;      ASSERT_OK ( db - > Put ( woptions ,  " key " ,  " value " ) ) ;   
			
				
				
			
		
	
		
		
			
				
					
					  ASSERT_TRUE ( wp_db - > IsInSnapshot ( 50 ,  100 ) ) ;      ASSERT_OK ( db - > Put ( woptions ,  " key " ,  " value " ) ) ;   
			
				
				
			
		
	
		
		
			
				
					
					  ASSERT_TRUE ( wp_db - > IsInSnapshot ( 50 ,  150 ) ) ;      ASSERT_OK ( db - > Put ( woptions ,  " key " ,  " value " ) ) ;   
			
				
				
			
		
	
		
		
			
				
					
					  ASSERT_FALSE ( wp_db - > IsInSnapshot ( 100 ,  80 ) ) ;      SequenceNumber  prepare_seq  =  kMaxSequenceNumber ;   
			
				
				
			
		
	
		
		
			
				
					
					  ASSERT_TRUE ( wp_db - > IsInSnapshot ( 100 ,  100 ) ) ;      if  ( end_with_prepare )  {   
			
				
				
			
		
	
		
		
			
				
					
					  ASSERT_TRUE ( wp_db - > IsInSnapshot ( 100 ,  150 ) ) ;        TransactionOptions  txn_options ;   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					      Transaction *  txn  =  db - > BeginTransaction ( woptions ,  txn_options ) ;   
			
		
	
		
		
			
				
					
					      ASSERT_OK ( txn - > SetName ( " xid0 " ) ) ;   
			
		
	
		
		
			
				
					
					      ASSERT_OK ( txn - > Prepare ( ) ) ;   
			
		
	
		
		
			
				
					
					      prepare_seq  =  txn - > GetId ( ) ;   
			
		
	
		
		
			
				
					
					      delete  txn ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					    dynamic_cast < WritePreparedTxnDB * > ( db ) - > TEST_Crash ( ) ;   
			
		
	
		
		
			
				
					
					    auto  db_impl  =  reinterpret_cast < DBImpl * > ( db - > GetRootDB ( ) ) ;   
			
		
	
		
		
			
				
					
					    db_impl - > FlushWAL ( true ) ;   
			
		
	
		
		
			
				
					
					    ReOpenNoDelete ( ) ;   
			
		
	
		
		
			
				
					
					    WritePreparedTxnDB *  wp_db  =  dynamic_cast < WritePreparedTxnDB * > ( db ) ;   
			
		
	
		
		
			
				
					
					    ASSERT_GT ( wp_db - > max_evicted_seq_ ,  0 ) ;   // max after recovery
   
			
		
	
		
		
			
				
					
					    // Take a snapshot right after recovery
   
			
		
	
		
		
			
				
					
					    const  Snapshot *  snap  =  db - > GetSnapshot ( ) ;   
			
		
	
		
		
			
				
					
					    auto  snap_seq  =  snap - > GetSequenceNumber ( ) ;   
			
		
	
		
		
			
				
					
					    ASSERT_GT ( snap_seq ,  0 ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    for  ( SequenceNumber  seq  =  0 ;   
			
		
	
		
		
			
				
					
					         seq  < =  wp_db - > max_evicted_seq_  & &  seq  ! =  prepare_seq ;  seq + + )  {   
			
		
	
		
		
			
				
					
					      ASSERT_TRUE ( wp_db - > IsInSnapshot ( seq ,  snap_seq ) ) ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					    if  ( end_with_prepare )  {   
			
		
	
		
		
			
				
					
					      ASSERT_FALSE ( wp_db - > IsInSnapshot ( prepare_seq ,  snap_seq ) ) ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					    // trivial check
   
			
		
	
		
		
			
				
					
					    ASSERT_FALSE ( wp_db - > IsInSnapshot ( snap_seq  +  1 ,  snap_seq ) ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    db - > ReleaseSnapshot ( snap ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    ASSERT_OK ( db - > Put ( woptions ,  " key " ,  " value " ) ) ;   
			
		
	
		
		
			
				
					
					    // Take a snapshot after some writes
   
			
		
	
		
		
			
				
					
					    snap  =  db - > GetSnapshot ( ) ;   
			
		
	
		
		
			
				
					
					    snap_seq  =  snap - > GetSequenceNumber ( ) ;   
			
		
	
		
		
			
				
					
					    for  ( SequenceNumber  seq  =  0 ;   
			
		
	
		
		
			
				
					
					         seq  < =  wp_db - > max_evicted_seq_  & &  seq  ! =  prepare_seq ;  seq + + )  {   
			
		
	
		
		
			
				
					
					      ASSERT_TRUE ( wp_db - > IsInSnapshot ( seq ,  snap_seq ) ) ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					    if  ( end_with_prepare )  {   
			
		
	
		
		
			
				
					
					      ASSERT_FALSE ( wp_db - > IsInSnapshot ( prepare_seq ,  snap_seq ) ) ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					    // trivial check
   
			
		
	
		
		
			
				
					
					    ASSERT_FALSE ( wp_db - > IsInSnapshot ( snap_seq  +  1 ,  snap_seq ) ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    db - > ReleaseSnapshot ( snap ) ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					// Test WritePreparedTxnDB's IsInSnapshot against different ordering of
 // Test WritePreparedTxnDB's IsInSnapshot against different ordering of