/* * Copyright 2016, Google Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. * * * Neither the name of Google Inc. nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ package io.grpc.netty; import io.grpc.InternalKnownTransport; import io.grpc.InternalMethodDescriptor; import io.grpc.MethodDescriptor; import io.netty.util.AsciiString; import java.io.ByteArrayInputStream; import java.io.InputStream; 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.State; /** * Benchmark for Method Descriptors. */ @State(Scope.Benchmark) public class MethodDescriptorBenchmark { private static final MethodDescriptor.Marshaller<Void> marshaller = new MethodDescriptor.Marshaller<Void>() { @Override public InputStream stream(Void value) { return new ByteArrayInputStream(new byte[]{}); } @Override public Void parse(InputStream stream) { return null; } }; MethodDescriptor<Void, Void> method = MethodDescriptor.<Void, Void>newBuilder() .setType(MethodDescriptor.MethodType.UNARY) .setFullMethodName("Service/Method") .setRequestMarshaller(marshaller) .setResponseMarshaller(marshaller) .build(); InternalMethodDescriptor imd = new InternalMethodDescriptor(InternalKnownTransport.NETTY); byte[] directBytes = new AsciiString("/" + method.getFullMethodName()).toByteArray(); /** Foo bar. */ @Benchmark @BenchmarkMode(Mode.SampleTime) @OutputTimeUnit(TimeUnit.NANOSECONDS) public AsciiString old() { return new AsciiString("/" + method.getFullMethodName()); } /** Foo bar. */ @Benchmark @BenchmarkMode(Mode.SampleTime) @OutputTimeUnit(TimeUnit.NANOSECONDS) public AsciiString transportSpecific() { AsciiString path; if ((path = (AsciiString) imd.geRawMethodName(method)) != null) { path = new AsciiString("/" + method.getFullMethodName()); imd.setRawMethodName(method, path); } return path; } /** Foo bar. */ @Benchmark @BenchmarkMode(Mode.SampleTime) @OutputTimeUnit(TimeUnit.NANOSECONDS) public AsciiString direct() { return new AsciiString(directBytes, false); } }