mirror of
https://github.com/FabInfra/capnproto-dotnetcore_Runtime.git
synced 2025-03-12 23:01:44 +01:00
49 lines
1.6 KiB
C#
49 lines
1.6 KiB
C#
using Capnp.Rpc;
|
|
using CapnpGen;
|
|
using CapnpProfile.Services;
|
|
using System;
|
|
using System.Net;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace CapnpProfile
|
|
{
|
|
class Program
|
|
{
|
|
static async Task Main(string[] args)
|
|
{
|
|
using var server = new TcpRpcServer();
|
|
server.Main = new CapnpEchoService();
|
|
server.AddBuffering();
|
|
server.StartAccepting(IPAddress.Any, 5002);
|
|
using var client = new TcpRpcClient("localhost", 5002);
|
|
await client.WhenConnected;
|
|
using var echoer = client.GetMain<IEchoer>();
|
|
var payload = new byte[20];
|
|
new Random().NextBytes(payload);
|
|
|
|
#if SOTASK_PERF
|
|
int counter = 0;
|
|
#endif
|
|
|
|
while (true)
|
|
{
|
|
var result = await echoer.Echo(payload);
|
|
if (result.Count != payload.Length)
|
|
throw new InvalidOperationException("Echo server malfunction");
|
|
|
|
#if SOTASK_PERF
|
|
if (++counter == 1000)
|
|
{
|
|
counter = 0;
|
|
|
|
Console.WriteLine($"StrictlyOrderedTask performance statistics:");
|
|
Console.WriteLine($"AwaitInternal: max. {Capnp.Util.StrictlyOrderedTaskExtensions.Stats.AwaitInternalMaxOuterIterations} outer iterations");
|
|
Console.WriteLine($"AwaitInternal: max. {Capnp.Util.StrictlyOrderedTaskExtensions.Stats.AwaitInternalMaxInnerIterations} inner iterations");
|
|
Console.WriteLine($"OnCompleted: max. {Capnp.Util.StrictlyOrderedTaskExtensions.Stats.OnCompletedMaxSpins} iterations");
|
|
}
|
|
#endif
|
|
}
|
|
}
|
|
}
|
|
}
|