diff --git a/server/src/main/java/org/elasticsearch/transport/SniffConnectionStrategy.java b/server/src/main/java/org/elasticsearch/transport/SniffConnectionStrategy.java index 47e00f23e7a..d18d5946a21 100644 --- a/server/src/main/java/org/elasticsearch/transport/SniffConnectionStrategy.java +++ b/server/src/main/java/org/elasticsearch/transport/SniffConnectionStrategy.java @@ -373,14 +373,6 @@ public class SniffConnectionStrategy extends RemoteConnectionStrategy { } } - List getSeedNodes() { - return configuredSeedNodes; - } - - int getMaxConnections() { - return maxNumRemoteConnections; - } - /* This class handles the _state response from the remote cluster when sniffing nodes to connect to */ private class SniffClusterStateResponseHandler implements TransportResponseHandler { @@ -438,7 +430,12 @@ public class SniffConnectionStrategy extends RemoteConnectionStrategy { // since if we do it afterwards we might fail assertions that check if all high level connections are closed. // from a code correctness perspective we could also close it afterwards. IOUtils.closeWhileHandlingException(connection); - listener.onResponse(null); + int openConnections = connectionManager.size(); + if (openConnections == 0) { + listener.onFailure(new IllegalStateException("Unable to open any connections to remote cluster [" + clusterAlias + "]")); + } else { + listener.onResponse(null); + } } @Override diff --git a/server/src/test/java/org/elasticsearch/transport/SniffConnectionStrategyTests.java b/server/src/test/java/org/elasticsearch/transport/SniffConnectionStrategyTests.java index 297c705b0e0..12d04818cc5 100644 --- a/server/src/test/java/org/elasticsearch/transport/SniffConnectionStrategyTests.java +++ b/server/src/test/java/org/elasticsearch/transport/SniffConnectionStrategyTests.java @@ -324,6 +324,34 @@ public class SniffConnectionStrategyTests extends ESTestCase { } } + public void testConnectFailsIfNoConnectionsOpened() { + List knownNodes = new CopyOnWriteArrayList<>(); + try (MockTransportService seedTransport = startTransport("seed_node", knownNodes, Version.CURRENT); + MockTransportService closedTransport = startTransport("discoverable_node", knownNodes, Version.CURRENT)) { + DiscoveryNode seedNode = seedTransport.getLocalNode(); + DiscoveryNode discoverableNode = closedTransport.getLocalNode(); + knownNodes.add(discoverableNode); + closedTransport.close(); + + try (MockTransportService localService = MockTransportService.createNewService(Settings.EMPTY, Version.CURRENT, threadPool)) { + localService.start(); + localService.acceptIncomingRequests(); + + // Predicate excludes seed node as a possible connection + ClusterConnectionManager connectionManager = new ClusterConnectionManager(profile, localService.transport); + try (RemoteConnectionManager remoteConnectionManager = new RemoteConnectionManager(clusterAlias, connectionManager); + SniffConnectionStrategy strategy = new SniffConnectionStrategy(clusterAlias, localService, remoteConnectionManager, + null, 3, n -> n.equals(seedNode) == false, seedNodes(seedNode))) { + PlainActionFuture connectFuture = PlainActionFuture.newFuture(); + strategy.connect(connectFuture); + final IllegalStateException ise = expectThrows(IllegalStateException.class, connectFuture::actionGet); + assertEquals("Unable to open any connections to remote cluster [cluster-alias]", ise.getMessage()); + assertTrue(strategy.assertNoRunningConnections()); + } + } + } + } + public void testClusterNameValidationPreventConnectingToDifferentClusters() throws Exception { List knownNodes = new CopyOnWriteArrayList<>(); List otherKnownNodes = new CopyOnWriteArrayList<>();