From 55fa9904b34cd24fbe7e8fd0ac028373521b0517 Mon Sep 17 00:00:00 2001 From: Martin Traverso Date: Fri, 4 Aug 2023 17:48:10 -0700 Subject: [PATCH] Use single tablet server replica for Kudu tests Using 3 tablet servers is overkill and makes the tests take longer. It takes ~10 seconds to initialize the docker instance for each tablet server. This change reduces the runtime of Kudu tests from 9:40 min to 4 min on an Macbook Pro M1 laptop. --- .../kudu/BaseKuduConnectorSmokeTest.java | 2 +- .../plugin/kudu/TestKuduConnectorTest.java | 2 +- .../trino/plugin/kudu/TestingKuduServer.java | 38 ++++++++----------- 3 files changed, 17 insertions(+), 25 deletions(-) diff --git a/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/BaseKuduConnectorSmokeTest.java b/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/BaseKuduConnectorSmokeTest.java index 6ada8cdf9f6c..ccc606c04ada 100644 --- a/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/BaseKuduConnectorSmokeTest.java +++ b/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/BaseKuduConnectorSmokeTest.java @@ -95,7 +95,7 @@ public void testShowCreateTable() " comment varchar COMMENT '' WITH ( nullable = true )\n" + ")\n" + "WITH (\n" + - " number_of_replicas = 3,\n" + + " number_of_replicas = 1,\n" + " partition_by_hash_buckets = 2,\n" + " partition_by_hash_columns = ARRAY['row_uuid'],\n" + " partition_by_range_columns = ARRAY['row_uuid'],\n" + diff --git a/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/TestKuduConnectorTest.java b/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/TestKuduConnectorTest.java index 659917606fae..6fb5b5557a85 100644 --- a/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/TestKuduConnectorTest.java +++ b/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/TestKuduConnectorTest.java @@ -232,7 +232,7 @@ public void testShowCreateTable() " comment varchar COMMENT '' WITH ( nullable = true )\n" + ")\n" + "WITH (\n" + - " number_of_replicas = 3,\n" + + " number_of_replicas = 1,\n" + " partition_by_hash_buckets = 2,\n" + " partition_by_hash_columns = ARRAY['row_uuid'],\n" + " partition_by_range_columns = ARRAY['row_uuid'],\n" + diff --git a/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/TestingKuduServer.java b/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/TestingKuduServer.java index 235c4062d1e7..b1b42b7adb5c 100644 --- a/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/TestingKuduServer.java +++ b/plugin/trino-kudu/src/test/java/io/trino/plugin/kudu/TestingKuduServer.java @@ -13,7 +13,6 @@ */ package io.trino.plugin.kudu; -import com.google.common.collect.ImmutableList; import com.google.common.io.Closer; import com.google.common.net.HostAndPort; import io.trino.testing.ResourcePresence; @@ -28,7 +27,6 @@ import java.net.NetworkInterface; import java.net.SocketException; import java.util.Enumeration; -import java.util.List; import static java.lang.String.format; @@ -41,7 +39,6 @@ public class TestingKuduServer private static final Integer KUDU_MASTER_PORT = 7051; private static final Integer KUDU_TSERVER_PORT = 7050; - private static final Integer NUMBER_OF_REPLICA = 3; private static final String TOXIPROXY_IMAGE = "ghcr.io/shopify/toxiproxy:2.4.0"; private static final String TOXIPROXY_NETWORK_ALIAS = "toxiproxy"; @@ -49,7 +46,7 @@ public class TestingKuduServer private final Network network; private final ToxiproxyContainer toxiProxy; private final GenericContainer master; - private final List> tServers; + private final GenericContainer tabletServer; private boolean stopped; @@ -67,7 +64,6 @@ public TestingKuduServer() public TestingKuduServer(String kuduVersion) { network = Network.newNetwork(); - ImmutableList.Builder> tServersBuilder = ImmutableList.builder(); String hostIP = getHostIPAddress(); @@ -75,6 +71,7 @@ public TestingKuduServer(String kuduVersion) this.master = new GenericContainer<>(format("%s:%s", KUDU_IMAGE, kuduVersion)) .withExposedPorts(KUDU_MASTER_PORT) .withCommand("master") + .withEnv("MASTER_ARGS", "--default_num_replicas=1") .withNetwork(network) .withNetworkAliases(masterContainerAlias); @@ -83,24 +80,19 @@ public TestingKuduServer(String kuduVersion) .withNetworkAliases(TOXIPROXY_NETWORK_ALIAS); toxiProxy.start(); - for (int instance = 0; instance < NUMBER_OF_REPLICA; instance++) { - String instanceName = "kudu-tserver-" + instance; - ToxiproxyContainer.ContainerProxy proxy = toxiProxy.getProxy(instanceName, KUDU_TSERVER_PORT); - GenericContainer tableServer = new GenericContainer<>(format("%s:%s", KUDU_IMAGE, kuduVersion)) - .withExposedPorts(KUDU_TSERVER_PORT) - .withCommand("tserver") - .withEnv("KUDU_MASTERS", format("%s:%s", masterContainerAlias, KUDU_MASTER_PORT)) - .withEnv("TSERVER_ARGS", format("--fs_wal_dir=/var/lib/kudu/tserver --logtostderr --use_hybrid_clock=false --rpc_bind_addresses=%s:%s --rpc_advertised_addresses=%s:%s", instanceName, KUDU_TSERVER_PORT, hostIP, proxy.getProxyPort())) - .withNetwork(network) - .withNetworkAliases(instanceName) - .dependsOn(master); - - tServersBuilder.add(tableServer); - } - this.tServers = tServersBuilder.build(); - master.start(); + String instanceName = "kudu-tserver"; + ToxiproxyContainer.ContainerProxy proxy = toxiProxy.getProxy(instanceName, KUDU_TSERVER_PORT); + tabletServer = new GenericContainer<>(format("%s:%s", KUDU_IMAGE, kuduVersion)) + .withExposedPorts(KUDU_TSERVER_PORT) + .withCommand("tserver") + .withEnv("KUDU_MASTERS", format("%s:%s", masterContainerAlias, KUDU_MASTER_PORT)) + .withEnv("TSERVER_ARGS", format("--fs_wal_dir=/var/lib/kudu/tserver --logtostderr --use_hybrid_clock=false --rpc_bind_addresses=%s:%s --rpc_advertised_addresses=%s:%s", instanceName, KUDU_TSERVER_PORT, hostIP, proxy.getProxyPort())) + .withNetwork(network) + .withNetworkAliases(instanceName) + .dependsOn(master); - tServers.forEach(GenericContainer::start); + master.start(); + tabletServer.start(); } public HostAndPort getMasterAddress() @@ -116,7 +108,7 @@ public void close() { try (Closer closer = Closer.create()) { closer.register(master::stop); - tServers.forEach(tabletServer -> closer.register(tabletServer::stop)); + closer.register(tabletServer::stop); closer.register(toxiProxy::stop); closer.register(network::close); }