|
1 | 1 | /*
|
2 |
| - * Copyright 2021 the original author or authors. |
| 2 | + * Copyright 2021-2022 the original author or authors. |
3 | 3 | *
|
4 | 4 | * Licensed under the Apache License, Version 2.0 (the "License");
|
5 | 5 | * you may not use this file except in compliance with the License.
|
|
18 | 18 |
|
19 | 19 | import static org.mockito.ArgumentMatchers.any;
|
20 | 20 | import static org.mockito.Mockito.mock;
|
| 21 | +import static org.mockito.Mockito.never; |
21 | 22 | import static org.mockito.Mockito.verify;
|
22 | 23 |
|
23 | 24 | import java.io.IOException;
|
|
29 | 30 | import org.junit.jupiter.api.Test;
|
30 | 31 |
|
31 | 32 | import org.springframework.kafka.KafkaException;
|
| 33 | +import org.springframework.kafka.core.KafkaProducerException; |
32 | 34 |
|
33 | 35 | /**
|
34 |
| - * Tests for {@link CommonDelegatingErrorHandler}. Copied from |
35 |
| - * {@link ConditionalDelegatingErrorHandlerTests} with changed handler type. |
| 36 | + * Tests for {@link CommonDelegatingErrorHandler}. |
36 | 37 | *
|
37 | 38 | * @author Gary Russell
|
| 39 | + * @author Adrian Chlebosz |
38 | 40 | * @since 2.8
|
39 | 41 | *
|
40 | 42 | */
|
@@ -88,6 +90,83 @@ void testBatchDelegates() {
|
88 | 90 | verify(one).handleBatch(any(), any(), any(), any(), any());
|
89 | 91 | }
|
90 | 92 |
|
| 93 | + @Test |
| 94 | + void testDelegateForThrowableIsAppliedWhenCauseTraversingIsEnabled() { |
| 95 | + var defaultHandler = mock(CommonErrorHandler.class); |
| 96 | + |
| 97 | + var directCauseErrorHandler = mock(CommonErrorHandler.class); |
| 98 | + var directCauseExc = new IllegalArgumentException(); |
| 99 | + var errorHandler = mock(CommonErrorHandler.class); |
| 100 | + var exc = new UnsupportedOperationException(directCauseExc); |
| 101 | + |
| 102 | + var delegatingErrorHandler = new CommonDelegatingErrorHandler(defaultHandler); |
| 103 | + delegatingErrorHandler.setCauseChainTraversing(true); |
| 104 | + delegatingErrorHandler.setErrorHandlers(Map.of( |
| 105 | + exc.getClass(), errorHandler, |
| 106 | + directCauseExc.getClass(), directCauseErrorHandler |
| 107 | + )); |
| 108 | + |
| 109 | + delegatingErrorHandler.handleRemaining(directCauseExc, Collections.emptyList(), mock(Consumer.class), |
| 110 | + mock(MessageListenerContainer.class)); |
| 111 | + |
| 112 | + verify(directCauseErrorHandler).handleRemaining(any(), any(), any(), any()); |
| 113 | + verify(errorHandler, never()).handleRemaining(any(), any(), any(), any()); |
| 114 | + } |
| 115 | + |
| 116 | + @Test |
| 117 | + void testDelegateForThrowableCauseIsAppliedWhenCauseTraversingIsEnabled() { |
| 118 | + var defaultHandler = mock(CommonErrorHandler.class); |
| 119 | + |
| 120 | + var directCauseErrorHandler = mock(CommonErrorHandler.class); |
| 121 | + var directCauseExc = new IllegalArgumentException(); |
| 122 | + var exc = new UnsupportedOperationException(directCauseExc); |
| 123 | + |
| 124 | + var delegatingErrorHandler = new CommonDelegatingErrorHandler(defaultHandler); |
| 125 | + delegatingErrorHandler.setCauseChainTraversing(true); |
| 126 | + delegatingErrorHandler.setErrorHandlers(Map.of( |
| 127 | + directCauseExc.getClass(), directCauseErrorHandler |
| 128 | + )); |
| 129 | + |
| 130 | + delegatingErrorHandler.handleRemaining(exc, Collections.emptyList(), mock(Consumer.class), |
| 131 | + mock(MessageListenerContainer.class)); |
| 132 | + |
| 133 | + verify(directCauseErrorHandler).handleRemaining(any(), any(), any(), any()); |
| 134 | + } |
| 135 | + |
| 136 | + @Test |
| 137 | + @SuppressWarnings("ConstantConditions") |
| 138 | + void testDelegateForClassifiableThrowableCauseIsAppliedWhenCauseTraversingIsEnabled() { |
| 139 | + var defaultHandler = mock(CommonErrorHandler.class); |
| 140 | + |
| 141 | + var directCauseErrorHandler = mock(CommonErrorHandler.class); |
| 142 | + var directCauseExc = new KafkaProducerException(null, null, null); |
| 143 | + var exc = new UnsupportedOperationException(directCauseExc); |
| 144 | + |
| 145 | + var delegatingErrorHandler = new CommonDelegatingErrorHandler(defaultHandler); |
| 146 | + delegatingErrorHandler.setCauseChainTraversing(true); |
| 147 | + delegatingErrorHandler.setErrorHandlers(Map.of( |
| 148 | + KafkaException.class, directCauseErrorHandler |
| 149 | + )); |
| 150 | + |
| 151 | + delegatingErrorHandler.handleRemaining(exc, Collections.emptyList(), mock(Consumer.class), |
| 152 | + mock(MessageListenerContainer.class)); |
| 153 | + |
| 154 | + verify(directCauseErrorHandler).handleRemaining(any(), any(), any(), any()); |
| 155 | + } |
| 156 | + |
| 157 | + @Test |
| 158 | + @SuppressWarnings("ConstantConditions") |
| 159 | + void testDefaultDelegateIsApplied() { |
| 160 | + var defaultHandler = mock(CommonErrorHandler.class); |
| 161 | + var delegatingErrorHandler = new CommonDelegatingErrorHandler(defaultHandler); |
| 162 | + delegatingErrorHandler.setCauseChainTraversing(true); |
| 163 | + |
| 164 | + delegatingErrorHandler.handleRemaining(null, Collections.emptyList(), mock(Consumer.class), |
| 165 | + mock(MessageListenerContainer.class)); |
| 166 | + |
| 167 | + verify(defaultHandler).handleRemaining(any(), any(), any(), any()); |
| 168 | + } |
| 169 | + |
91 | 170 | private Exception wrap(Exception ex) {
|
92 | 171 | return new ListenerExecutionFailedException("test", ex);
|
93 | 172 | }
|
|
0 commit comments