From 438d93b30f789ae660c849e69deba8c42943611f Mon Sep 17 00:00:00 2001 From: Duo Zhang Date: Thu, 4 May 2023 20:58:38 +0800 Subject: [PATCH] HBASE-27822 TestFromClientSide5.testAppendWithoutWAL is flaky (#5211) Signed-off-by: Liangjun He (cherry picked from commit b59eb9640749bfb1bc22bbcb4a36921b79ad176f) --- .../hbase/client/FromClientSideBase.java | 4 +-- .../hbase/client/TestFromClientSide5.java | 30 +++++++++++++------ .../TestFromClientSideWithCoprocessor5.java | 15 +++++----- 3 files changed, 31 insertions(+), 18 deletions(-) diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/client/FromClientSideBase.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/client/FromClientSideBase.java index 2008c8060216..dd8bd3a03eae 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/client/FromClientSideBase.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/client/FromClientSideBase.java @@ -97,8 +97,8 @@ protected static boolean isSameParameterizedCluster(Class registryImpl, int n return confClass.getName().equals(registryImpl.getName()) && numHedgedReqs == hedgedReqConfig; } - protected static final void initialize(Class registryImpl, int numHedgedReqs, Class... cps) - throws Exception { + protected static final void initialize(Class registryImpl, + int numHedgedReqs, Class... cps) throws Exception { // initialize() is called for every unit test, however we only want to reset the cluster state // at the end of every parameterized run. if (isSameParameterizedCluster(registryImpl, numHedgedReqs)) { diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestFromClientSide5.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestFromClientSide5.java index ceef1ef32473..e72bd8fee86c 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestFromClientSide5.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestFromClientSide5.java @@ -28,7 +28,6 @@ import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; -import java.util.Collection; import java.util.LinkedList; import java.util.List; import java.util.Map; @@ -96,6 +95,7 @@ import org.junit.experimental.categories.Category; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; +import org.junit.runners.Parameterized.Parameters; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -113,6 +113,7 @@ public class TestFromClientSide5 extends FromClientSideBase { @ClassRule public static final HBaseClassTestRule CLASS_RULE = HBaseClassTestRule.forClass(TestFromClientSide5.class); + @Rule public TableNameTestRule name = new TableNameTestRule(); @@ -120,14 +121,15 @@ public class TestFromClientSide5 extends FromClientSideBase { TestFromClientSide5() { } - public TestFromClientSide5(Class registry, int numHedgedReqs) throws Exception { + public TestFromClientSide5(Class registry, int numHedgedReqs) + throws Exception { initialize(registry, numHedgedReqs, MultiRowMutationEndpoint.class); } - @Parameterized.Parameters - public static Collection parameters() { - return Arrays.asList(new Object[][] { { MasterRegistry.class, 1 }, { MasterRegistry.class, 2 }, - { ZKConnectionRegistry.class, 1 } }); + @Parameters(name = "{index}: registry={0}, numHedgedReqs={1}") + public static List parameters() { + return Arrays.asList(new Object[] { MasterRegistry.class, 1 }, + new Object[] { MasterRegistry.class, 2 }, new Object[] { ZKConnectionRegistry.class, 1 }); } @AfterClass @@ -769,10 +771,20 @@ private List doAppend(final boolean walUsed) throws IOException { t.put(put_1); List results = new LinkedList<>(); try (ResultScanner scanner = t.getScanner(s)) { + // get one row(should be row3) from the scanner to make sure that we have send a request to + // region server, which means we have already set the read point, so later we should not see + // the new appended values. + Result r = scanner.next(); + assertNotNull(r); + results.add(r); t.append(append_1); t.append(append_2); t.append(append_3); - for (Result r : scanner) { + for (;;) { + r = scanner.next(); + if (r == null) { + break; + } results.add(r); } } @@ -786,11 +798,11 @@ public void testAppendWithoutWAL() throws Exception { List resultsWithWal = doAppend(true); List resultsWithoutWal = doAppend(false); assertEquals(resultsWithWal.size(), resultsWithoutWal.size()); - for (int i = 0; i != resultsWithWal.size(); ++i) { + for (int i = 0; i < resultsWithWal.size(); ++i) { Result resultWithWal = resultsWithWal.get(i); Result resultWithoutWal = resultsWithoutWal.get(i); assertEquals(resultWithWal.rawCells().length, resultWithoutWal.rawCells().length); - for (int j = 0; j != resultWithWal.rawCells().length; ++j) { + for (int j = 0; j < resultWithWal.rawCells().length; ++j) { Cell cellWithWal = resultWithWal.rawCells()[j]; Cell cellWithoutWal = resultWithoutWal.rawCells()[j]; assertArrayEquals(CellUtil.cloneRow(cellWithWal), CellUtil.cloneRow(cellWithoutWal)); diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestFromClientSideWithCoprocessor5.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestFromClientSideWithCoprocessor5.java index e1677dfeb6c1..759360f4b5e3 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestFromClientSideWithCoprocessor5.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestFromClientSideWithCoprocessor5.java @@ -18,7 +18,7 @@ package org.apache.hadoop.hbase.client; import java.util.Arrays; -import java.util.Collection; +import java.util.List; import org.apache.hadoop.hbase.HBaseClassTestRule; import org.apache.hadoop.hbase.coprocessor.MultiRowMutationEndpoint; import org.apache.hadoop.hbase.regionserver.NoOpScanPolicyObserver; @@ -27,7 +27,7 @@ import org.junit.AfterClass; import org.junit.ClassRule; import org.junit.experimental.categories.Category; -import org.junit.runners.Parameterized; +import org.junit.runners.Parameterized.Parameters; /** * Test all client operations with a coprocessor that just implements the default flush/compact/scan @@ -41,10 +41,10 @@ public class TestFromClientSideWithCoprocessor5 extends TestFromClientSide5 { // Override the parameters from the parent class. We just want to run it for the default // param combination. - @Parameterized.Parameters - public static Collection parameters() { - return Arrays - .asList(new Object[][] { { MasterRegistry.class, 1 }, { ZKConnectionRegistry.class, 1 } }); + @Parameters(name = "{index}: registry={0}, numHedgedReqs={1}") + public static List parameters() { + return Arrays.asList(new Object[] { MasterRegistry.class, 1 }, + new Object[] { ZKConnectionRegistry.class, 1 }); } @AfterClass @@ -52,7 +52,8 @@ public static void tearDownAfterClass() throws Exception { afterClass(); } - public TestFromClientSideWithCoprocessor5(Class registry, int numHedgedReqs) throws Exception { + public TestFromClientSideWithCoprocessor5(Class registry, + int numHedgedReqs) throws Exception { initialize(registry, numHedgedReqs, NoOpScanPolicyObserver.class, MultiRowMutationEndpoint.class); }