From 79b9fe0ddb23025abd3d1029f776bca3d13d7952 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christian=20Neum=C3=BCller?= Date: Thu, 12 Dec 2019 12:56:45 +0100 Subject: [PATCH] Simplify span end time. The only reason to have now() returned in getEndEpochNanos seems to be that it kinda makes sense for getLatencyMs, but that method is package-private and never used. See also https://github.com/open-telemetry/opentelemetry-specification/issues/373#issuecomment-564939980. --- .../sdk/trace/RecordEventsReadableSpan.java | 24 ++-------------- .../sdk/OpenTelemetrySdkTest.java | 7 +++++ .../trace/RecordEventsReadableSpanTest.java | 28 +------------------ 3 files changed, 11 insertions(+), 48 deletions(-) diff --git a/sdk/src/main/java/io/opentelemetry/sdk/trace/RecordEventsReadableSpan.java b/sdk/src/main/java/io/opentelemetry/sdk/trace/RecordEventsReadableSpan.java index 1aa0ed6a5c4..e84b1143899 100644 --- a/sdk/src/main/java/io/opentelemetry/sdk/trace/RecordEventsReadableSpan.java +++ b/sdk/src/main/java/io/opentelemetry/sdk/trace/RecordEventsReadableSpan.java @@ -220,14 +220,14 @@ public InstrumentationLibraryInfo getInstrumentationLibraryInfo() { } /** - * Returns the end nano time (see {@link System#nanoTime()}). If the current {@code Span} is not - * ended then returns {@link Clock#nanoTime()}. + * Returns the end nano time (see {@link System#nanoTime()}) or zero if the current {@code Span} + * is not ended. * * @return the end nano time. */ private long getEndEpochNanos() { synchronized (lock) { - return getEndNanoTimeInternal(); + return endEpochNanos; } } @@ -291,24 +291,6 @@ Map getAttributes() { } } - /** - * Returns the latency of the {@code Span} in nanos. If still active then returns now() - start - * time. - * - * @return the latency of the {@code Span} in nanos. - */ - long getLatencyNs() { - synchronized (lock) { - return getEndNanoTimeInternal() - startEpochNanos; - } - } - - // Use getEndNanoTimeInternal to avoid over-locking. - @GuardedBy("lock") - private long getEndNanoTimeInternal() { - return hasBeenEnded ? endEpochNanos : clock.now(); - } - /** * Returns the kind of this {@code Span}. * diff --git a/sdk/src/test/java/io/opentelemetry/sdk/OpenTelemetrySdkTest.java b/sdk/src/test/java/io/opentelemetry/sdk/OpenTelemetrySdkTest.java index c17aad4a82d..c019dc75642 100644 --- a/sdk/src/test/java/io/opentelemetry/sdk/OpenTelemetrySdkTest.java +++ b/sdk/src/test/java/io/opentelemetry/sdk/OpenTelemetrySdkTest.java @@ -19,6 +19,9 @@ import static com.google.common.truth.Truth.assertThat; import io.opentelemetry.OpenTelemetry; +import io.opentelemetry.sdk.trace.ReadableSpan; +import io.opentelemetry.sdk.trace.SpanData; +import io.opentelemetry.trace.Span; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.JUnit4; @@ -34,5 +37,9 @@ public void testDefault() { .isSameInstanceAs(OpenTelemetry.getDistributedContextManager()); assertThat(OpenTelemetrySdk.getMeterFactory()) .isSameInstanceAs(OpenTelemetry.getMeterFactory()); + + Span span = OpenTelemetrySdk.getTracerFactory().get("foo").spanBuilder("bar").startSpan(); + SpanData sd = ((ReadableSpan) span).toSpanData(); + System.out.println(sd); } } diff --git a/sdk/src/test/java/io/opentelemetry/sdk/trace/RecordEventsReadableSpanTest.java b/sdk/src/test/java/io/opentelemetry/sdk/trace/RecordEventsReadableSpanTest.java index 3bfaee85760..8b3a6a22e99 100644 --- a/sdk/src/test/java/io/opentelemetry/sdk/trace/RecordEventsReadableSpanTest.java +++ b/sdk/src/test/java/io/opentelemetry/sdk/trace/RecordEventsReadableSpanTest.java @@ -134,7 +134,7 @@ public void toSpanData_ActiveSpan() { Collections.singletonList(link), SPAN_NEW_NAME, startEpochNanos, - testClock.now(), + 0, Status.OK); } finally { span.end(); @@ -243,32 +243,6 @@ public void getAndUpdateSpanName() { } } - @Test - public void getLatencyNs_ActiveSpan() { - RecordEventsReadableSpan span = createTestSpan(Kind.INTERNAL); - try { - testClock.advanceMillis(MILLIS_PER_SECOND); - long elapsedTimeNanos1 = testClock.now() - startEpochNanos; - assertThat(span.getLatencyNs()).isEqualTo(elapsedTimeNanos1); - testClock.advanceMillis(MILLIS_PER_SECOND); - long elapsedTimeNanos2 = testClock.now() - startEpochNanos; - assertThat(span.getLatencyNs()).isEqualTo(elapsedTimeNanos2); - } finally { - span.end(); - } - } - - @Test - public void getLatencyNs_EndedSpan() { - RecordEventsReadableSpan span = createTestSpan(Kind.INTERNAL); - testClock.advanceMillis(MILLIS_PER_SECOND); - span.end(); - long elapsedTimeNanos = testClock.now() - startEpochNanos; - assertThat(span.getLatencyNs()).isEqualTo(elapsedTimeNanos); - testClock.advanceMillis(MILLIS_PER_SECOND); - assertThat(span.getLatencyNs()).isEqualTo(elapsedTimeNanos); - } - @Test public void setAttribute() { RecordEventsReadableSpan span = createTestRootSpan();