| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819 | // <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>    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::Channel 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>    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::Channel 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>    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::Channel 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));    }  }}#endregion
 |