|
21 | 21 | import org.apache.kafka.clients.producer.ProducerConfig; |
22 | 22 | import org.apache.kafka.common.KafkaException; |
23 | 23 | import org.apache.kafka.common.Uuid; |
| 24 | +import org.apache.kafka.common.errors.AuthorizationException; |
| 25 | +import org.apache.kafka.common.errors.DisconnectException; |
| 26 | +import org.apache.kafka.common.errors.NetworkException; |
| 27 | +import org.apache.kafka.common.errors.TimeoutException; |
| 28 | +import org.apache.kafka.common.errors.UnsupportedVersionException; |
24 | 29 | import org.apache.kafka.common.message.GetTelemetrySubscriptionsRequestData; |
25 | 30 | import org.apache.kafka.common.message.GetTelemetrySubscriptionsResponseData; |
26 | 31 | import org.apache.kafka.common.message.PushTelemetryRequestData; |
@@ -901,6 +906,163 @@ public void testTelemetryReporterInitiateCloseAlreadyInTerminatedStates() { |
901 | 906 | .telemetrySender()).state()); |
902 | 907 | } |
903 | 908 |
|
| 909 | + @Test |
| 910 | + public void testHandleFailedGetTelemetrySubscriptionsRequestWithRetriableException() { |
| 911 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 912 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 913 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 914 | + |
| 915 | + KafkaException retriableException = new TimeoutException("Request timed out"); |
| 916 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest(retriableException); |
| 917 | + |
| 918 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 919 | + assertEquals(ClientTelemetryReporter.DEFAULT_PUSH_INTERVAL_MS, telemetrySender.intervalMs()); |
| 920 | + assertTrue(telemetrySender.enabled()); |
| 921 | + } |
| 922 | + |
| 923 | + @Test |
| 924 | + public void testHandleFailedGetTelemetrySubscriptionsRequestWithWrappedRetriableException() { |
| 925 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 926 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 927 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 928 | + |
| 929 | + KafkaException wrappedException = new KafkaException(new DisconnectException("Connection lost")); |
| 930 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest(wrappedException); |
| 931 | + |
| 932 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 933 | + assertEquals(ClientTelemetryReporter.DEFAULT_PUSH_INTERVAL_MS, telemetrySender.intervalMs()); |
| 934 | + assertTrue(telemetrySender.enabled()); |
| 935 | + } |
| 936 | + |
| 937 | + @Test |
| 938 | + public void testHandleFailedGetTelemetrySubscriptionsRequestWithFatalException() { |
| 939 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 940 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 941 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 942 | + |
| 943 | + KafkaException fatalException = new AuthorizationException("Not authorized for telemetry"); |
| 944 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest(fatalException); |
| 945 | + |
| 946 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 947 | + assertEquals(Integer.MAX_VALUE, telemetrySender.intervalMs()); |
| 948 | + assertFalse(telemetrySender.enabled()); |
| 949 | + } |
| 950 | + |
| 951 | + @Test |
| 952 | + public void testHandleFailedGetTelemetrySubscriptionsRequestWithWrappedFatalException() { |
| 953 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 954 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 955 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 956 | + |
| 957 | + KafkaException wrappedException = new KafkaException("Version check failed", |
| 958 | + new UnsupportedVersionException("Broker doesn't support telemetry")); |
| 959 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest(wrappedException); |
| 960 | + |
| 961 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 962 | + assertEquals(Integer.MAX_VALUE, telemetrySender.intervalMs()); |
| 963 | + assertFalse(telemetrySender.enabled()); |
| 964 | + } |
| 965 | + |
| 966 | + @Test |
| 967 | + public void testHandleFailedPushTelemetryRequestWithRetriableException() { |
| 968 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 969 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 970 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 971 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.PUSH_NEEDED)); |
| 972 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.PUSH_IN_PROGRESS)); |
| 973 | + |
| 974 | + KafkaException networkException = new NetworkException("Network failure"); |
| 975 | + telemetrySender.handleFailedPushTelemetryRequest(networkException); |
| 976 | + |
| 977 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 978 | + assertEquals(ClientTelemetryReporter.DEFAULT_PUSH_INTERVAL_MS, telemetrySender.intervalMs()); |
| 979 | + assertTrue(telemetrySender.enabled()); |
| 980 | + } |
| 981 | + |
| 982 | + @Test |
| 983 | + public void testHandleFailedPushTelemetryRequestWithFatalException() { |
| 984 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 985 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 986 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 987 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.PUSH_NEEDED)); |
| 988 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.PUSH_IN_PROGRESS)); |
| 989 | + |
| 990 | + KafkaException authException = new AuthorizationException("Not authorized to push telemetry"); |
| 991 | + telemetrySender.handleFailedPushTelemetryRequest(authException); |
| 992 | + |
| 993 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 994 | + assertEquals(Integer.MAX_VALUE, telemetrySender.intervalMs()); |
| 995 | + assertFalse(telemetrySender.enabled()); |
| 996 | + } |
| 997 | + |
| 998 | + @Test |
| 999 | + public void testHandleFailedRequestWithMultipleRetriableExceptionsInChain() { |
| 1000 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 1001 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 1002 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 1003 | + |
| 1004 | + KafkaException chainedException = new TimeoutException("Outer timeout", |
| 1005 | + new DisconnectException("Inner disconnect")); |
| 1006 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest(chainedException); |
| 1007 | + |
| 1008 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 1009 | + assertEquals(ClientTelemetryReporter.DEFAULT_PUSH_INTERVAL_MS, telemetrySender.intervalMs()); |
| 1010 | + assertTrue(telemetrySender.enabled()); |
| 1011 | + } |
| 1012 | + |
| 1013 | + @Test |
| 1014 | + public void testHandleFailedRequestWithGenericKafkaException() { |
| 1015 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 1016 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 1017 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 1018 | + |
| 1019 | + KafkaException genericException = new KafkaException("Unknown error"); |
| 1020 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest(genericException); |
| 1021 | + |
| 1022 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 1023 | + assertEquals(Integer.MAX_VALUE, telemetrySender.intervalMs()); |
| 1024 | + assertFalse(telemetrySender.enabled()); |
| 1025 | + } |
| 1026 | + |
| 1027 | + @Test |
| 1028 | + public void testHandleFailedRequestDuringTermination() { |
| 1029 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 1030 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 1031 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 1032 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.PUSH_NEEDED)); |
| 1033 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.TERMINATING_PUSH_NEEDED)); |
| 1034 | + |
| 1035 | + KafkaException exception = new TimeoutException("Timeout"); |
| 1036 | + telemetrySender.handleFailedPushTelemetryRequest(exception); |
| 1037 | + |
| 1038 | + assertEquals(ClientTelemetryState.TERMINATING_PUSH_NEEDED, telemetrySender.state()); |
| 1039 | + assertTrue(telemetrySender.enabled()); |
| 1040 | + } |
| 1041 | + |
| 1042 | + @Test |
| 1043 | + public void testSequentialFailuresWithDifferentExceptionTypes() { |
| 1044 | + ClientTelemetryReporter.DefaultClientTelemetrySender telemetrySender = (ClientTelemetryReporter.DefaultClientTelemetrySender) clientTelemetryReporter.telemetrySender(); |
| 1045 | + telemetrySender.updateSubscriptionResult(subscription, time.milliseconds()); |
| 1046 | + |
| 1047 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 1048 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest( |
| 1049 | + new TimeoutException("Timeout 1")); |
| 1050 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 1051 | + assertTrue(telemetrySender.enabled()); |
| 1052 | + |
| 1053 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 1054 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest( |
| 1055 | + new DisconnectException("Disconnect")); |
| 1056 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 1057 | + assertTrue(telemetrySender.enabled()); |
| 1058 | + |
| 1059 | + assertTrue(telemetrySender.maybeSetState(ClientTelemetryState.SUBSCRIPTION_IN_PROGRESS)); |
| 1060 | + telemetrySender.handleFailedGetTelemetrySubscriptionsRequest( |
| 1061 | + new UnsupportedVersionException("Version not supported")); |
| 1062 | + assertEquals(ClientTelemetryState.SUBSCRIPTION_NEEDED, telemetrySender.state()); |
| 1063 | + assertFalse(telemetrySender.enabled()); |
| 1064 | + } |
| 1065 | + |
904 | 1066 | @AfterEach |
905 | 1067 | public void tearDown() { |
906 | 1068 | clientTelemetryReporter.close(); |
|
0 commit comments