|  |  |  | @ -670,7 +670,7 @@ Status MultiOpsTxnsStressTest::PrimaryKeyUpdateTxn(ThreadState* thread, | 
			
		
	
		
			
				
					|  |  |  |  |     return s; | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   s = txn->Commit(); | 
			
		
	
		
			
				
					|  |  |  |  |   s = CommitAndCreateTimestampedSnapshotIfNeeded(thread, *txn); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   auto& key_gen = key_gen_for_a_.at(thread->tid); | 
			
		
	
		
			
				
					|  |  |  |  |   if (s.ok()) { | 
			
		
	
	
		
			
				
					|  |  |  | @ -876,7 +876,7 @@ Status MultiOpsTxnsStressTest::SecondaryKeyUpdateTxn(ThreadState* thread, | 
			
		
	
		
			
				
					|  |  |  |  |     return s; | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   s = txn->Commit(); | 
			
		
	
		
			
				
					|  |  |  |  |   s = CommitAndCreateTimestampedSnapshotIfNeeded(thread, *txn); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   if (s.ok()) { | 
			
		
	
		
			
				
					|  |  |  |  |     delete txn; | 
			
		
	
	
		
			
				
					|  |  |  | @ -968,7 +968,8 @@ Status MultiOpsTxnsStressTest::UpdatePrimaryIndexValueTxn(ThreadState* thread, | 
			
		
	
		
			
				
					|  |  |  |  |     return s; | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   s = txn->Commit(); | 
			
		
	
		
			
				
					|  |  |  |  |   s = CommitAndCreateTimestampedSnapshotIfNeeded(thread, *txn); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   if (s.ok()) { | 
			
		
	
		
			
				
					|  |  |  |  |     delete txn; | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
	
		
			
				
					|  |  |  | @ -1011,8 +1012,8 @@ Status MultiOpsTxnsStressTest::PointLookupTxn(ThreadState* thread, | 
			
		
	
		
			
				
					|  |  |  |  |     RollbackTxn(txn).PermitUncheckedError(); | 
			
		
	
		
			
				
					|  |  |  |  |   }); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   txn->SetSnapshot(); | 
			
		
	
		
			
				
					|  |  |  |  |   ropts.snapshot = txn->GetSnapshot(); | 
			
		
	
		
			
				
					|  |  |  |  |   std::shared_ptr<const Snapshot> snapshot; | 
			
		
	
		
			
				
					|  |  |  |  |   SetupSnapshot(thread, ropts, *txn, snapshot); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   if (FLAGS_delay_snapshot_read_one_in > 0 && | 
			
		
	
		
			
				
					|  |  |  |  |       thread->rand.OneIn(FLAGS_delay_snapshot_read_one_in)) { | 
			
		
	
	
		
			
				
					|  |  |  | @ -1062,8 +1063,8 @@ Status MultiOpsTxnsStressTest::RangeScanTxn(ThreadState* thread, | 
			
		
	
		
			
				
					|  |  |  |  |     RollbackTxn(txn).PermitUncheckedError(); | 
			
		
	
		
			
				
					|  |  |  |  |   }); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   txn->SetSnapshot(); | 
			
		
	
		
			
				
					|  |  |  |  |   ropts.snapshot = txn->GetSnapshot(); | 
			
		
	
		
			
				
					|  |  |  |  |   std::shared_ptr<const Snapshot> snapshot; | 
			
		
	
		
			
				
					|  |  |  |  |   SetupSnapshot(thread, ropts, *txn, snapshot); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   if (FLAGS_delay_snapshot_read_one_in > 0 && | 
			
		
	
		
			
				
					|  |  |  |  |       thread->rand.OneIn(FLAGS_delay_snapshot_read_one_in)) { | 
			
		
	
	
		
			
				
					|  |  |  | @ -1369,6 +1370,35 @@ Status MultiOpsTxnsStressTest::WriteToCommitTimeWriteBatch(Transaction& txn) { | 
			
		
	
		
			
				
					|  |  |  |  |   return ctwb->Put(Slice(key_buf, sizeof(key_buf)), | 
			
		
	
		
			
				
					|  |  |  |  |                    Slice(val_buf, sizeof(val_buf))); | 
			
		
	
		
			
				
					|  |  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | Status MultiOpsTxnsStressTest::CommitAndCreateTimestampedSnapshotIfNeeded( | 
			
		
	
		
			
				
					|  |  |  |  |     ThreadState* thread, Transaction& txn) { | 
			
		
	
		
			
				
					|  |  |  |  |   Status s; | 
			
		
	
		
			
				
					|  |  |  |  |   if (FLAGS_create_timestamped_snapshot_one_in > 0 && | 
			
		
	
		
			
				
					|  |  |  |  |       thread->rand.OneInOpt(FLAGS_create_timestamped_snapshot_one_in)) { | 
			
		
	
		
			
				
					|  |  |  |  |     uint64_t ts = db_stress_env->NowNanos(); | 
			
		
	
		
			
				
					|  |  |  |  |     std::shared_ptr<const Snapshot> snapshot; | 
			
		
	
		
			
				
					|  |  |  |  |     s = txn.CommitAndTryCreateSnapshot(/*notifier=*/nullptr, ts, &snapshot); | 
			
		
	
		
			
				
					|  |  |  |  |   } else { | 
			
		
	
		
			
				
					|  |  |  |  |     s = txn.Commit(); | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  |  |   return s; | 
			
		
	
		
			
				
					|  |  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | void MultiOpsTxnsStressTest::SetupSnapshot( | 
			
		
	
		
			
				
					|  |  |  |  |     ThreadState* thread, ReadOptions& read_opts, Transaction& txn, | 
			
		
	
		
			
				
					|  |  |  |  |     std::shared_ptr<const Snapshot>& snapshot) { | 
			
		
	
		
			
				
					|  |  |  |  |   if (thread->rand.OneInOpt(2)) { | 
			
		
	
		
			
				
					|  |  |  |  |     snapshot = txn_db_->GetLatestTimestampedSnapshot(); | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   if (snapshot) { | 
			
		
	
		
			
				
					|  |  |  |  |     read_opts.snapshot = snapshot.get(); | 
			
		
	
		
			
				
					|  |  |  |  |   } else { | 
			
		
	
		
			
				
					|  |  |  |  |     txn.SetSnapshot(); | 
			
		
	
		
			
				
					|  |  |  |  |     read_opts.snapshot = txn.GetSnapshot(); | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | #endif  // !ROCKSDB_LITE
 | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | std::string MultiOpsTxnsStressTest::KeySpaces::EncodeTo() const { | 
			
		
	
	
		
			
				
					|  |  |  | @ -1734,6 +1764,15 @@ void CheckAndSetOptionsForMultiOpsTxnStressTest() { | 
			
		
	
		
			
				
					|  |  |  |  |             "-key_spaces_path\n"); | 
			
		
	
		
			
				
					|  |  |  |  |     exit(1); | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  |  |   if (FLAGS_create_timestamped_snapshot_one_in > 0) { | 
			
		
	
		
			
				
					|  |  |  |  |     if (FLAGS_txn_write_policy != | 
			
		
	
		
			
				
					|  |  |  |  |         static_cast<uint64_t>(TxnDBWritePolicy::WRITE_COMMITTED)) { | 
			
		
	
		
			
				
					|  |  |  |  |       fprintf(stderr, | 
			
		
	
		
			
				
					|  |  |  |  |               "Timestamped snapshot is not yet supported by " | 
			
		
	
		
			
				
					|  |  |  |  |               "write-prepared/write-unprepared transactions\n"); | 
			
		
	
		
			
				
					|  |  |  |  |       exit(1); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  |  | #else | 
			
		
	
		
			
				
					|  |  |  |  |   fprintf(stderr, "-test_multi_ops_txns not supported in ROCKSDB_LITE mode\n"); | 
			
		
	
		
			
				
					|  |  |  |  |   exit(1); | 
			
		
	
	
		
			
				
					|  |  |  | 
 |