diff --git a/hbase-common/src/test/java/org/apache/hadoop/hbase/HBaseCommonTestingUtility.java b/hbase-common/src/test/java/org/apache/hadoop/hbase/HBaseCommonTestingUtility.java index 71704babf78..e0525fc2522 100644 --- a/hbase-common/src/test/java/org/apache/hadoop/hbase/HBaseCommonTestingUtility.java +++ b/hbase-common/src/test/java/org/apache/hadoop/hbase/HBaseCommonTestingUtility.java @@ -23,6 +23,7 @@ import java.net.ServerSocket; import java.util.Arrays; import java.util.HashSet; import java.util.List; +import java.util.Random; import java.util.Set; import java.util.UUID; import java.util.concurrent.ThreadLocalRandom; @@ -280,10 +281,11 @@ public class HBaseCommonTestingUtility { /** A set of ports that have been claimed using {@link #randomFreePort()}. */ private final Set takenRandomPorts = new HashSet<>(); - + private final Random random; private final AvailablePortChecker portChecker; public PortAllocator() { + this.random = new Random(); this.portChecker = new AvailablePortChecker() { @Override public boolean available(int port) { @@ -298,10 +300,15 @@ public class HBaseCommonTestingUtility { }; } - public PortAllocator(AvailablePortChecker portChecker) { + public PortAllocator(Random random, AvailablePortChecker portChecker) { + this.random = random; this.portChecker = portChecker; } + public PortAllocator(AvailablePortChecker portChecker) { + this(new Random(), portChecker); + } + /** * Returns a random free port and marks that port as taken. Not thread-safe. Expected to be * called from single-threaded test setup code/ @@ -328,8 +335,7 @@ public class HBaseCommonTestingUtility { * intended for dynamic allocation (see http://bit.ly/dynports). */ private int randomPort() { - return MIN_RANDOM_PORT - + ThreadLocalRandom.current().nextInt(MAX_RANDOM_PORT - MIN_RANDOM_PORT); + return MIN_RANDOM_PORT + random.nextInt(MAX_RANDOM_PORT - MIN_RANDOM_PORT); } interface AvailablePortChecker { diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/TestHBaseTestingUtility.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/TestHBaseTestingUtility.java index 3182e62c1bb..993af218723 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/TestHBaseTestingUtility.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/TestHBaseTestingUtility.java @@ -428,7 +428,7 @@ public class TestHBaseTestingUtility { when(portChecker.available(anyInt())).thenReturn(true); HBaseTestingUtility.PortAllocator portAllocator = - new HBaseTestingUtility.PortAllocator(portChecker); + new HBaseTestingUtility.PortAllocator(random, portChecker); int port1 = portAllocator.randomFreePort(); int port2 = portAllocator.randomFreePort();