|
|
|
@ -0,0 +1,69 @@ |
|
|
|
|
#region Copyright notice and license |
|
|
|
|
|
|
|
|
|
// Copyright 2015 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. |
|
|
|
|
|
|
|
|
|
#endregion |
|
|
|
|
|
|
|
|
|
using System; |
|
|
|
|
using System.Runtime.InteropServices; |
|
|
|
|
using System.Threading; |
|
|
|
|
using Grpc.Core; |
|
|
|
|
using Grpc.Core.Internal; |
|
|
|
|
using System.Collections.Generic; |
|
|
|
|
using System.Diagnostics; |
|
|
|
|
|
|
|
|
|
namespace Grpc.Microbenchmarks |
|
|
|
|
{ |
|
|
|
|
public class CompletionRegistryBenchmark |
|
|
|
|
{ |
|
|
|
|
GrpcEnvironment environment; |
|
|
|
|
|
|
|
|
|
public void Init() |
|
|
|
|
{ |
|
|
|
|
environment = GrpcEnvironment.AddRef(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public void Cleanup() |
|
|
|
|
{ |
|
|
|
|
GrpcEnvironment.ReleaseAsync().Wait(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public void Run(int threadCount, int iterations) |
|
|
|
|
{ |
|
|
|
|
Console.WriteLine(string.Format("CompletionRegistryBenchmark: threads={0}, iterations={1}", threadCount, iterations)); |
|
|
|
|
var threadedBenchmark = new ThreadedBenchmark(threadCount, () => ThreadBody(iterations)); |
|
|
|
|
threadedBenchmark.Run(); |
|
|
|
|
// TODO: parametrize by number of pending completions |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
private void ThreadBody(int iterations) |
|
|
|
|
{ |
|
|
|
|
var completionRegistry = new CompletionRegistry(environment); |
|
|
|
|
var ctx = BatchContextSafeHandle.Create(); |
|
|
|
|
var completionDelegate = new OpCompletionDelegate((success) => {}); |
|
|
|
|
|
|
|
|
|
var stopwatch = Stopwatch.StartNew(); |
|
|
|
|
for (int i = 0; i < iterations; i++) |
|
|
|
|
{ |
|
|
|
|
completionRegistry.Register(ctx.DangerousGetHandle(), completionDelegate); |
|
|
|
|
var callback = completionRegistry.Extract(completionRegistry.LastRegisteredKey); |
|
|
|
|
} |
|
|
|
|
stopwatch.Stop(); |
|
|
|
|
Console.WriteLine("Elapsed millis: " + stopwatch.ElapsedMilliseconds); |
|
|
|
|
|
|
|
|
|
ctx.Dispose(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |