Пример #1
0
 def start_batch(self, ops, tag):
     translated_ops = []
     for op in ops:
         if op.type == _types.OpType.SEND_INITIAL_METADATA:
             translated_op = cygrpc.operation_send_initial_metadata(
                 cygrpc.Metadata(
                     cygrpc.Metadatum(key, value)
                     for key, value in op.initial_metadata))
         elif op.type == _types.OpType.SEND_MESSAGE:
             translated_op = cygrpc.operation_send_message(op.message)
         elif op.type == _types.OpType.SEND_CLOSE_FROM_CLIENT:
             translated_op = cygrpc.operation_send_close_from_client()
         elif op.type == _types.OpType.SEND_STATUS_FROM_SERVER:
             translated_op = cygrpc.operation_send_status_from_server(
                 cygrpc.Metadata(
                     cygrpc.Metadatum(key, value)
                     for key, value in op.trailing_metadata),
                 op.status.code, op.status.details)
         elif op.type == _types.OpType.RECV_INITIAL_METADATA:
             translated_op = cygrpc.operation_receive_initial_metadata()
         elif op.type == _types.OpType.RECV_MESSAGE:
             translated_op = cygrpc.operation_receive_message()
         elif op.type == _types.OpType.RECV_STATUS_ON_CLIENT:
             translated_op = cygrpc.operation_receive_status_on_client()
         elif op.type == _types.OpType.RECV_CLOSE_ON_SERVER:
             translated_op = cygrpc.operation_receive_close_on_server()
         else:
             raise ValueError('unexpected operation type {}'.format(
                 op.type))
         translated_ops.append(translated_op)
     return self.call.start_batch(cygrpc.Operations(translated_ops), tag)
Пример #2
0
 def testMetadataIteration(self):
     metadata = cygrpc.Metadata(
         [cygrpc.Metadatum(b'a', b'b'), cygrpc.Metadatum(b'c', b'd')])
     iterator = iter(metadata)
     metadatum = next(iterator)
     self.assertIsInstance(metadatum, cygrpc.Metadatum)
     self.assertEqual(metadatum.key, b'a')
     self.assertEqual(metadatum.value, b'b')
     metadatum = next(iterator)
     self.assertIsInstance(metadatum, cygrpc.Metadatum)
     self.assertEqual(metadatum.key, b'c')
     self.assertEqual(metadatum.value, b'd')
     with self.assertRaises(StopIteration):
         next(iterator)
Пример #3
0
 def testMetadataIteration(self):
   metadata = cygrpc.Metadata([
       cygrpc.Metadatum('a', 'b'), cygrpc.Metadatum('c', 'd')])
   iterator = iter(metadata)
   metadatum = next(iterator)
   self.assertIsInstance(metadatum, cygrpc.Metadatum)
   self.assertEqual(metadatum.key, 'a'.encode())
   self.assertEqual(metadatum.value, 'b'.encode())
   metadatum = next(iterator)
   self.assertIsInstance(metadatum, cygrpc.Metadatum)
   self.assertEqual(metadatum.key, 'c'.encode())
   self.assertEqual(metadatum.value, 'd'.encode())
   with self.assertRaises(StopIteration):
     next(iterator)
Пример #4
0
 def testStringsInUtilitiesUpDown(self):
     self.assertEqual(0, cygrpc.StatusCode.ok)
     metadatum = cygrpc.Metadatum(b'a', b'b')
     self.assertEqual(b'a', metadatum.key)
     self.assertEqual(b'b', metadatum.value)
     metadata = cygrpc.Metadata([metadatum])
     self.assertEqual(1, len(metadata))
     self.assertEqual(metadatum.key, metadata[0].key)
Пример #5
0
 def _invoke_success(self, metadata):
     try:
         cygrpc_metadata = cygrpc.Metadata(
             cygrpc.Metadatum(key, value) for key, value in metadata)
     except Exception as error:
         self._invoke_failure(error)
         return
     self.cygrpc_callback(cygrpc_metadata, cygrpc.StatusCode.ok, '')
Пример #6
0
def cygrpc_metadata(application_metadata):
    return _EMPTY_METADATA if application_metadata is None else cygrpc.Metadata(
        cygrpc.Metadatum(encode(key), encode(value))
        for key, value in application_metadata)
