public void TestReplaceOldCase9Event() { TransactionExecution texUpdate = new TransactionExecution(null, this.versionDb); texUpdate.DEBUG_MODE = true; while (texUpdate.Progress == TxProgress.Initi) { this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate.InitTx(); } texUpdate.Read(TABLE_ID, DEFAULT_KEY, out bool receivedRead, out object payloadRead); while (!receivedRead) { this.versionDb.Visit(TABLE_ID, 0); this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate.Read(TABLE_ID, DEFAULT_KEY, out receivedRead, out payloadRead); } texUpdate.Delete(TABLE_ID, DEFAULT_KEY, out object payloadDelete); texUpdate.Upload(); while (texUpdate.CurrentProc == null) { this.versionDb.Visit(TABLE_ID, 0); this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate.Upload(); } Assert.AreEqual(new Procedure(texUpdate.SetCommitTimestamp), texUpdate.CurrentProc); TransactionExecution texUpdate1 = new TransactionExecution(null, this.versionDb); texUpdate1.DEBUG_MODE = true; while (texUpdate1.Progress == TxProgress.Initi) { this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate1.InitTx(); } texUpdate1.Read(TABLE_ID, DEFAULT_KEY, out bool receivedRead1, out object payloadRead1); while (!receivedRead1) { this.versionDb.Visit(TABLE_ID, 0); this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate1.Read(TABLE_ID, DEFAULT_KEY, out receivedRead1, out payloadRead1); } texUpdate.SetCommitTimestamp(); while (texUpdate.CurrentProc == new Procedure(texUpdate.SetCommitTimestamp)) { this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate.SetCommitTimestamp(); } Assert.AreEqual(new Procedure(texUpdate.Validate), texUpdate.CurrentProc); texUpdate.Validate(); while (texUpdate.CurrentProc == new Procedure(texUpdate.Validate)) { this.versionDb.Visit(TABLE_ID, 0); texUpdate.Validate(); } Assert.AreEqual(new Procedure(texUpdate.WriteToLog), texUpdate.CurrentProc); texUpdate.WriteToLog(); while (texUpdate.CurrentProc == new Procedure(texUpdate.WriteToLog)) { this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate.WriteToLog(); } Assert.AreEqual(new Procedure(texUpdate.PostProcessingAfterCommit), texUpdate.CurrentProc); texUpdate.PostProcessingAfterCommit(); while (texUpdate.Progress != TxProgress.Close) { this.versionDb.Visit(TABLE_ID, 0); texUpdate.PostProcessingAfterCommit(); } texUpdate1.Update(TABLE_ID, DEFAULT_KEY, "value_update_1"); texUpdate1.Upload(); while (texUpdate1.CurrentProc == null) { this.versionDb.Visit(TABLE_ID, 0); this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate1.Upload(); } Assert.AreEqual(new Procedure(texUpdate1.Abort), texUpdate1.CurrentProc); }
public void TestPostProcessing4Event() { TransactionExecution texUpdate = new TransactionExecution(null, this.versionDb); texUpdate.DEBUG_MODE = true; while (texUpdate.Progress == TxProgress.Initi) { this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate.InitTx(); } texUpdate.Read(TABLE_ID, DEFAULT_KEY, out bool received, out object payload); while (!received) { this.versionDb.Visit(TABLE_ID, 0); texUpdate.Read(TABLE_ID, DEFAULT_KEY, out received, out payload); } texUpdate.Update(TABLE_ID, DEFAULT_KEY, "value_update"); texUpdate.maxCommitTsOfWrites = 4L; texUpdate.Upload(); while (texUpdate.CurrentProc == null) { this.versionDb.Visit(TABLE_ID, 0); texUpdate.Upload(); } texUpdate.SetCommitTimestamp(); while (texUpdate.CurrentProc == new Procedure(texUpdate.SetCommitTimestamp)) { this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate.SetCommitTimestamp(); } texUpdate.Validate(); while (texUpdate.CurrentProc == new Procedure(texUpdate.Validate)) { this.versionDb.Visit(TABLE_ID, 0); texUpdate.Validate(); } Assert.AreEqual(new Procedure(texUpdate.WriteToLog), texUpdate.CurrentProc); texUpdate.WriteToLog(); while (texUpdate.CurrentProc == new Procedure(texUpdate.WriteToLog)) { this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texUpdate.WriteToLog(); } TransactionExecution texDelete = new TransactionExecution(null, this.versionDb); texDelete.DEBUG_MODE = true; while (texDelete.Progress == TxProgress.Initi) { this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texDelete.InitTx(); } texDelete.Read(TABLE_ID, DEFAULT_KEY, out bool receivedRead, out object payloadRead); while (!receivedRead) { this.versionDb.Visit(TABLE_ID, 0); this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texDelete.Read(TABLE_ID, DEFAULT_KEY, out receivedRead, out payloadRead); } texDelete.Delete(TABLE_ID, DEFAULT_KEY, out object payloadDelete); texDelete.Upload(); while (texDelete.CurrentProc == null) { this.versionDb.Visit(TABLE_ID, 0); this.versionDb.Visit(RedisVersionDb.TX_TABLE, 0); texDelete.Upload(); } texUpdate.PostProcessingAfterCommit(); while (texUpdate.Progress != TxProgress.Close) { this.versionDb.Visit(TABLE_ID, 0); texUpdate.PostProcessingAfterCommit(); } VersionEntry newVersionEntry = this.GetVersionByKey(2L); Assert.AreEqual(5L, newVersionEntry.BeginTimestamp); Assert.AreEqual(long.MaxValue, newVersionEntry.EndTimestamp); Assert.AreEqual(texDelete.txId, newVersionEntry.TxId); VersionEntry oldVersionEntry = this.GetVersionByKey(1L); Assert.AreEqual(0L, oldVersionEntry.BeginTimestamp); Assert.AreEqual(5L, oldVersionEntry.EndTimestamp); Assert.AreEqual(-1L, oldVersionEntry.TxId); }