|
| 1 | +package dev.vality.woody.api.interceptor; |
| 2 | + |
| 3 | +import dev.vality.woody.api.MDCUtils; |
| 4 | +import dev.vality.woody.api.trace.TraceData; |
| 5 | +import dev.vality.woody.api.trace.context.TraceContext; |
| 6 | +import org.junit.After; |
| 7 | +import org.junit.Before; |
| 8 | +import org.junit.Test; |
| 9 | +import org.slf4j.MDC; |
| 10 | + |
| 11 | +import static org.junit.Assert.*; |
| 12 | + |
| 13 | +public class ContextInterceptorTest { |
| 14 | + |
| 15 | + private TraceData originalTraceData; |
| 16 | + private TraceData testTraceData; |
| 17 | + |
| 18 | + @Before |
| 19 | + public void setUp() { |
| 20 | + originalTraceData = TraceContext.getCurrentTraceData(); |
| 21 | + testTraceData = new TraceData(); |
| 22 | + TraceContext.setCurrentTraceData(testTraceData); |
| 23 | + MDC.clear(); |
| 24 | + } |
| 25 | + |
| 26 | + @After |
| 27 | + public void tearDown() { |
| 28 | + MDC.clear(); |
| 29 | + if (testTraceData != null) { |
| 30 | + testTraceData.getOtelSpan().end(); |
| 31 | + } |
| 32 | + TraceContext.setCurrentTraceData(originalTraceData); |
| 33 | + } |
| 34 | + |
| 35 | + @Test |
| 36 | + public void skipInitWhenServiceSpanEmpty() { |
| 37 | + RecordingInterceptor delegate = new RecordingInterceptor(); |
| 38 | + ContextInterceptor interceptor = new ContextInterceptor(TraceContext.forService(), delegate); |
| 39 | + |
| 40 | + TraceData current = TraceContext.getCurrentTraceData(); |
| 41 | + MDC.put(MDCUtils.SPAN_ID, "existing"); |
| 42 | + |
| 43 | + assertTrue(interceptor.interceptRequest(current, null)); |
| 44 | + assertTrue(delegate.requestInvoked); |
| 45 | + |
| 46 | + interceptor.interceptResponse(current, null); |
| 47 | + |
| 48 | + assertTrue(delegate.responseInvoked); |
| 49 | + assertNull(MDC.get(MDCUtils.SPAN_ID)); |
| 50 | + assertFalse(TraceContext.getCurrentTraceData().getServiceSpan().isFilled()); |
| 51 | + } |
| 52 | + |
| 53 | + @Test |
| 54 | + public void destroyWithoutTraceDataClearsMdc() { |
| 55 | + TraceContext.setCurrentTraceData(null); |
| 56 | + MDC.put(MDCUtils.SPAN_ID, "value"); |
| 57 | + |
| 58 | + TraceContext.forService().destroy(); |
| 59 | + |
| 60 | + assertNull(MDC.get(MDCUtils.SPAN_ID)); |
| 61 | + TraceContext.setCurrentTraceData(testTraceData); |
| 62 | + } |
| 63 | + |
| 64 | + private static class RecordingInterceptor extends EmptyCommonInterceptor { |
| 65 | + private boolean requestInvoked; |
| 66 | + private boolean responseInvoked; |
| 67 | + |
| 68 | + @Override |
| 69 | + public boolean interceptRequest(TraceData traceData, Object providerContext, Object... contextParams) { |
| 70 | + requestInvoked = true; |
| 71 | + return super.interceptRequest(traceData, providerContext, contextParams); |
| 72 | + } |
| 73 | + |
| 74 | + @Override |
| 75 | + public boolean interceptResponse(TraceData traceData, Object providerContext, Object... contextParams) { |
| 76 | + responseInvoked = true; |
| 77 | + return super.interceptResponse(traceData, providerContext, contextParams); |
| 78 | + } |
| 79 | + } |
| 80 | +} |
0 commit comments