Пример #7
0
def _metadata_plugin_callback(context, callback):
    callback(
        cygrpc.Metadata([
            cygrpc.Metadatum(_CALL_CREDENTIALS_METADATA_KEY,
                             _CALL_CREDENTIALS_METADATA_VALUE)
        ]), cygrpc.StatusCode.ok, b'')
Пример #8
0
    def testEcho(self):
        DEADLINE = time.time() + 5
        DEADLINE_TOLERANCE = 0.25
        CLIENT_METADATA_ASCII_KEY = b'key'
        CLIENT_METADATA_ASCII_VALUE = b'val'
        CLIENT_METADATA_BIN_KEY = b'key-bin'
        CLIENT_METADATA_BIN_VALUE = b'\0' * 1000
        SERVER_INITIAL_METADATA_KEY = b'init_me_me_me'
        SERVER_INITIAL_METADATA_VALUE = b'whodawha?'
        SERVER_TRAILING_METADATA_KEY = b'california_is_in_a_drought'
        SERVER_TRAILING_METADATA_VALUE = b'zomg it is'
        SERVER_STATUS_CODE = cygrpc.StatusCode.ok
        SERVER_STATUS_DETAILS = b'our work is never over'
        REQUEST = b'in death a member of project mayhem has a name'
        RESPONSE = b'his name is robert paulson'
        METHOD = b'twinkies'

        cygrpc_deadline = cygrpc.Timespec(DEADLINE)

        server_request_tag = object()
        request_call_result = self.server.request_call(
            self.server_completion_queue, self.server_completion_queue,
            server_request_tag)

        self.assertEqual(cygrpc.CallError.ok, request_call_result)

        client_call_tag = object()
        client_call = self.client_channel.create_call(
            None, 0, self.client_completion_queue, METHOD, self.host_argument,
            cygrpc_deadline)
        client_initial_metadata = cygrpc.Metadata([
            cygrpc.Metadatum(CLIENT_METADATA_ASCII_KEY,
                             CLIENT_METADATA_ASCII_VALUE),
            cygrpc.Metadatum(CLIENT_METADATA_BIN_KEY, CLIENT_METADATA_BIN_VALUE)
        ])
        client_start_batch_result = client_call.start_client_batch([
            cygrpc.operation_send_initial_metadata(client_initial_metadata,
                                                   _EMPTY_FLAGS),
            cygrpc.operation_send_message(REQUEST, _EMPTY_FLAGS),
            cygrpc.operation_send_close_from_client(_EMPTY_FLAGS),
            cygrpc.operation_receive_initial_metadata(_EMPTY_FLAGS),
            cygrpc.operation_receive_message(_EMPTY_FLAGS),
            cygrpc.operation_receive_status_on_client(_EMPTY_FLAGS)
        ], client_call_tag)
        self.assertEqual(cygrpc.CallError.ok, client_start_batch_result)
        client_event_future = test_utilities.CompletionQueuePollFuture(
            self.client_completion_queue, cygrpc_deadline)

        request_event = self.server_completion_queue.poll(cygrpc_deadline)
        self.assertEqual(cygrpc.CompletionType.operation_complete,
                         request_event.type)
        self.assertIsInstance(request_event.operation_call, cygrpc.Call)
        self.assertIs(server_request_tag, request_event.tag)
        self.assertEqual(0, len(request_event.batch_operations))
        self.assertTrue(
            test_common.metadata_transmitted(client_initial_metadata,
                                             request_event.request_metadata))
        self.assertEqual(METHOD, request_event.request_call_details.method)
        self.assertEqual(self.expected_host,
                         request_event.request_call_details.host)
        self.assertLess(
            abs(DEADLINE - float(request_event.request_call_details.deadline)),
            DEADLINE_TOLERANCE)

        server_call_tag = object()
        server_call = request_event.operation_call
        server_initial_metadata = cygrpc.Metadata([
            cygrpc.Metadatum(SERVER_INITIAL_METADATA_KEY,
                             SERVER_INITIAL_METADATA_VALUE)
        ])
        server_trailing_metadata = cygrpc.Metadata([
            cygrpc.Metadatum(SERVER_TRAILING_METADATA_KEY,
                             SERVER_TRAILING_METADATA_VALUE)
        ])
        server_start_batch_result = server_call.start_server_batch([
            cygrpc.operation_send_initial_metadata(
                server_initial_metadata,
                _EMPTY_FLAGS), cygrpc.operation_receive_message(_EMPTY_FLAGS),
            cygrpc.operation_send_message(RESPONSE, _EMPTY_FLAGS),
            cygrpc.operation_receive_close_on_server(_EMPTY_FLAGS),
            cygrpc.operation_send_status_from_server(
                server_trailing_metadata, SERVER_STATUS_CODE,
                SERVER_STATUS_DETAILS, _EMPTY_FLAGS)
        ], server_call_tag)
        self.assertEqual(cygrpc.CallError.ok, server_start_batch_result)

        server_event = self.server_completion_queue.poll(cygrpc_deadline)
        client_event = client_event_future.result()

        self.assertEqual(6, len(client_event.batch_operations))
        found_client_op_types = set()
        for client_result in client_event.batch_operations:
            # we expect each op type to be unique
            self.assertNotIn(client_result.type, found_client_op_types)
            found_client_op_types.add(client_result.type)
            if client_result.type == cygrpc.OperationType.receive_initial_metadata:
                self.assertTrue(
                    test_common.metadata_transmitted(
                        server_initial_metadata,
                        client_result.received_metadata))
            elif client_result.type == cygrpc.OperationType.receive_message:
                self.assertEqual(RESPONSE,
                                 client_result.received_message.bytes())
            elif client_result.type == cygrpc.OperationType.receive_status_on_client:
                self.assertTrue(
                    test_common.metadata_transmitted(
                        server_trailing_metadata,
                        client_result.received_metadata))
                self.assertEqual(SERVER_STATUS_DETAILS,
                                 client_result.received_status_details)
                self.assertEqual(SERVER_STATUS_CODE,
                                 client_result.received_status_code)
        self.assertEqual(
            set([
                cygrpc.OperationType.send_initial_metadata,
                cygrpc.OperationType.send_message,
                cygrpc.OperationType.send_close_from_client,
                cygrpc.OperationType.receive_initial_metadata,
                cygrpc.OperationType.receive_message,
                cygrpc.OperationType.receive_status_on_client
            ]), found_client_op_types)

        self.assertEqual(5, len(server_event.batch_operations))
        found_server_op_types = set()
        for server_result in server_event.batch_operations:
            self.assertNotIn(client_result.type, found_server_op_types)
            found_server_op_types.add(server_result.type)
            if server_result.type == cygrpc.OperationType.receive_message:
                self.assertEqual(REQUEST,
                                 server_result.received_message.bytes())
            elif server_result.type == cygrpc.OperationType.receive_close_on_server:
                self.assertFalse(server_result.received_cancelled)
        self.assertEqual(
            set([
                cygrpc.OperationType.send_initial_metadata,
                cygrpc.OperationType.receive_message,
                cygrpc.OperationType.send_message,
                cygrpc.OperationType.receive_close_on_server,
                cygrpc.OperationType.send_status_from_server
            ]), found_server_op_types)

        del client_call
        del server_call
