| 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 code
 
- using 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
 
 
  |