Skip to content

Commit

Permalink
Fix off-by-one error which effectively disabled recycling validation
Browse files Browse the repository at this point in the history
  • Loading branch information
JonasKunz committed Oct 12, 2023
1 parent 61dfa35 commit 93ec02f
Show file tree
Hide file tree
Showing 6 changed files with 17 additions and 8 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,10 @@ public static ElasticApmTracer createRealTracer(Reporter reporter, Configuration
* values that can be customized by mocking the configuration.
*/
public static synchronized MockInstrumentationSetup createMockInstrumentationSetup(ConfigurationRegistry configRegistry) {
return createMockInstrumentationSetup(configRegistry, true);
}

public static synchronized MockInstrumentationSetup createMockInstrumentationSetup(ConfigurationRegistry configRegistry, boolean checkRecycling) {
// use an object pool that does bookkeeping to allow for extra usage checks
TestObjectPoolFactory objectPoolFactory = new TestObjectPoolFactory();

Expand All @@ -106,9 +110,11 @@ public static synchronized MockInstrumentationSetup createMockInstrumentationSet
// is left behind
.withObjectPoolFactory(objectPoolFactory)
.withLifecycleListener(ClosableLifecycleListenerAdapter.of(() -> {
reporter.assertRecycledAfterDecrementingReferences();
// checking proper object pool usage using tracer lifecycle events
objectPoolFactory.checkAllPooledObjectsHaveBeenRecycled();
if (checkRecycling) {
reporter.assertRecycledAfterDecrementingReferences();
// checking proper object pool usage using tracer lifecycle events
objectPoolFactory.checkAllPooledObjectsHaveBeenRecycled();
}
}))
.buildAndStart();
return new MockInstrumentationSetup(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ public void checkAllPooledObjectsHaveBeenRecycled() {
// silently ignored
}
}
} while (retry-- > 0 && hasSomethingLeft);
} while (--retry > 0 && hasSomethingLeft);

if (retry == 0 && hasSomethingLeft) {
for (BookkeeperObjectPool<?> pool : createdPools) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -88,8 +88,8 @@ public void setup() throws MalformedURLException {

@AfterEach
public void cleanup() {
reporter.reset();
objectPoolFactory.checkAllPooledObjectsHaveBeenRecycled();
reporter.resetWithoutRecycling();
objectPoolFactory.reset();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
import co.elastic.apm.agent.MockTracer;
import co.elastic.apm.agent.bci.ElasticApmAgent;
import co.elastic.apm.agent.configuration.CoreConfiguration;
import co.elastic.apm.agent.configuration.SpyConfiguration;
import co.elastic.apm.agent.impl.ElasticApmTracer;
import net.bytebuddy.agent.ByteBuddyAgent;
import org.junit.jupiter.api.AfterAll;
Expand Down Expand Up @@ -49,7 +50,7 @@ void cleanup() {
}

private void init(boolean annotationInheritanceEnabled) {
MockTracer.MockInstrumentationSetup mockInstrumentationSetup = MockTracer.createMockInstrumentationSetup();
MockTracer.MockInstrumentationSetup mockInstrumentationSetup = MockTracer.createMockInstrumentationSetup(SpyConfiguration.createSpyConfig(), false);
tracer = mockInstrumentationSetup.getTracer();
doReturn(annotationInheritanceEnabled).when(tracer.getConfig(CoreConfiguration.class)).isEnablePublicApiAnnotationInheritance();
reporter = mockInstrumentationSetup.getReporter();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -401,6 +401,7 @@ private void verifyTraceContextHeaders(Span span, String path) {
assertThat(transaction).isNotNull();
assertThat(transaction.getTraceContext().getTraceId()).isEqualTo(span.getTraceContext().getTraceId());
assertThat(transaction.getTraceContext().getParentId()).isEqualTo(span.getTraceContext().getId());
transaction.decrementReferences(); //recycle transaction without reporting
});
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ void testTransactionContext() {
try (Scope scope = transaction.activateInScope()) {
assertThat(CorrelationIdMapAdapter.get()).containsOnlyKeys("trace.id", "transaction.id");
} finally {
transaction.end();
transaction.decrementReferences(); //recycle without reporting
}
assertThat(CorrelationIdMapAdapter.get()).isEmpty();
}
Expand All @@ -70,8 +70,9 @@ void testSpanContext() {
assertThat(CorrelationIdMapAdapter.get()).containsOnlyKeys("trace.id", "transaction.id");
} finally {
span.end();
span.decrementReferences();
}
transaction.end();
transaction.decrementReferences();
assertThat(CorrelationIdMapAdapter.get()).isEmpty();
}

Expand Down

0 comments on commit 93ec02f

Please sign in to comment.