Skip to content

Commit

Permalink
Add javadoc for the opentelemetry context timer.
Browse files Browse the repository at this point in the history
Signed-off-by: Sjoerd Talsma <[email protected]>
  • Loading branch information
sjoerdtalsma committed Nov 24, 2024
1 parent 0b8611b commit 59fcc3d
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
/*
* Copyright 2016-2024 Talsma ICT
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* {@link nl.talsmasoftware.context.api.ContextTimer Context timer} that
* updates a {@linkplain io.micrometer.core.instrument.Timer micrometer Timer}
* to {@linkplain io.micrometer.core.instrument.Timer#record(long, TimeUnit) record}
* the context switching durations.
*/
package nl.talsmasoftware.context.timers.micrometer;

import java.util.concurrent.TimeUnit;
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,38 @@

import static io.opentelemetry.api.common.AttributeKey.stringKey;

/**
* {@link nl.talsmasoftware.context.api.ContextTimer Context timer} that
* creates a {@linkplain io.opentelemetry.api.trace.Span Span}
* using the {@linkplain io.opentelemetry.api.GlobalOpenTelemetry GlobalOpenTelemetry}
* for context switches.
*
* <p>
* Individual {@linkplain nl.talsmasoftware.context.api.ContextManager context managers}
* are <strong>not</strong> traced, only the operations regarding {@linkplain ContextSnapshot}
* are traced.
*
* @author Sjoerd Talsma
*/
public class OpenTelemetryContextTimer implements ContextTimer {
private static final Logger LOGGER = Logger.getLogger(OpenTelemetryContextTimer.class.getName());
private static final String INSTRUMENTATION_SCOPE = "nl.talsmasoftware.context";
private static final String INSTRUMENTATION_VERSION = Optional.ofNullable(readVersion()).orElse("2.0.0");

/**
* Creates a {@linkplain Span} using the {@linkplain GlobalOpenTelemetry} for context switches.
*
* <p>
* Individual {@linkplain nl.talsmasoftware.context.api.ContextManager context managers}
* are <strong>not</strong> traced, only the operations regarding {@linkplain ContextSnapshot}
* are traced.
*
* @param type Class that was called
* @param method Method that was called
* @param duration Duration of the call
* @param unit Unit of the duration
* @param error Error that was thrown in the call (optional, normally {@code null})
*/
@Override
public void update(Class<?> type, String method, long duration, TimeUnit unit, Throwable error) {
if (mustTrace(type)) {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
/*
* Copyright 2016-2024 Talsma ICT
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* {@link nl.talsmasoftware.context.api.ContextTimer Context timer} that
* creates a {@linkplain io.opentelemetry.api.trace.Span Span}
* using the {@linkplain io.opentelemetry.api.GlobalOpenTelemetry GlobalOpenTelemetry}
* for context switches.
*
* <p>
* Individual {@linkplain nl.talsmasoftware.context.api.ContextManager context managers}
* are <strong>not</strong> traced, only the operations regarding {@linkplain nl.talsmasoftware.context.api.ContextSnapshot}
* are traced.
*/
package nl.talsmasoftware.context.timers.opentelemetry;

0 comments on commit 59fcc3d

Please sign in to comment.