-
Notifications
You must be signed in to change notification settings - Fork 775
/
AwsXrayIdGeneratorBenchmark.java
44 lines (39 loc) · 1.35 KB
/
AwsXrayIdGeneratorBenchmark.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/*
* Copyright The OpenTelemetry Authors
* SPDX-License-Identifier: Apache-2.0
*/
package io.opentelemetry.sdk.extension.aws;
import java.util.concurrent.TimeUnit;
import org.openjdk.jmh.annotations.Benchmark;
import org.openjdk.jmh.annotations.BenchmarkMode;
import org.openjdk.jmh.annotations.Fork;
import org.openjdk.jmh.annotations.Measurement;
import org.openjdk.jmh.annotations.Mode;
import org.openjdk.jmh.annotations.OutputTimeUnit;
import org.openjdk.jmh.annotations.Scope;
import org.openjdk.jmh.annotations.State;
import org.openjdk.jmh.annotations.Warmup;
@State(Scope.Benchmark)
@SuppressWarnings("deprecation") // Moved to contrib
public class AwsXrayIdGeneratorBenchmark {
private final io.opentelemetry.sdk.extension.aws.trace.AwsXrayIdGenerator idGenerator =
io.opentelemetry.sdk.extension.aws.trace.AwsXrayIdGenerator.getInstance();
@Benchmark
@Measurement(iterations = 15, time = 1)
@Warmup(iterations = 5, time = 1)
@OutputTimeUnit(TimeUnit.NANOSECONDS)
@BenchmarkMode(Mode.AverageTime)
@Fork(1)
public String generateTraceId() {
return idGenerator.generateTraceId();
}
@Benchmark
@Measurement(iterations = 15, time = 1)
@Warmup(iterations = 5, time = 1)
@OutputTimeUnit(TimeUnit.NANOSECONDS)
@BenchmarkMode(Mode.AverageTime)
@Fork(1)
public String generateSpanId() {
return idGenerator.generateSpanId();
}
}