using Echo.ThriftModel; using System; using System.Collections.Generic; using System.Diagnostics; using System.Text; namespace Esiur.Tests.RPC.Client; public class ThriftTest { public static async Task DoTest(string host, int port, Dictionary docsWorkloads, Dictionary dataWorkloads, Dictionary intWorkloads, int warmupDelayMs = 3000, int postHandshakeDelayMs = 2000, int sampleDelayMs = 3000) { var rt = new TestResults(); using var mon = new PerProcessNetMonitor(Process.GetCurrentProcess().Id); mon.Start(); Console.WriteLine($"\n== Thrift @ {host} =="); using var socket = new Thrift.Transport.Client.TSocketTransport(host, port, new Thrift.TConfiguration()); //await socket.OpenAsync(new CancellationToken()); var proto = new Thrift.Protocol.TBinaryProtocol(socket); var service = new EchoService.Client(proto); Thread.Sleep(warmupDelayMs); var (tx, rx, ctx, crx) = mon.GetDiff(0, 0); Console.WriteLine($"Handshake {ctx}/{crx}"); await Task.Delay(postHandshakeDelayMs); foreach (var w in docsWorkloads) { Console.Write("Workload: " + w.Key); var docs = await service.EchoDocuments(w.Value.ToList()); //for (var i = 0; i < docs.Length; i++) // if (!docs[i].Equals(w.Value[i])) // throw new Exception("No match"); await Task.Delay(sampleDelayMs); (tx, rx, ctx, crx) = mon.GetDiff(tx, rx); Console.WriteLine($", {tx}/{rx}, {ctx}/{crx}"); rt.Docs.Add(w.Key, (ctx, crx)); } foreach (var w in dataWorkloads) { Console.Write("Bytes Workload: " + w.Key); var res = await service.EchoBytes(w.Value); if (!w.Value.SequenceEqual(res)) throw new Exception("No match"); await Task.Delay(sampleDelayMs); (tx, rx, ctx, crx) = mon.GetDiff(tx, rx); Console.WriteLine($", {tx}/{rx}, {ctx}/{crx}"); //Console.WriteLine($"Socket {sock.BytesSent}/{sock.BytesReceived}"); rt.Bytes.Add(w.Key, (ctx, crx)); } foreach (var w in intWorkloads) { Console.Write("Ints Workload: " + w.Key); var res = await service.EchoIntArray(w.Value.ToList()); if (!w.Value.SequenceEqual(res)) throw new Exception("No match"); await Task.Delay(sampleDelayMs); (tx, rx, ctx, crx) = mon.GetDiff(tx, rx); Console.WriteLine($", {tx}/{rx}, {ctx}/{crx}"); //Console.WriteLine($"Socket {sock.BytesSent}/{sock.BytesReceived}"); rt.Ints.Add(w.Key, (ctx, crx)); } await Task.Delay(sampleDelayMs); (tx, rx) = mon.GetTotals(); Console.WriteLine($"Transfer {tx}/{rx}"); //Console.WriteLine($"Socket {sock.BytesSent}/{sock.BytesReceived}"); mon.Stop(); return rt; } }