ascherbakoff commented on code in PR #5209:
URL: https://github.com/apache/ignite-3/pull/5209#discussion_r1980931784


##########
modules/client/src/main/java/org/apache/ignite/internal/client/tx/ClientTransactions.java:
##########
@@ -33,6 +33,8 @@
  * Client transactions implementation.
  */
 public class ClientTransactions implements IgniteTransactions {
+    private static final int DEFAULT_TIMEOUT = 0;

Review Comment:
   I don't think default timeout should be 0.



##########
modules/runner/src/integrationTest/java/org/apache/ignite/internal/table/ItTableScanTest.java:
##########
@@ -578,10 +585,12 @@ public void testTwiceScanInTransaction() throws Exception 
{
     public void testScanWithUpperBound() throws Exception {
         KeyValueView<Tuple, Tuple> kvView = table.keyValueView();
 
-        BinaryTuplePrefix lowBound = BinaryTuplePrefix.fromBinaryTuple(new 
BinaryTuple(1,
-                new BinaryTupleBuilder(1).appendInt(5).build()));
-        BinaryTuplePrefix upperBound = BinaryTuplePrefix.fromBinaryTuple(new 
BinaryTuple(1,
-                new BinaryTupleBuilder(1).appendInt(9).build()));
+        BinaryTuplePrefix lowBound = BinaryTuplePrefix.fromBinaryTuple(

Review Comment:
   here and below - formatting issues.
   avoid reformatting existing code.



##########
modules/table/src/main/java/org/apache/ignite/internal/table/distributed/storage/InternalTableImpl.java:
##########
@@ -1730,16 +1761,21 @@ protected CompletableFuture<Void> onClose(boolean 
intentionallyClose, long scanI
 
                     PendingTxPartitionEnlistment enlistment = 
tx.enlistedPartition(replicationGrpId);
                     opFut = enlistment != null ? completeScan(
-                        tx.id(),
-                        replicationGrpId,
-                        scanId,
-                        th,
-                        enlistment.primaryNodeConsistentId(),
-                        intentionallyClose
+                            tx.id(),

Review Comment:
   again - formatting is broken



##########
modules/sql-engine/src/integrationTest/java/org/apache/ignite/internal/sql/engine/ItDmlTest.java:
##########
@@ -373,9 +373,12 @@ public void testMergeBatch() {
 
         assertQuery("SELECT count(*) FROM test2 WHERE b = 
0").returns(10_000L).check();
 
-        sql("MERGE INTO test2 dst USING test1 src ON dst.a = src.a"
+        var longerTimeoutOptions = new 
TransactionOptions().readOnly(false).timeoutMillis(TimeUnit.MINUTES.toMillis(2));

Review Comment:
   I think timeouts should be disabled (set to 0) by default in tests and 
enabled explicitely in tests which need timeout.
   



##########
modules/transactions/src/main/java/org/apache/ignite/internal/tx/InternalTransaction.java:
##########
@@ -117,9 +117,10 @@ void enlist(
      * @param executionTimestamp The timestamp is the time when a read-only 
transaction is applied to the remote node. The parameter
      *         is not used for read-write transactions.
      * @param full Full state transaction marker.
+     * @param timeoutExceeded Timeout exceeded flag (commit flag must be 
{@code false}).
      * @return The future.
      */
-    CompletableFuture<Void> finish(boolean commit, @Nullable HybridTimestamp 
executionTimestamp, boolean full);
+    CompletableFuture<Void> finish(boolean commit, @Nullable HybridTimestamp 
executionTimestamp, boolean full, boolean timeoutExceeded);

Review Comment:
   I have the same idea. Abort state must be generalized in some way. Separate 
ticket is OK.



##########
modules/runner/src/integrationTest/java/org/apache/ignite/internal/table/ItTableScanTest.java:
##########
@@ -1040,20 +1048,24 @@ private Row createKeyRow(int id) {
     private InternalTransaction startTxWithEnlistedPartition(int partId, 
boolean readOnly) {
         IgniteImpl ignite = unwrapIgniteImpl(CLUSTER.aliveNode());
 
-        InternalTransaction tx = (InternalTransaction) 
ignite.transactions().begin(new TransactionOptions().readOnly(readOnly));
+        InternalTransaction tx = (InternalTransaction) 
ignite.transactions().begin(
+                new 
TransactionOptions().timeoutMillis(10_000).readOnly(readOnly)

Review Comment:
   Why is this required ?



##########
modules/table/src/main/java/org/apache/ignite/internal/table/distributed/storage/InternalTableImpl.java:
##########
@@ -514,6 +519,18 @@ private <T> CompletableFuture<T> enlistInTx(
         }).thenCompose(identity());
     }
 
+    private long getTimeout(InternalTransaction tx) {

Review Comment:
   Better to add method
   long timeout(long defaultValue) 
   to internal transaction



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: notifications-unsubscr...@ignite.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org

Reply via email to