| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 | 
							- # Copyright 2019 The 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.
 
- """This example handles rich error status in client-side."""
 
- from __future__ import print_function
 
- import logging
 
- import grpc
 
- from grpc_status import rpc_status
 
- from google.rpc import error_details_pb2
 
- from examples.protos import helloworld_pb2
 
- from examples.protos import helloworld_pb2_grpc
 
- _LOGGER = logging.getLogger(__name__)
 
- def process(stub):
 
-     try:
 
-         response = stub.SayHello(helloworld_pb2.HelloRequest(name='Alice'))
 
-         _LOGGER.info('Call success: %s', response.message)
 
-     except grpc.RpcError as rpc_error:
 
-         _LOGGER.error('Call failure: %s', rpc_error)
 
-         status = rpc_status.from_call(rpc_error)
 
-         for detail in status.details:
 
-             if detail.Is(error_details_pb2.QuotaFailure.DESCRIPTOR):
 
-                 info = error_details_pb2.QuotaFailure()
 
-                 detail.Unpack(info)
 
-                 _LOGGER.error('Quota failure: %s', info)
 
-             else:
 
-                 raise RuntimeError('Unexpected failure: %s' % detail)
 
- def main():
 
-     # NOTE(gRPC Python Team): .close() is possible on a channel and should be
 
-     # used in circumstances in which the with statement does not fit the needs
 
-     # of the code.
 
-     with grpc.insecure_channel('localhost:50051') as channel:
 
-         stub = helloworld_pb2_grpc.GreeterStub(channel)
 
-         process(stub)
 
- if __name__ == '__main__':
 
-     logging.basicConfig()
 
-     main()
 
 
  |