Пример #9
0
def metadata(application_metadata):
    return _EMPTY_METADATA if application_metadata is None else cygrpc.Metadata(
        cygrpc.Metadatum(key, value) for key, value in application_metadata)
Пример #10
0
# See the License for the specific language governing permissions and
# limitations under the License.
"""Common utilities for tests of the Cython layer of gRPC Python."""

import collections
import threading

from grpc._cython import cygrpc

RPC_COUNT = 4000

INFINITE_FUTURE = cygrpc.Timespec(float('+inf'))
EMPTY_FLAGS = 0

INVOCATION_METADATA = cygrpc.Metadata((
    cygrpc.Metadatum(b'client-md-key', b'client-md-key'),
    cygrpc.Metadatum(b'client-md-key-bin', b'\x00\x01' * 3000),
))

INITIAL_METADATA = cygrpc.Metadata((
    cygrpc.Metadatum(b'server-initial-md-key', b'server-initial-md-value'),
    cygrpc.Metadatum(b'server-initial-md-key-bin', b'\x00\x02' * 3000),
))

TRAILING_METADATA = cygrpc.Metadata((
    cygrpc.Metadatum(b'server-trailing-md-key', b'server-trailing-md-value'),
    cygrpc.Metadatum(b'server-trailing-md-key-bin', b'\x00\x03' * 3000),
))


class QueueDriver(object):