def test_query_time_series(transport: str = "grpc", request_type=metric_service.QueryTimeSeriesRequest): client = QueryServiceClient( 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.query_time_series), "__call__") as call: # Designate an appropriate return value for the call. call.return_value = metric_service.QueryTimeSeriesResponse( next_page_token="next_page_token_value", ) response = client.query_time_series(request) # Establish that the underlying gRPC stub method was called. assert len(call.mock_calls) == 1 _, args, _ = call.mock_calls[0] assert args[0] == metric_service.QueryTimeSeriesRequest() # Establish that the response is the type that we expect. assert isinstance(response, pagers.QueryTimeSeriesPager) assert response.next_page_token == "next_page_token_value"
def test_query_time_series_field_headers(): client = QueryServiceClient( 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 = metric_service.QueryTimeSeriesRequest() request.name = "name/value" # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.query_time_series), "__call__") as call: call.return_value = metric_service.QueryTimeSeriesResponse() client.query_time_series(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_query_time_series_pages(): client = QueryServiceClient(credentials=credentials.AnonymousCredentials, ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.query_time_series), "__call__") as call: # Set the response to a series of pages. call.side_effect = ( metric_service.QueryTimeSeriesResponse( time_series_data=[ metric.TimeSeriesData(), metric.TimeSeriesData(), metric.TimeSeriesData(), ], next_page_token="abc", ), metric_service.QueryTimeSeriesResponse( time_series_data=[], next_page_token="def", ), metric_service.QueryTimeSeriesResponse( time_series_data=[ metric.TimeSeriesData(), ], next_page_token="ghi", ), metric_service.QueryTimeSeriesResponse(time_series_data=[ metric.TimeSeriesData(), metric.TimeSeriesData(), ], ), RuntimeError, ) pages = list(client.query_time_series(request={}).pages) for page_, token in zip(pages, ["abc", "def", "ghi", ""]): assert page_.raw_page.next_page_token == token
def test_credentials_transport_error(): # It is an error to provide credentials and a transport instance. transport = transports.QueryServiceGrpcTransport( credentials=credentials.AnonymousCredentials(), ) with pytest.raises(ValueError): client = QueryServiceClient( credentials=credentials.AnonymousCredentials(), transport=transport, ) # It is an error to provide a credentials file and a transport instance. transport = transports.QueryServiceGrpcTransport( credentials=credentials.AnonymousCredentials(), ) with pytest.raises(ValueError): client = QueryServiceClient( client_options={"credentials_file": "credentials.json"}, transport=transport, ) # It is an error to provide scopes and a transport instance. transport = transports.QueryServiceGrpcTransport( credentials=credentials.AnonymousCredentials(), ) with pytest.raises(ValueError): client = QueryServiceClient( client_options={"scopes": ["1", "2"]}, transport=transport, )
def test_parse_common_project_path(): expected = { "project": "mussel", } path = QueryServiceClient.common_project_path(**expected) # Check that the path construction is reversible. actual = QueryServiceClient.parse_common_project_path(path) assert expected == actual
def test_parse_common_organization_path(): expected = { "organization": "nudibranch", } path = QueryServiceClient.common_organization_path(**expected) # Check that the path construction is reversible. actual = QueryServiceClient.parse_common_organization_path(path) assert expected == actual
def test_parse_common_folder_path(): expected = { "folder": "octopus", } path = QueryServiceClient.common_folder_path(**expected) # Check that the path construction is reversible. actual = QueryServiceClient.parse_common_folder_path(path) assert expected == actual
def test_parse_common_billing_account_path(): expected = { "billing_account": "clam", } path = QueryServiceClient.common_billing_account_path(**expected) # Check that the path construction is reversible. actual = QueryServiceClient.parse_common_billing_account_path(path) assert expected == actual
def test_query_service_client_get_transport_class(): transport = QueryServiceClient.get_transport_class() available_transports = [ transports.QueryServiceGrpcTransport, ] assert transport in available_transports transport = QueryServiceClient.get_transport_class("grpc") assert transport == transports.QueryServiceGrpcTransport
def test_parse_common_location_path(): expected = { "project": "scallop", "location": "abalone", } path = QueryServiceClient.common_location_path(**expected) # Check that the path construction is reversible. actual = QueryServiceClient.parse_common_location_path(path) assert expected == actual
def test_common_organization_path(): organization = "oyster" expected = "organizations/{organization}".format( organization=organization, ) actual = QueryServiceClient.common_organization_path(organization) assert expected == actual
def test_common_billing_account_path(): billing_account = "squid" expected = "billingAccounts/{billing_account}".format( billing_account=billing_account, ) actual = QueryServiceClient.common_billing_account_path(billing_account) assert expected == actual
def test_query_service_host_with_port(): client = QueryServiceClient( credentials=credentials.AnonymousCredentials(), client_options=client_options.ClientOptions( api_endpoint="monitoring.googleapis.com:8000"), ) assert client.transport._host == "monitoring.googleapis.com:8000"
def test_query_time_series_empty_call(): # This test is a coverage failsafe to make sure that totally empty calls, # i.e. request == None and no flattened fields passed, work. client = QueryServiceClient( credentials=credentials.AnonymousCredentials(), transport="grpc", ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.query_time_series), "__call__") as call: client.query_time_series() call.assert_called() _, args, _ = call.mock_calls[0] assert args[0] == metric_service.QueryTimeSeriesRequest()
def test_transport_grpc_default(): # A client should use the gRPC transport by default. client = QueryServiceClient( credentials=credentials.AnonymousCredentials(), ) assert isinstance( client.transport, transports.QueryServiceGrpcTransport, )
def test_query_time_series_pager(): client = QueryServiceClient(credentials=credentials.AnonymousCredentials, ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.query_time_series), "__call__") as call: # Set the response to a series of pages. call.side_effect = ( metric_service.QueryTimeSeriesResponse( time_series_data=[ metric.TimeSeriesData(), metric.TimeSeriesData(), metric.TimeSeriesData(), ], next_page_token="abc", ), metric_service.QueryTimeSeriesResponse( time_series_data=[], next_page_token="def", ), metric_service.QueryTimeSeriesResponse( time_series_data=[ metric.TimeSeriesData(), ], next_page_token="ghi", ), metric_service.QueryTimeSeriesResponse(time_series_data=[ metric.TimeSeriesData(), metric.TimeSeriesData(), ], ), RuntimeError, ) metadata = () metadata = tuple(metadata) + (gapic_v1.routing_header.to_grpc_metadata( (("name", ""), )), ) pager = client.query_time_series(request={}) assert pager._metadata == metadata results = [i for i in pager] assert len(results) == 6 assert all(isinstance(i, metric.TimeSeriesData) for i in results)
def test_common_location_path(): project = "winkle" location = "nautilus" expected = "projects/{project}/locations/{location}".format( project=project, location=location, ) actual = QueryServiceClient.common_location_path(project, location) assert expected == actual
def test_client_withDEFAULT_CLIENT_INFO(): client_info = gapic_v1.client_info.ClientInfo() with mock.patch.object(transports.QueryServiceTransport, "_prep_wrapped_messages") as prep: client = QueryServiceClient( credentials=credentials.AnonymousCredentials(), client_info=client_info, ) prep.assert_called_once_with(client_info) with mock.patch.object(transports.QueryServiceTransport, "_prep_wrapped_messages") as prep: transport_class = QueryServiceClient.get_transport_class() transport = transport_class( credentials=credentials.AnonymousCredentials(), client_info=client_info, ) prep.assert_called_once_with(client_info)
def test_query_service_auth_adc(): # If no credentials are provided, we should use ADC credentials. with mock.patch.object(auth, "default") as adc: adc.return_value = (credentials.AnonymousCredentials(), None) QueryServiceClient() adc.assert_called_once_with( scopes=( "https://www.googleapis.com/auth/cloud-platform", "https://www.googleapis.com/auth/monitoring", "https://www.googleapis.com/auth/monitoring.read", ), quota_project_id=None, )
def test_query_service_client_client_options_from_dict(): with mock.patch( "google.cloud.monitoring_v3.services.query_service.transports.QueryServiceGrpcTransport.__init__" ) as grpc_transport: grpc_transport.return_value = None client = QueryServiceClient( 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, )
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 QueryServiceClient._get_default_mtls_endpoint(None) is None assert (QueryServiceClient._get_default_mtls_endpoint(api_endpoint) == api_mtls_endpoint) assert (QueryServiceClient._get_default_mtls_endpoint(api_mtls_endpoint) == api_mtls_endpoint) assert (QueryServiceClient._get_default_mtls_endpoint(sandbox_endpoint) == sandbox_mtls_endpoint) assert (QueryServiceClient._get_default_mtls_endpoint( sandbox_mtls_endpoint) == sandbox_mtls_endpoint) assert QueryServiceClient._get_default_mtls_endpoint( non_googleapi) == non_googleapi
def test_transport_instance(): # A client may be instantiated with a custom transport instance. transport = transports.QueryServiceGrpcTransport( credentials=credentials.AnonymousCredentials(), ) client = QueryServiceClient(transport=transport) assert client.transport is transport
def test_common_folder_path(): folder = "whelk" expected = "folders/{folder}".format(folder=folder, ) actual = QueryServiceClient.common_folder_path(folder) assert expected == actual
def test_common_project_path(): project = "cuttlefish" expected = "projects/{project}".format(project=project, ) actual = QueryServiceClient.common_project_path(project) assert expected == actual