ivanzlenko commented on code in PR #5184:
URL: https://github.com/apache/ignite-3/pull/5184#discussion_r1944192466


##########
modules/table/src/main/java/org/apache/ignite/internal/table/distributed/storage/InternalTableImpl.java:
##########
@@ -2098,14 +2106,24 @@ protected CompletableFuture<ClusterNode> 
evaluateReadOnlyRecipientNode(int partI
                         throw withCause(TransactionException::new, 
REPLICA_UNAVAILABLE_ERR, e);
                     } else {
                         if (res == null) {
-                            throw withCause(TransactionException::new, 
REPLICA_UNAVAILABLE_ERR, e);
+                            throw createTransactionException(tablePartitionId, 
readTimestamp);
                         } else {
                             return getClusterNode(res);
                         }
                     }
                 });
     }
 
+    private static TransactionException 
createTransactionException(TablePartitionId tablePartitionId, HybridTimestamp 
readTimestamp) {

Review Comment:
   Done



##########
modules/table/src/main/java/org/apache/ignite/internal/table/distributed/storage/InternalTableImpl.java:
##########
@@ -898,8 +898,12 @@ public CompletableFuture<BinaryRow> get(BinaryRowEx 
keyRow, @Nullable InternalTr
         }
 
         if (tx.isReadOnly()) {
-            return evaluateReadOnlyRecipientNode(partitionId(keyRow), 
tx.readTimestamp())
-                    .thenCompose(recipientNode -> get(keyRow, 
tx.readTimestamp(), tx.id(), tx.coordinatorId(), recipientNode));
+            HybridTimestamp readTimestamp = tx.readTimestamp();
+
+            assert readTimestamp != null : "Read timestamp is not set for 
read-only transaction";

Review Comment:
   Removed



##########
modules/table/src/main/java/org/apache/ignite/internal/table/distributed/storage/InternalTableImpl.java:
##########
@@ -995,8 +999,12 @@ public CompletableFuture<List<BinaryRow>> 
getAll(Collection<BinaryRowEx> keyRows
         if (tx != null && tx.isReadOnly()) {
             BinaryRowEx firstRow = keyRows.iterator().next();
 
-            return evaluateReadOnlyRecipientNode(partitionId(firstRow), 
tx.readTimestamp())
-                    .thenCompose(recipientNode -> getAll(keyRows, 
tx.readTimestamp(), tx.id(), tx.coordinatorId(), recipientNode));
+            HybridTimestamp readTimestamp = tx.readTimestamp();
+
+            assert readTimestamp != null : "Read timestamp is not set for 
read-only transaction";

Review Comment:
   Removed



-- 
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