Ejemplo n.º 1
0
def test_credentials_transport_error():
    # It is an error to provide credentials and a transport instance.
    transport = transports.PartitionAssignmentServiceGrpcTransport(
        credentials=ga_credentials.AnonymousCredentials(), )
    with pytest.raises(ValueError):
        client = PartitionAssignmentServiceClient(
            credentials=ga_credentials.AnonymousCredentials(),
            transport=transport,
        )

    # It is an error to provide a credentials file and a transport instance.
    transport = transports.PartitionAssignmentServiceGrpcTransport(
        credentials=ga_credentials.AnonymousCredentials(), )
    with pytest.raises(ValueError):
        client = PartitionAssignmentServiceClient(
            client_options={"credentials_file": "credentials.json"},
            transport=transport,
        )

    # It is an error to provide scopes and a transport instance.
    transport = transports.PartitionAssignmentServiceGrpcTransport(
        credentials=ga_credentials.AnonymousCredentials(), )
    with pytest.raises(ValueError):
        client = PartitionAssignmentServiceClient(
            client_options={"scopes": ["1", "2"]},
            transport=transport,
        )
Ejemplo n.º 2
0
def test_assign_partitions(transport: str = "grpc",
                           request_type=subscriber.PartitionAssignmentRequest):
    client = PartitionAssignmentServiceClient(
        credentials=ga_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()
    requests = [request]

    # Mock the actual call within the gRPC stub, and fake the request.
    with mock.patch.object(type(client.transport.assign_partitions),
                           "__call__") as call:
        # Designate an appropriate return value for the call.
        call.return_value = iter([subscriber.PartitionAssignment()])
        response = client.assign_partitions(iter(requests))

        # Establish that the underlying gRPC stub method was called.
        assert len(call.mock_calls) == 1
        _, args, _ = call.mock_calls[0]
        assert next(args[0]) == request

    # Establish that the response is the type that we expect.
    for message in response:
        assert isinstance(message, subscriber.PartitionAssignment)
Ejemplo n.º 3
0
def test_partition_assignment_service_client_get_transport_class():
    transport = PartitionAssignmentServiceClient.get_transport_class()
    available_transports = [
        transports.PartitionAssignmentServiceGrpcTransport,
    ]
    assert transport in available_transports

    transport = PartitionAssignmentServiceClient.get_transport_class("grpc")
    assert transport == transports.PartitionAssignmentServiceGrpcTransport
Ejemplo n.º 4
0
def test_parse_common_project_path():
    expected = {
        "project": "mussel",
    }
    path = PartitionAssignmentServiceClient.common_project_path(**expected)

    # Check that the path construction is reversible.
    actual = PartitionAssignmentServiceClient.parse_common_project_path(path)
    assert expected == actual
Ejemplo n.º 5
0
def test_parse_common_folder_path():
    expected = {
        "folder": "octopus",
    }
    path = PartitionAssignmentServiceClient.common_folder_path(**expected)

    # Check that the path construction is reversible.
    actual = PartitionAssignmentServiceClient.parse_common_folder_path(path)
    assert expected == actual
Ejemplo n.º 6
0
def test_parse_common_location_path():
    expected = {
        "project": "scallop",
        "location": "abalone",
    }
    path = PartitionAssignmentServiceClient.common_location_path(**expected)

    # Check that the path construction is reversible.
    actual = PartitionAssignmentServiceClient.parse_common_location_path(path)
    assert expected == actual
Ejemplo n.º 7
0
def test_parse_common_organization_path():
    expected = {
        "organization": "nudibranch",
    }
    path = PartitionAssignmentServiceClient.common_organization_path(
        **expected)

    # Check that the path construction is reversible.
    actual = PartitionAssignmentServiceClient.parse_common_organization_path(
        path)
    assert expected == actual
Ejemplo n.º 8
0
def test_parse_common_billing_account_path():
    expected = {
        "billing_account": "clam",
    }
    path = PartitionAssignmentServiceClient.common_billing_account_path(
        **expected)

    # Check that the path construction is reversible.
    actual = PartitionAssignmentServiceClient.parse_common_billing_account_path(
        path)
    assert expected == actual
Ejemplo n.º 9
0
def test_common_organization_path():
    organization = "oyster"
    expected = "organizations/{organization}".format(
        organization=organization, )
    actual = PartitionAssignmentServiceClient.common_organization_path(
        organization)
    assert expected == actual
Ejemplo n.º 10
0
def test_partition_assignment_service_host_with_port():
    client = PartitionAssignmentServiceClient(
        credentials=ga_credentials.AnonymousCredentials(),
        client_options=client_options.ClientOptions(
            api_endpoint="pubsublite.googleapis.com:8000"),
    )
    assert client.transport._host == "pubsublite.googleapis.com:8000"
Ejemplo n.º 11
0
def test_common_billing_account_path():
    billing_account = "squid"
    expected = "billingAccounts/{billing_account}".format(
        billing_account=billing_account, )
    actual = PartitionAssignmentServiceClient.common_billing_account_path(
        billing_account)
    assert expected == actual
Ejemplo n.º 12
0
def test_transport_grpc_default():
    # A client should use the gRPC transport by default.
    client = PartitionAssignmentServiceClient(
        credentials=ga_credentials.AnonymousCredentials(), )
    assert isinstance(
        client.transport,
        transports.PartitionAssignmentServiceGrpcTransport,
    )
Ejemplo n.º 13
0
def test_partition_assignment_service_auth_adc_old_google_auth():
    # If no credentials are provided, we should use ADC credentials.
    with mock.patch.object(google.auth, "default", autospec=True) as adc:
        adc.return_value = (ga_credentials.AnonymousCredentials(), None)
        PartitionAssignmentServiceClient()
        adc.assert_called_once_with(
            scopes=("https://www.googleapis.com/auth/cloud-platform", ),
            quota_project_id=None,
        )
Ejemplo n.º 14
0
def test_common_location_path():
    project = "winkle"
    location = "nautilus"
    expected = "projects/{project}/locations/{location}".format(
        project=project,
        location=location,
    )
    actual = PartitionAssignmentServiceClient.common_location_path(
        project, location)
    assert expected == actual
Ejemplo n.º 15
0
def test_client_withDEFAULT_CLIENT_INFO():
    client_info = gapic_v1.client_info.ClientInfo()

    with mock.patch.object(transports.PartitionAssignmentServiceTransport,
                           "_prep_wrapped_messages") as prep:
        client = PartitionAssignmentServiceClient(
            credentials=ga_credentials.AnonymousCredentials(),
            client_info=client_info,
        )
        prep.assert_called_once_with(client_info)

    with mock.patch.object(transports.PartitionAssignmentServiceTransport,
                           "_prep_wrapped_messages") as prep:
        transport_class = PartitionAssignmentServiceClient.get_transport_class(
        )
        transport = transport_class(
            credentials=ga_credentials.AnonymousCredentials(),
            client_info=client_info,
        )
        prep.assert_called_once_with(client_info)
Ejemplo n.º 16
0
def test_partition_assignment_service_client_client_options_from_dict():
    with mock.patch(
            "google.cloud.pubsublite_v1.services.partition_assignment_service.transports.PartitionAssignmentServiceGrpcTransport.__init__"
    ) as grpc_transport:
        grpc_transport.return_value = None
        client = PartitionAssignmentServiceClient(
            client_options={"api_endpoint": "squid.clam.whelk"})
        grpc_transport.assert_called_once_with(
            credentials=None,
            credentials_file=None,
            host="squid.clam.whelk",
            scopes=None,
            client_cert_source_for_mtls=None,
            quota_project_id=None,
            client_info=transports.base.DEFAULT_CLIENT_INFO,
            always_use_jwt_access=True,
        )
Ejemplo n.º 17
0
def test__get_default_mtls_endpoint():
    api_endpoint = "example.googleapis.com"
    api_mtls_endpoint = "example.mtls.googleapis.com"
    sandbox_endpoint = "example.sandbox.googleapis.com"
    sandbox_mtls_endpoint = "example.mtls.sandbox.googleapis.com"
    non_googleapi = "api.example.com"

    assert PartitionAssignmentServiceClient._get_default_mtls_endpoint(
        None) is None
    assert (PartitionAssignmentServiceClient._get_default_mtls_endpoint(
        api_endpoint) == api_mtls_endpoint)
    assert (PartitionAssignmentServiceClient._get_default_mtls_endpoint(
        api_mtls_endpoint) == api_mtls_endpoint)
    assert (PartitionAssignmentServiceClient._get_default_mtls_endpoint(
        sandbox_endpoint) == sandbox_mtls_endpoint)
    assert (PartitionAssignmentServiceClient._get_default_mtls_endpoint(
        sandbox_mtls_endpoint) == sandbox_mtls_endpoint)
    assert (PartitionAssignmentServiceClient._get_default_mtls_endpoint(
        non_googleapi) == non_googleapi)
Ejemplo n.º 18
0
def test_transport_instance():
    # A client may be instantiated with a custom transport instance.
    transport = transports.PartitionAssignmentServiceGrpcTransport(
        credentials=ga_credentials.AnonymousCredentials(), )
    client = PartitionAssignmentServiceClient(transport=transport)
    assert client.transport is transport
Ejemplo n.º 19
0
def test_common_folder_path():
    folder = "whelk"
    expected = "folders/{folder}".format(folder=folder, )
    actual = PartitionAssignmentServiceClient.common_folder_path(folder)
    assert expected == actual
Ejemplo n.º 20
0
def test_common_project_path():
    project = "cuttlefish"
    expected = "projects/{project}".format(project=project, )
    actual = PartitionAssignmentServiceClient.common_project_path(project)
    assert expected == actual