Merge pull request #9998 from tomerv/main

Raise KeyError in Python ServiceDescriptor.FindMethodByName (#9592)
pull/10197/head
Theodore Rose 3 years ago committed by GitHub
commit f9ebb9ee36
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 9
      python/google/protobuf/descriptor.py
  2. 8
      python/google/protobuf/internal/descriptor_test.py

@ -873,11 +873,14 @@ class ServiceDescriptor(_NestedDescriptorBase):
Args:
name (str): Name of the method.
Returns:
MethodDescriptor or None: the descriptor for the requested method, if
found.
MethodDescriptor: The descriptor for the requested method.
Raises:
KeyError: if the method cannot be found in the service.
"""
return self.methods_by_name.get(name, None)
return self.methods_by_name[name]
def CopyToProto(self, proto):
"""Copies this to a descriptor_pb2.ServiceDescriptorProto.

@ -118,6 +118,14 @@ class DescriptorTest(unittest.TestCase):
def GetDescriptorPool(self):
return symbol_database.Default().pool
def testFindMethodByName(self):
service_descriptor = (unittest_custom_options_pb2.
TestServiceWithCustomOptions.DESCRIPTOR)
method_descriptor = service_descriptor.FindMethodByName('Foo')
self.assertEqual(method_descriptor.name, 'Foo')
with self.assertRaises(KeyError):
service_descriptor.FindMethodByName('MethodDoesNotExist')
def testEnumValueName(self):
self.assertEqual(self.my_message.EnumValueName('ForeignEnum', 4),
'FOREIGN_FOO')

Loading…
Cancel
Save