JAkutenshi commented on code in PR #5258:
URL: https://github.com/apache/ignite-3/pull/5258#discussion_r1981366270


##########
modules/partition-replicator/src/integrationTest/java/org/apache/ignite/internal/partition/replicator/ItReplicaLifecycleTest.java:
##########
@@ -636,6 +639,54 @@ public void testScanCloseReplicaRequest() throws Exception 
{
         assertDoesNotThrow(tx::commit);
     }
 
+    @Test
+    public void testReplicaSafeTimeSyncRequest() throws Exception {
+        startCluster(2);
+        Node node = getNode(0);
+
+        // Prepare a zone.
+        String zoneName = "test_zone";
+        createZone(node, zoneName, 1, 2);
+        int zoneId =  DistributionZonesTestUtil.getZoneId(node.catalogManager, 
zoneName, node.hybridClock.nowLong());
+        int partId = 0;
+
+        // Wait for sure that zone replication group was created on both nodes.
+        waitForZoneReplicaStartedOnNode(node, zoneId, partId);
+        waitForZoneReplicaStartedOnNode(getNode(1), zoneId, partId);

Review Comment:
   Not sure, but used method looks more verbose and precise for the situation, 
isn't?



##########
modules/partition-replicator/src/integrationTest/java/org/apache/ignite/internal/partition/replicator/ItReplicaLifecycleTest.java:
##########
@@ -636,6 +639,54 @@ public void testScanCloseReplicaRequest() throws Exception 
{
         assertDoesNotThrow(tx::commit);
     }
 
+    @Test
+    public void testReplicaSafeTimeSyncRequest() throws Exception {
+        startCluster(2);
+        Node node = getNode(0);
+
+        // Prepare a zone.
+        String zoneName = "test_zone";
+        createZone(node, zoneName, 1, 2);
+        int zoneId =  DistributionZonesTestUtil.getZoneId(node.catalogManager, 
zoneName, node.hybridClock.nowLong());
+        int partId = 0;
+
+        // Wait for sure that zone replication group was created on both nodes.
+        waitForZoneReplicaStartedOnNode(node, zoneId, partId);
+        waitForZoneReplicaStartedOnNode(getNode(1), zoneId, partId);
+
+        // Check that time was adjusted even without table.
+        checkSafeTimeWasAdjustedForZoneGroup(zoneId, partId);
+
+        // Create a table to work with.
+        String tableName = "test_table";
+        createTable(node, zoneName, tableName);
+        assertDoesNotThrow(() -> 
TableTestUtils.getTableIdStrict(node.catalogManager, tableName, 
node.hybridClock.nowLong()));
+
+        // Check that time was adjusted  table.
+        checkSafeTimeWasAdjustedForZoneGroup(zoneId, partId);
+    }
+
+    private static void waitForZoneReplicaStartedOnNode(Node node, int zoneId, 
int partId) throws InterruptedException {
+        ZonePartitionId zoneReplicationId = new ZonePartitionId(zoneId, 
partId);
+
+        waitForCondition(() -> node.replicaManager.replica(zoneReplicationId) 
!= null, AWAIT_TIMEOUT_MILLIS);

Review Comment:
   Fixed, thank you!



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