| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081 | // <auto-generated>//     Generated by the protocol buffer compiler.  DO NOT EDIT!//     source: src/proto/grpc/testing/test.proto// </auto-generated>// Original file comments:// Copyright 2015-2016 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.//// An integration test service that covers all the method signature permutations// of unary/streaming requests/responses.//#pragma warning disable 0414, 1591#region Designer generated codeusing grpc = global::Grpc.Core;namespace Grpc.Testing {  /// <summary>  /// A simple service to test the various types of RPCs and experiment with  /// performance with various types of payload.  /// </summary>  public static partial class TestService  {    static readonly string __ServiceName = "grpc.testing.TestService";    static readonly grpc::Marshaller<global::Grpc.Testing.Empty> __Marshaller_grpc_testing_Empty = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.Empty.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.SimpleRequest> __Marshaller_grpc_testing_SimpleRequest = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.SimpleRequest.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.SimpleResponse> __Marshaller_grpc_testing_SimpleResponse = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.SimpleResponse.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.StreamingOutputCallRequest> __Marshaller_grpc_testing_StreamingOutputCallRequest = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.StreamingOutputCallRequest.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.StreamingOutputCallResponse> __Marshaller_grpc_testing_StreamingOutputCallResponse = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.StreamingOutputCallResponse.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.StreamingInputCallRequest> __Marshaller_grpc_testing_StreamingInputCallRequest = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.StreamingInputCallRequest.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.StreamingInputCallResponse> __Marshaller_grpc_testing_StreamingInputCallResponse = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.StreamingInputCallResponse.Parser.ParseFrom);    static readonly grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty> __Method_EmptyCall = new grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(        grpc::MethodType.Unary,        __ServiceName,        "EmptyCall",        __Marshaller_grpc_testing_Empty,        __Marshaller_grpc_testing_Empty);    static readonly grpc::Method<global::Grpc.Testing.SimpleRequest, global::Grpc.Testing.SimpleResponse> __Method_UnaryCall = new grpc::Method<global::Grpc.Testing.SimpleRequest, global::Grpc.Testing.SimpleResponse>(        grpc::MethodType.Unary,        __ServiceName,        "UnaryCall",        __Marshaller_grpc_testing_SimpleRequest,        __Marshaller_grpc_testing_SimpleResponse);    static readonly grpc::Method<global::Grpc.Testing.SimpleRequest, global::Grpc.Testing.SimpleResponse> __Method_CacheableUnaryCall = new grpc::Method<global::Grpc.Testing.SimpleRequest, global::Grpc.Testing.SimpleResponse>(        grpc::MethodType.Unary,        __ServiceName,        "CacheableUnaryCall",        __Marshaller_grpc_testing_SimpleRequest,        __Marshaller_grpc_testing_SimpleResponse);    static readonly grpc::Method<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse> __Method_StreamingOutputCall = new grpc::Method<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse>(        grpc::MethodType.ServerStreaming,        __ServiceName,        "StreamingOutputCall",        __Marshaller_grpc_testing_StreamingOutputCallRequest,        __Marshaller_grpc_testing_StreamingOutputCallResponse);    static readonly grpc::Method<global::Grpc.Testing.StreamingInputCallRequest, global::Grpc.Testing.StreamingInputCallResponse> __Method_StreamingInputCall = new grpc::Method<global::Grpc.Testing.StreamingInputCallRequest, global::Grpc.Testing.StreamingInputCallResponse>(        grpc::MethodType.ClientStreaming,        __ServiceName,        "StreamingInputCall",        __Marshaller_grpc_testing_StreamingInputCallRequest,        __Marshaller_grpc_testing_StreamingInputCallResponse);    static readonly grpc::Method<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse> __Method_FullDuplexCall = new grpc::Method<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse>(        grpc::MethodType.DuplexStreaming,        __ServiceName,        "FullDuplexCall",        __Marshaller_grpc_testing_StreamingOutputCallRequest,        __Marshaller_grpc_testing_StreamingOutputCallResponse);    static readonly grpc::Method<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse> __Method_HalfDuplexCall = new grpc::Method<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse>(        grpc::MethodType.DuplexStreaming,        __ServiceName,        "HalfDuplexCall",        __Marshaller_grpc_testing_StreamingOutputCallRequest,        __Marshaller_grpc_testing_StreamingOutputCallResponse);    static readonly grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty> __Method_UnimplementedCall = new grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(        grpc::MethodType.Unary,        __ServiceName,        "UnimplementedCall",        __Marshaller_grpc_testing_Empty,        __Marshaller_grpc_testing_Empty);    /// <summary>Service descriptor</summary>    public static global::Google.Protobuf.Reflection.ServiceDescriptor Descriptor    {      get { return global::Grpc.Testing.TestReflection.Descriptor.Services[0]; }    }    /// <summary>Base class for server-side implementations of TestService</summary>    [grpc::BindServiceMethod(typeof(TestService), "BindService")]    public abstract partial class TestServiceBase    {      /// <summary>      /// One empty request followed by one empty response.      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.Empty> EmptyCall(global::Grpc.Testing.Empty request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// One request followed by one response.      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.SimpleResponse> UnaryCall(global::Grpc.Testing.SimpleRequest request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// One request followed by one response. Response has cache control      /// headers set such that a caching HTTP proxy (such as GFE) can      /// satisfy subsequent requests.      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.SimpleResponse> CacheableUnaryCall(global::Grpc.Testing.SimpleRequest request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// One request followed by a sequence of responses (streamed download).      /// The server returns the payload with client desired type and sizes.      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="responseStream">Used for sending responses back to the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>A task indicating completion of the handler.</returns>      public virtual global::System.Threading.Tasks.Task StreamingOutputCall(global::Grpc.Testing.StreamingOutputCallRequest request, grpc::IServerStreamWriter<global::Grpc.Testing.StreamingOutputCallResponse> responseStream, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// A sequence of requests followed by one response (streamed upload).      /// The server returns the aggregated size of client payload as the result.      /// </summary>      /// <param name="requestStream">Used for reading requests from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.StreamingInputCallResponse> StreamingInputCall(grpc::IAsyncStreamReader<global::Grpc.Testing.StreamingInputCallRequest> requestStream, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// A sequence of requests with each request served by the server immediately.      /// As one request could lead to multiple responses, this interface      /// demonstrates the idea of full duplexing.      /// </summary>      /// <param name="requestStream">Used for reading requests from the client.</param>      /// <param name="responseStream">Used for sending responses back to the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>A task indicating completion of the handler.</returns>      public virtual global::System.Threading.Tasks.Task FullDuplexCall(grpc::IAsyncStreamReader<global::Grpc.Testing.StreamingOutputCallRequest> requestStream, grpc::IServerStreamWriter<global::Grpc.Testing.StreamingOutputCallResponse> responseStream, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// A sequence of requests followed by a sequence of responses.      /// The server buffers all the client requests and then serves them in order. A      /// stream of responses are returned to the client when the server starts with      /// first request.      /// </summary>      /// <param name="requestStream">Used for reading requests from the client.</param>      /// <param name="responseStream">Used for sending responses back to the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>A task indicating completion of the handler.</returns>      public virtual global::System.Threading.Tasks.Task HalfDuplexCall(grpc::IAsyncStreamReader<global::Grpc.Testing.StreamingOutputCallRequest> requestStream, grpc::IServerStreamWriter<global::Grpc.Testing.StreamingOutputCallResponse> responseStream, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// The test server will not implement this method. It will be used      /// to test the behavior when clients call unimplemented methods.      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.Empty> UnimplementedCall(global::Grpc.Testing.Empty request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }    }    /// <summary>Client for TestService</summary>    public partial class TestServiceClient : grpc::ClientBase<TestServiceClient>    {      /// <summary>Creates a new client for TestService</summary>      /// <param name="channel">The channel to use to make remote calls.</param>      public TestServiceClient(grpc::ChannelBase channel) : base(channel)      {      }      /// <summary>Creates a new client for TestService that uses a custom <c>CallInvoker</c>.</summary>      /// <param name="callInvoker">The callInvoker to use to make remote calls.</param>      public TestServiceClient(grpc::CallInvoker callInvoker) : base(callInvoker)      {      }      /// <summary>Protected parameterless constructor to allow creation of test doubles.</summary>      protected TestServiceClient() : base()      {      }      /// <summary>Protected constructor to allow creation of configured clients.</summary>      /// <param name="configuration">The client configuration.</param>      protected TestServiceClient(ClientBaseConfiguration configuration) : base(configuration)      {      }      /// <summary>      /// One empty request followed by one empty response.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.Empty EmptyCall(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return EmptyCall(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// One empty request followed by one empty response.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.Empty EmptyCall(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_EmptyCall, null, options, request);      }      /// <summary>      /// One empty request followed by one empty response.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> EmptyCallAsync(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return EmptyCallAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// One empty request followed by one empty response.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> EmptyCallAsync(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_EmptyCall, null, options, request);      }      /// <summary>      /// One request followed by one response.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.SimpleResponse UnaryCall(global::Grpc.Testing.SimpleRequest request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return UnaryCall(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// One request followed by one response.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.SimpleResponse UnaryCall(global::Grpc.Testing.SimpleRequest request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_UnaryCall, null, options, request);      }      /// <summary>      /// One request followed by one response.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.SimpleResponse> UnaryCallAsync(global::Grpc.Testing.SimpleRequest request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return UnaryCallAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// One request followed by one response.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.SimpleResponse> UnaryCallAsync(global::Grpc.Testing.SimpleRequest request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_UnaryCall, null, options, request);      }      /// <summary>      /// One request followed by one response. Response has cache control      /// headers set such that a caching HTTP proxy (such as GFE) can      /// satisfy subsequent requests.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.SimpleResponse CacheableUnaryCall(global::Grpc.Testing.SimpleRequest request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return CacheableUnaryCall(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// One request followed by one response. Response has cache control      /// headers set such that a caching HTTP proxy (such as GFE) can      /// satisfy subsequent requests.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.SimpleResponse CacheableUnaryCall(global::Grpc.Testing.SimpleRequest request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_CacheableUnaryCall, null, options, request);      }      /// <summary>      /// One request followed by one response. Response has cache control      /// headers set such that a caching HTTP proxy (such as GFE) can      /// satisfy subsequent requests.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.SimpleResponse> CacheableUnaryCallAsync(global::Grpc.Testing.SimpleRequest request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return CacheableUnaryCallAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// One request followed by one response. Response has cache control      /// headers set such that a caching HTTP proxy (such as GFE) can      /// satisfy subsequent requests.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.SimpleResponse> CacheableUnaryCallAsync(global::Grpc.Testing.SimpleRequest request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_CacheableUnaryCall, null, options, request);      }      /// <summary>      /// One request followed by a sequence of responses (streamed download).      /// The server returns the payload with client desired type and sizes.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncServerStreamingCall<global::Grpc.Testing.StreamingOutputCallResponse> StreamingOutputCall(global::Grpc.Testing.StreamingOutputCallRequest request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return StreamingOutputCall(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// One request followed by a sequence of responses (streamed download).      /// The server returns the payload with client desired type and sizes.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncServerStreamingCall<global::Grpc.Testing.StreamingOutputCallResponse> StreamingOutputCall(global::Grpc.Testing.StreamingOutputCallRequest request, grpc::CallOptions options)      {        return CallInvoker.AsyncServerStreamingCall(__Method_StreamingOutputCall, null, options, request);      }      /// <summary>      /// A sequence of requests followed by one response (streamed upload).      /// The server returns the aggregated size of client payload as the result.      /// </summary>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncClientStreamingCall<global::Grpc.Testing.StreamingInputCallRequest, global::Grpc.Testing.StreamingInputCallResponse> StreamingInputCall(grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return StreamingInputCall(new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A sequence of requests followed by one response (streamed upload).      /// The server returns the aggregated size of client payload as the result.      /// </summary>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncClientStreamingCall<global::Grpc.Testing.StreamingInputCallRequest, global::Grpc.Testing.StreamingInputCallResponse> StreamingInputCall(grpc::CallOptions options)      {        return CallInvoker.AsyncClientStreamingCall(__Method_StreamingInputCall, null, options);      }      /// <summary>      /// A sequence of requests with each request served by the server immediately.      /// As one request could lead to multiple responses, this interface      /// demonstrates the idea of full duplexing.      /// </summary>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncDuplexStreamingCall<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse> FullDuplexCall(grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return FullDuplexCall(new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A sequence of requests with each request served by the server immediately.      /// As one request could lead to multiple responses, this interface      /// demonstrates the idea of full duplexing.      /// </summary>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncDuplexStreamingCall<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse> FullDuplexCall(grpc::CallOptions options)      {        return CallInvoker.AsyncDuplexStreamingCall(__Method_FullDuplexCall, null, options);      }      /// <summary>      /// A sequence of requests followed by a sequence of responses.      /// The server buffers all the client requests and then serves them in order. A      /// stream of responses are returned to the client when the server starts with      /// first request.      /// </summary>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncDuplexStreamingCall<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse> HalfDuplexCall(grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return HalfDuplexCall(new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A sequence of requests followed by a sequence of responses.      /// The server buffers all the client requests and then serves them in order. A      /// stream of responses are returned to the client when the server starts with      /// first request.      /// </summary>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncDuplexStreamingCall<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse> HalfDuplexCall(grpc::CallOptions options)      {        return CallInvoker.AsyncDuplexStreamingCall(__Method_HalfDuplexCall, null, options);      }      /// <summary>      /// The test server will not implement this method. It will be used      /// to test the behavior when clients call unimplemented methods.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.Empty UnimplementedCall(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return UnimplementedCall(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// The test server will not implement this method. It will be used      /// to test the behavior when clients call unimplemented methods.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.Empty UnimplementedCall(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_UnimplementedCall, null, options, request);      }      /// <summary>      /// The test server will not implement this method. It will be used      /// to test the behavior when clients call unimplemented methods.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> UnimplementedCallAsync(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return UnimplementedCallAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// The test server will not implement this method. It will be used      /// to test the behavior when clients call unimplemented methods.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> UnimplementedCallAsync(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_UnimplementedCall, null, options, request);      }      /// <summary>Creates a new instance of client from given <c>ClientBaseConfiguration</c>.</summary>      protected override TestServiceClient NewInstance(ClientBaseConfiguration configuration)      {        return new TestServiceClient(configuration);      }    }    /// <summary>Creates service definition that can be registered with a server</summary>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static grpc::ServerServiceDefinition BindService(TestServiceBase serviceImpl)    {      return grpc::ServerServiceDefinition.CreateBuilder()          .AddMethod(__Method_EmptyCall, serviceImpl.EmptyCall)          .AddMethod(__Method_UnaryCall, serviceImpl.UnaryCall)          .AddMethod(__Method_CacheableUnaryCall, serviceImpl.CacheableUnaryCall)          .AddMethod(__Method_StreamingOutputCall, serviceImpl.StreamingOutputCall)          .AddMethod(__Method_StreamingInputCall, serviceImpl.StreamingInputCall)          .AddMethod(__Method_FullDuplexCall, serviceImpl.FullDuplexCall)          .AddMethod(__Method_HalfDuplexCall, serviceImpl.HalfDuplexCall)          .AddMethod(__Method_UnimplementedCall, serviceImpl.UnimplementedCall).Build();    }    /// <summary>Register service method with a service binder with or without implementation. Useful when customizing the  service binding logic.    /// Note: this method is part of an experimental API that can change or be removed without any prior notice.</summary>    /// <param name="serviceBinder">Service methods will be bound by calling <c>AddMethod</c> on this object.</param>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static void BindService(grpc::ServiceBinderBase serviceBinder, TestServiceBase serviceImpl)    {      serviceBinder.AddMethod(__Method_EmptyCall, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(serviceImpl.EmptyCall));      serviceBinder.AddMethod(__Method_UnaryCall, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.SimpleRequest, global::Grpc.Testing.SimpleResponse>(serviceImpl.UnaryCall));      serviceBinder.AddMethod(__Method_CacheableUnaryCall, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.SimpleRequest, global::Grpc.Testing.SimpleResponse>(serviceImpl.CacheableUnaryCall));      serviceBinder.AddMethod(__Method_StreamingOutputCall, serviceImpl == null ? null : new grpc::ServerStreamingServerMethod<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse>(serviceImpl.StreamingOutputCall));      serviceBinder.AddMethod(__Method_StreamingInputCall, serviceImpl == null ? null : new grpc::ClientStreamingServerMethod<global::Grpc.Testing.StreamingInputCallRequest, global::Grpc.Testing.StreamingInputCallResponse>(serviceImpl.StreamingInputCall));      serviceBinder.AddMethod(__Method_FullDuplexCall, serviceImpl == null ? null : new grpc::DuplexStreamingServerMethod<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse>(serviceImpl.FullDuplexCall));      serviceBinder.AddMethod(__Method_HalfDuplexCall, serviceImpl == null ? null : new grpc::DuplexStreamingServerMethod<global::Grpc.Testing.StreamingOutputCallRequest, global::Grpc.Testing.StreamingOutputCallResponse>(serviceImpl.HalfDuplexCall));      serviceBinder.AddMethod(__Method_UnimplementedCall, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(serviceImpl.UnimplementedCall));    }  }  /// <summary>  /// A simple service NOT implemented at servers so clients can test for  /// that case.  /// </summary>  public static partial class UnimplementedService  {    static readonly string __ServiceName = "grpc.testing.UnimplementedService";    static readonly grpc::Marshaller<global::Grpc.Testing.Empty> __Marshaller_grpc_testing_Empty = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.Empty.Parser.ParseFrom);    static readonly grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty> __Method_UnimplementedCall = new grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(        grpc::MethodType.Unary,        __ServiceName,        "UnimplementedCall",        __Marshaller_grpc_testing_Empty,        __Marshaller_grpc_testing_Empty);    /// <summary>Service descriptor</summary>    public static global::Google.Protobuf.Reflection.ServiceDescriptor Descriptor    {      get { return global::Grpc.Testing.TestReflection.Descriptor.Services[1]; }    }    /// <summary>Base class for server-side implementations of UnimplementedService</summary>    [grpc::BindServiceMethod(typeof(UnimplementedService), "BindService")]    public abstract partial class UnimplementedServiceBase    {      /// <summary>      /// A call that no server should implement      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.Empty> UnimplementedCall(global::Grpc.Testing.Empty request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }    }    /// <summary>Client for UnimplementedService</summary>    public partial class UnimplementedServiceClient : grpc::ClientBase<UnimplementedServiceClient>    {      /// <summary>Creates a new client for UnimplementedService</summary>      /// <param name="channel">The channel to use to make remote calls.</param>      public UnimplementedServiceClient(grpc::ChannelBase channel) : base(channel)      {      }      /// <summary>Creates a new client for UnimplementedService that uses a custom <c>CallInvoker</c>.</summary>      /// <param name="callInvoker">The callInvoker to use to make remote calls.</param>      public UnimplementedServiceClient(grpc::CallInvoker callInvoker) : base(callInvoker)      {      }      /// <summary>Protected parameterless constructor to allow creation of test doubles.</summary>      protected UnimplementedServiceClient() : base()      {      }      /// <summary>Protected constructor to allow creation of configured clients.</summary>      /// <param name="configuration">The client configuration.</param>      protected UnimplementedServiceClient(ClientBaseConfiguration configuration) : base(configuration)      {      }      /// <summary>      /// A call that no server should implement      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.Empty UnimplementedCall(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return UnimplementedCall(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A call that no server should implement      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.Empty UnimplementedCall(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_UnimplementedCall, null, options, request);      }      /// <summary>      /// A call that no server should implement      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> UnimplementedCallAsync(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return UnimplementedCallAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A call that no server should implement      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> UnimplementedCallAsync(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_UnimplementedCall, null, options, request);      }      /// <summary>Creates a new instance of client from given <c>ClientBaseConfiguration</c>.</summary>      protected override UnimplementedServiceClient NewInstance(ClientBaseConfiguration configuration)      {        return new UnimplementedServiceClient(configuration);      }    }    /// <summary>Creates service definition that can be registered with a server</summary>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static grpc::ServerServiceDefinition BindService(UnimplementedServiceBase serviceImpl)    {      return grpc::ServerServiceDefinition.CreateBuilder()          .AddMethod(__Method_UnimplementedCall, serviceImpl.UnimplementedCall).Build();    }    /// <summary>Register service method with a service binder with or without implementation. Useful when customizing the  service binding logic.    /// Note: this method is part of an experimental API that can change or be removed without any prior notice.</summary>    /// <param name="serviceBinder">Service methods will be bound by calling <c>AddMethod</c> on this object.</param>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static void BindService(grpc::ServiceBinderBase serviceBinder, UnimplementedServiceBase serviceImpl)    {      serviceBinder.AddMethod(__Method_UnimplementedCall, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(serviceImpl.UnimplementedCall));    }  }  /// <summary>  /// A service used to control reconnect server.  /// </summary>  public static partial class ReconnectService  {    static readonly string __ServiceName = "grpc.testing.ReconnectService";    static readonly grpc::Marshaller<global::Grpc.Testing.ReconnectParams> __Marshaller_grpc_testing_ReconnectParams = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.ReconnectParams.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.Empty> __Marshaller_grpc_testing_Empty = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.Empty.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.ReconnectInfo> __Marshaller_grpc_testing_ReconnectInfo = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.ReconnectInfo.Parser.ParseFrom);    static readonly grpc::Method<global::Grpc.Testing.ReconnectParams, global::Grpc.Testing.Empty> __Method_Start = new grpc::Method<global::Grpc.Testing.ReconnectParams, global::Grpc.Testing.Empty>(        grpc::MethodType.Unary,        __ServiceName,        "Start",        __Marshaller_grpc_testing_ReconnectParams,        __Marshaller_grpc_testing_Empty);    static readonly grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.ReconnectInfo> __Method_Stop = new grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.ReconnectInfo>(        grpc::MethodType.Unary,        __ServiceName,        "Stop",        __Marshaller_grpc_testing_Empty,        __Marshaller_grpc_testing_ReconnectInfo);    /// <summary>Service descriptor</summary>    public static global::Google.Protobuf.Reflection.ServiceDescriptor Descriptor    {      get { return global::Grpc.Testing.TestReflection.Descriptor.Services[2]; }    }    /// <summary>Base class for server-side implementations of ReconnectService</summary>    [grpc::BindServiceMethod(typeof(ReconnectService), "BindService")]    public abstract partial class ReconnectServiceBase    {      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.Empty> Start(global::Grpc.Testing.ReconnectParams request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.ReconnectInfo> Stop(global::Grpc.Testing.Empty request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }    }    /// <summary>Client for ReconnectService</summary>    public partial class ReconnectServiceClient : grpc::ClientBase<ReconnectServiceClient>    {      /// <summary>Creates a new client for ReconnectService</summary>      /// <param name="channel">The channel to use to make remote calls.</param>      public ReconnectServiceClient(grpc::ChannelBase channel) : base(channel)      {      }      /// <summary>Creates a new client for ReconnectService that uses a custom <c>CallInvoker</c>.</summary>      /// <param name="callInvoker">The callInvoker to use to make remote calls.</param>      public ReconnectServiceClient(grpc::CallInvoker callInvoker) : base(callInvoker)      {      }      /// <summary>Protected parameterless constructor to allow creation of test doubles.</summary>      protected ReconnectServiceClient() : base()      {      }      /// <summary>Protected constructor to allow creation of configured clients.</summary>      /// <param name="configuration">The client configuration.</param>      protected ReconnectServiceClient(ClientBaseConfiguration configuration) : base(configuration)      {      }      public virtual global::Grpc.Testing.Empty Start(global::Grpc.Testing.ReconnectParams request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return Start(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      public virtual global::Grpc.Testing.Empty Start(global::Grpc.Testing.ReconnectParams request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_Start, null, options, request);      }      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> StartAsync(global::Grpc.Testing.ReconnectParams request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return StartAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> StartAsync(global::Grpc.Testing.ReconnectParams request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_Start, null, options, request);      }      public virtual global::Grpc.Testing.ReconnectInfo Stop(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return Stop(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      public virtual global::Grpc.Testing.ReconnectInfo Stop(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_Stop, null, options, request);      }      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.ReconnectInfo> StopAsync(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return StopAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.ReconnectInfo> StopAsync(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_Stop, null, options, request);      }      /// <summary>Creates a new instance of client from given <c>ClientBaseConfiguration</c>.</summary>      protected override ReconnectServiceClient NewInstance(ClientBaseConfiguration configuration)      {        return new ReconnectServiceClient(configuration);      }    }    /// <summary>Creates service definition that can be registered with a server</summary>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static grpc::ServerServiceDefinition BindService(ReconnectServiceBase serviceImpl)    {      return grpc::ServerServiceDefinition.CreateBuilder()          .AddMethod(__Method_Start, serviceImpl.Start)          .AddMethod(__Method_Stop, serviceImpl.Stop).Build();    }    /// <summary>Register service method with a service binder with or without implementation. Useful when customizing the  service binding logic.    /// Note: this method is part of an experimental API that can change or be removed without any prior notice.</summary>    /// <param name="serviceBinder">Service methods will be bound by calling <c>AddMethod</c> on this object.</param>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static void BindService(grpc::ServiceBinderBase serviceBinder, ReconnectServiceBase serviceImpl)    {      serviceBinder.AddMethod(__Method_Start, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.ReconnectParams, global::Grpc.Testing.Empty>(serviceImpl.Start));      serviceBinder.AddMethod(__Method_Stop, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.Empty, global::Grpc.Testing.ReconnectInfo>(serviceImpl.Stop));    }  }  /// <summary>  /// A service used to obtain stats for verifying LB behavior.  /// </summary>  public static partial class LoadBalancerStatsService  {    static readonly string __ServiceName = "grpc.testing.LoadBalancerStatsService";    static readonly grpc::Marshaller<global::Grpc.Testing.LoadBalancerStatsRequest> __Marshaller_grpc_testing_LoadBalancerStatsRequest = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.LoadBalancerStatsRequest.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Grpc.Testing.LoadBalancerStatsResponse> __Marshaller_grpc_testing_LoadBalancerStatsResponse = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.LoadBalancerStatsResponse.Parser.ParseFrom);    static readonly grpc::Method<global::Grpc.Testing.LoadBalancerStatsRequest, global::Grpc.Testing.LoadBalancerStatsResponse> __Method_GetClientStats = new grpc::Method<global::Grpc.Testing.LoadBalancerStatsRequest, global::Grpc.Testing.LoadBalancerStatsResponse>(        grpc::MethodType.Unary,        __ServiceName,        "GetClientStats",        __Marshaller_grpc_testing_LoadBalancerStatsRequest,        __Marshaller_grpc_testing_LoadBalancerStatsResponse);    /// <summary>Service descriptor</summary>    public static global::Google.Protobuf.Reflection.ServiceDescriptor Descriptor    {      get { return global::Grpc.Testing.TestReflection.Descriptor.Services[3]; }    }    /// <summary>Base class for server-side implementations of LoadBalancerStatsService</summary>    [grpc::BindServiceMethod(typeof(LoadBalancerStatsService), "BindService")]    public abstract partial class LoadBalancerStatsServiceBase    {      /// <summary>      /// Gets the backend distribution for RPCs sent by a test client.      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.LoadBalancerStatsResponse> GetClientStats(global::Grpc.Testing.LoadBalancerStatsRequest request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }    }    /// <summary>Client for LoadBalancerStatsService</summary>    public partial class LoadBalancerStatsServiceClient : grpc::ClientBase<LoadBalancerStatsServiceClient>    {      /// <summary>Creates a new client for LoadBalancerStatsService</summary>      /// <param name="channel">The channel to use to make remote calls.</param>      public LoadBalancerStatsServiceClient(grpc::ChannelBase channel) : base(channel)      {      }      /// <summary>Creates a new client for LoadBalancerStatsService that uses a custom <c>CallInvoker</c>.</summary>      /// <param name="callInvoker">The callInvoker to use to make remote calls.</param>      public LoadBalancerStatsServiceClient(grpc::CallInvoker callInvoker) : base(callInvoker)      {      }      /// <summary>Protected parameterless constructor to allow creation of test doubles.</summary>      protected LoadBalancerStatsServiceClient() : base()      {      }      /// <summary>Protected constructor to allow creation of configured clients.</summary>      /// <param name="configuration">The client configuration.</param>      protected LoadBalancerStatsServiceClient(ClientBaseConfiguration configuration) : base(configuration)      {      }      /// <summary>      /// Gets the backend distribution for RPCs sent by a test client.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.LoadBalancerStatsResponse GetClientStats(global::Grpc.Testing.LoadBalancerStatsRequest request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return GetClientStats(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// Gets the backend distribution for RPCs sent by a test client.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Grpc.Testing.LoadBalancerStatsResponse GetClientStats(global::Grpc.Testing.LoadBalancerStatsRequest request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_GetClientStats, null, options, request);      }      /// <summary>      /// Gets the backend distribution for RPCs sent by a test client.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.LoadBalancerStatsResponse> GetClientStatsAsync(global::Grpc.Testing.LoadBalancerStatsRequest request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return GetClientStatsAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// Gets the backend distribution for RPCs sent by a test client.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.LoadBalancerStatsResponse> GetClientStatsAsync(global::Grpc.Testing.LoadBalancerStatsRequest request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_GetClientStats, null, options, request);      }      /// <summary>Creates a new instance of client from given <c>ClientBaseConfiguration</c>.</summary>      protected override LoadBalancerStatsServiceClient NewInstance(ClientBaseConfiguration configuration)      {        return new LoadBalancerStatsServiceClient(configuration);      }    }    /// <summary>Creates service definition that can be registered with a server</summary>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static grpc::ServerServiceDefinition BindService(LoadBalancerStatsServiceBase serviceImpl)    {      return grpc::ServerServiceDefinition.CreateBuilder()          .AddMethod(__Method_GetClientStats, serviceImpl.GetClientStats).Build();    }    /// <summary>Register service method with a service binder with or without implementation. Useful when customizing the  service binding logic.    /// Note: this method is part of an experimental API that can change or be removed without any prior notice.</summary>    /// <param name="serviceBinder">Service methods will be bound by calling <c>AddMethod</c> on this object.</param>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static void BindService(grpc::ServiceBinderBase serviceBinder, LoadBalancerStatsServiceBase serviceImpl)    {      serviceBinder.AddMethod(__Method_GetClientStats, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.LoadBalancerStatsRequest, global::Grpc.Testing.LoadBalancerStatsResponse>(serviceImpl.GetClientStats));    }  }  /// <summary>  /// A service to remotely control health status of an xDS test server.  /// </summary>  public static partial class XdsUpdateHealthService  {    static readonly string __ServiceName = "grpc.testing.XdsUpdateHealthService";    static readonly grpc::Marshaller<global::Grpc.Testing.Empty> __Marshaller_grpc_testing_Empty = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Grpc.Testing.Empty.Parser.ParseFrom);    static readonly grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty> __Method_SetServing = new grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(        grpc::MethodType.Unary,        __ServiceName,        "SetServing",        __Marshaller_grpc_testing_Empty,        __Marshaller_grpc_testing_Empty);    static readonly grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty> __Method_SetNotServing = new grpc::Method<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(        grpc::MethodType.Unary,        __ServiceName,        "SetNotServing",        __Marshaller_grpc_testing_Empty,        __Marshaller_grpc_testing_Empty);    /// <summary>Service descriptor</summary>    public static global::Google.Protobuf.Reflection.ServiceDescriptor Descriptor    {      get { return global::Grpc.Testing.TestReflection.Descriptor.Services[4]; }    }    /// <summary>Base class for server-side implementations of XdsUpdateHealthService</summary>    [grpc::BindServiceMethod(typeof(XdsUpdateHealthService), "BindService")]    public abstract partial class XdsUpdateHealthServiceBase    {      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.Empty> SetServing(global::Grpc.Testing.Empty request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      public virtual global::System.Threading.Tasks.Task<global::Grpc.Testing.Empty> SetNotServing(global::Grpc.Testing.Empty request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }    }    /// <summary>Client for XdsUpdateHealthService</summary>    public partial class XdsUpdateHealthServiceClient : grpc::ClientBase<XdsUpdateHealthServiceClient>    {      /// <summary>Creates a new client for XdsUpdateHealthService</summary>      /// <param name="channel">The channel to use to make remote calls.</param>      public XdsUpdateHealthServiceClient(grpc::ChannelBase channel) : base(channel)      {      }      /// <summary>Creates a new client for XdsUpdateHealthService that uses a custom <c>CallInvoker</c>.</summary>      /// <param name="callInvoker">The callInvoker to use to make remote calls.</param>      public XdsUpdateHealthServiceClient(grpc::CallInvoker callInvoker) : base(callInvoker)      {      }      /// <summary>Protected parameterless constructor to allow creation of test doubles.</summary>      protected XdsUpdateHealthServiceClient() : base()      {      }      /// <summary>Protected constructor to allow creation of configured clients.</summary>      /// <param name="configuration">The client configuration.</param>      protected XdsUpdateHealthServiceClient(ClientBaseConfiguration configuration) : base(configuration)      {      }      public virtual global::Grpc.Testing.Empty SetServing(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return SetServing(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      public virtual global::Grpc.Testing.Empty SetServing(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_SetServing, null, options, request);      }      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> SetServingAsync(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return SetServingAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> SetServingAsync(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_SetServing, null, options, request);      }      public virtual global::Grpc.Testing.Empty SetNotServing(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return SetNotServing(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      public virtual global::Grpc.Testing.Empty SetNotServing(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_SetNotServing, null, options, request);      }      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> SetNotServingAsync(global::Grpc.Testing.Empty request, grpc::Metadata headers = null, global::System.DateTime? deadline = null, global::System.Threading.CancellationToken cancellationToken = default(global::System.Threading.CancellationToken))      {        return SetNotServingAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      public virtual grpc::AsyncUnaryCall<global::Grpc.Testing.Empty> SetNotServingAsync(global::Grpc.Testing.Empty request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_SetNotServing, null, options, request);      }      /// <summary>Creates a new instance of client from given <c>ClientBaseConfiguration</c>.</summary>      protected override XdsUpdateHealthServiceClient NewInstance(ClientBaseConfiguration configuration)      {        return new XdsUpdateHealthServiceClient(configuration);      }    }    /// <summary>Creates service definition that can be registered with a server</summary>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static grpc::ServerServiceDefinition BindService(XdsUpdateHealthServiceBase serviceImpl)    {      return grpc::ServerServiceDefinition.CreateBuilder()          .AddMethod(__Method_SetServing, serviceImpl.SetServing)          .AddMethod(__Method_SetNotServing, serviceImpl.SetNotServing).Build();    }    /// <summary>Register service method with a service binder with or without implementation. Useful when customizing the  service binding logic.    /// Note: this method is part of an experimental API that can change or be removed without any prior notice.</summary>    /// <param name="serviceBinder">Service methods will be bound by calling <c>AddMethod</c> on this object.</param>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static void BindService(grpc::ServiceBinderBase serviceBinder, XdsUpdateHealthServiceBase serviceImpl)    {      serviceBinder.AddMethod(__Method_SetServing, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(serviceImpl.SetServing));      serviceBinder.AddMethod(__Method_SetNotServing, serviceImpl == null ? null : new grpc::UnaryServerMethod<global::Grpc.Testing.Empty, global::Grpc.Testing.Empty>(serviceImpl.SetNotServing));    }  }}#endregion
 |