Exemplo n.º 1
0
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"]
Exemplo n.º 2
0
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")]
Exemplo n.º 3
0
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")],
        )
Exemplo n.º 4
0
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