def test_batch_write_spans_field_headers(): client = TraceServiceClient( credentials=credentials.AnonymousCredentials(), ) # Any value that is part of the HTTP/1.1 URI should be sent as # a field header. Set these to a non-empty value. request = tracing.BatchWriteSpansRequest() request.name = "name/value" # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client._transport.batch_write_spans), "__call__") as call: call.return_value = None client.batch_write_spans(request) # Establish that the underlying gRPC stub method was called. assert len(call.mock_calls) == 1 _, args, _ = call.mock_calls[0] assert args[0] == request # Establish that the field header was sent. _, _, kw = call.mock_calls[0] assert ( "x-goog-request-params", "name=name/value", ) in kw["metadata"]
def test_batch_write_spans_flattened(): client = TraceServiceClient( credentials=credentials.AnonymousCredentials(), ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client._transport.batch_write_spans), "__call__") as call: # Designate an appropriate return value for the call. call.return_value = None # Call the method with a truthy value for each flattened field, # using the keyword arguments to the method. client.batch_write_spans( name="name_value", spans=[trace.Span(name="name_value")], ) # Establish that the underlying call was made with the expected # request object values. assert len(call.mock_calls) == 1 _, args, _ = call.mock_calls[0] assert args[0].name == "name_value" assert args[0].spans == [trace.Span(name="name_value")]
def test_batch_write_spans_flattened_error(): client = TraceServiceClient( credentials=credentials.AnonymousCredentials(), ) # Attempting to call a method with both a request object and flattened # fields is an error. with pytest.raises(ValueError): client.batch_write_spans( tracing.BatchWriteSpansRequest(), name="name_value", spans=[trace.Span(name="name_value")], )
def test_batch_write_spans(transport: str = "grpc", request_type=tracing.BatchWriteSpansRequest): client = TraceServiceClient( credentials=credentials.AnonymousCredentials(), transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, # and we are mocking out the actual API, so just send an empty request. request = request_type() # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client._transport.batch_write_spans), "__call__") as call: # Designate an appropriate return value for the call. call.return_value = None response = client.batch_write_spans(request) # Establish that the underlying gRPC stub method was called. assert len(call.mock_calls) == 1 _, args, _ = call.mock_calls[0] assert args[0] == tracing.BatchWriteSpansRequest() # Establish that the response is the type that we expect. assert response is None