فهرست منبع

Remove TCP handshake BWC from master (#22151)

Since #22094 has been back-ported to 5.2 we can remove all BWC layers from master since all supported version will handle handshake requests.

Relates to #22094
Simon Willnauer 8 سال پیش
والد
کامیت
ef610636b6

+ 3 - 19
core/src/main/java/org/elasticsearch/transport/TcpTransport.java

@@ -245,7 +245,6 @@ public abstract class TcpTransport<Channel> extends AbstractLifecycleComponent i
     private static class HandshakeResponseHandler<Channel> implements TransportResponseHandler<VersionHandshakeResponse> {
         final AtomicReference<Version> versionRef = new AtomicReference<>();
         final CountDownLatch latch = new CountDownLatch(1);
-        final AtomicBoolean handshakeNotSupported = new AtomicBoolean(false);
         final AtomicReference<Exception> exceptionRef = new AtomicReference<>();
         final Channel channel;
 
@@ -261,24 +260,15 @@ public abstract class TcpTransport<Channel> extends AbstractLifecycleComponent i
         @Override
         public void handleResponse(VersionHandshakeResponse response) {
             final boolean success = versionRef.compareAndSet(null, response.version);
-            assert success;
             latch.countDown();
+            assert success;
         }
 
         @Override
         public void handleException(TransportException exp) {
-            Throwable cause = exp.getCause();
-            if (cause != null
-                && cause instanceof ActionNotFoundTransportException
-                // this will happen if we talk to a node (pre 5.2) that doesn't have a handshake handler
-                // we will just treat the node as a 5.0.0 node unless the discovery node that is used to connect has a higher version.
-                && cause.getMessage().equals("No handler for action [internal:tcp/handshake]")) {
-                    handshakeNotSupported.set(true);
-            } else {
-                final boolean success = exceptionRef.compareAndSet(null, exp);
-                assert success;
-            }
+            final boolean success = exceptionRef.compareAndSet(null, exp);
             latch.countDown();
+            assert success;
         }
 
         @Override
@@ -1546,12 +1536,6 @@ public abstract class TcpTransport<Channel> extends AbstractLifecycleComponent i
                 throw new ConnectTransportException(node, "handshake_timeout[" + timeout + "]");
             }
             success = true;
-            if (handler.handshakeNotSupported.get()) {
-                // this is a BWC layer, if we talk to a pre 5.2 node then the handshake is not supported
-                // this will go away in master once it's all ported to 5.2 but for now we keep this to make
-                // the backport straight forward
-                return null;
-            }
             if (exceptionRef.get() != null) {
                 throw new IllegalStateException("handshake failed", exceptionRef.get());
             } else {

+ 3 - 6
test/framework/src/main/java/org/elasticsearch/transport/AbstractSimpleTransportTestCase.java

@@ -1805,12 +1805,9 @@ public abstract class AbstractSimpleTransportTestCase extends ESTestCase {
             // this acts like a node that doesn't have support for handshakes
             DiscoveryNode node =
                 new DiscoveryNode("TS_TPC", "TS_TPC", service.boundAddress().publishAddress(), emptyMap(), emptySet(), version0);
-            serviceA.connectToNode(node);
-            TcpTransport.NodeChannels connection = originalTransport.getConnection(node);
-            Version version = originalTransport.executeHandshake(node, connection.channel(TransportRequestOptions.Type.PING),
-                TimeValue.timeValueSeconds(10));
-            assertNull(version);
-            serviceA.disconnectFromNode(node);
+            ConnectTransportException exception = expectThrows(ConnectTransportException.class, () -> serviceA.connectToNode(node));
+            assertTrue(exception.getCause() instanceof IllegalStateException);
+            assertEquals("handshake failed", exception.getCause().getMessage());
         }
 
         try (TransportService service = buildService("TS_TPC", Version.CURRENT, null)) {