/* * Copyright 2017 The gRPC Authors * * 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. */ package io.grpc; import java.util.ArrayList; import java.util.List; import java.util.concurrent.TimeUnit; import org.openjdk.jmh.annotations.Benchmark; import org.openjdk.jmh.annotations.BenchmarkMode; import org.openjdk.jmh.annotations.Mode; import org.openjdk.jmh.annotations.OutputTimeUnit; import org.openjdk.jmh.annotations.Scope; import org.openjdk.jmh.annotations.Setup; import org.openjdk.jmh.annotations.State; import org.openjdk.jmh.infra.Blackhole; /** Read benchmark. */ public class ReadBenchmark { @State(Scope.Benchmark) public static class ContextState { List> keys = new ArrayList>(); List contexts = new ArrayList<>(); @Setup public void setup() { for (int i = 0; i < 8; i++) { keys.add(Context.key("Key" + i)); } contexts.add(Context.ROOT.withValue(keys.get(0), new Object())); contexts.add(Context.ROOT.withValues(keys.get(0), new Object(), keys.get(1), new Object())); contexts.add( Context.ROOT.withValues( keys.get(0), new Object(), keys.get(1), new Object(), keys.get(2), new Object())); contexts.add( Context.ROOT.withValues( keys.get(0), new Object(), keys.get(1), new Object(), keys.get(2), new Object(), keys.get(3), new Object())); contexts.add(contexts.get(0).withValue(keys.get(1), new Object())); contexts.add( contexts.get(1).withValues(keys.get(2), new Object(), keys.get(3), new Object())); contexts.add( contexts .get(2) .withValues( keys.get(3), new Object(), keys.get(4), new Object(), keys.get(5), new Object())); contexts.add( contexts .get(3) .withValues( keys.get(4), new Object(), keys.get(5), new Object(), keys.get(6), new Object(), keys.get(7), new Object())); } } /** Perform the read operation. */ @Benchmark @BenchmarkMode(Mode.SampleTime) @OutputTimeUnit(TimeUnit.NANOSECONDS) public void testContextLookup(ContextState state, Blackhole bh) { for (Context.Key key : state.keys) { for (Context ctx : state.contexts) { bh.consume(key.get(ctx)); } } } }