diff --git a/.flake8 b/.flake8 index 29227d4c..2e438749 100644 --- a/.flake8 +++ b/.flake8 @@ -16,7 +16,7 @@ # Generated by synthtool. DO NOT EDIT! [flake8] -ignore = E203, E266, E501, W503 +ignore = E203, E231, E266, E501, W503 exclude = # Exclude generated code. **/proto/** diff --git a/.github/.OwlBot.lock.yaml b/.github/.OwlBot.lock.yaml index 44c78f7c..bc893c97 100644 --- a/.github/.OwlBot.lock.yaml +++ b/.github/.OwlBot.lock.yaml @@ -13,4 +13,5 @@ # limitations under the License. docker: image: gcr.io/cloud-devrel-public-resources/owlbot-python:latest - digest: sha256:4e1991042fe54b991db9ca17c8fb386e61b22fe4d1472a568bf0fcac85dcf5d3 + digest: sha256:8a5d3f6a2e43ed8293f34e06a2f56931d1e88a2694c3bb11b15df4eb256ad163 +# created: 2022-04-06T10:30:21.687684602Z diff --git a/.github/auto-label.yaml b/.github/auto-label.yaml new file mode 100644 index 00000000..ccad49b4 --- /dev/null +++ b/.github/auto-label.yaml @@ -0,0 +1,19 @@ +# Copyright 2022 Google LLC +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +requestsize: + enabled: true +staleness: + pullrequest: true + old: 30 + extraold: 60 diff --git a/.github/blunderbuss.yml b/.github/blunderbuss.yml index 148ebf4e..28438484 100644 --- a/.github/blunderbuss.yml +++ b/.github/blunderbuss.yml @@ -1,4 +1,4 @@ assign_issues: - - Daniel-Sanche + - arbrown assign_prs: - - Daniel-Sanche + - arbrown diff --git a/.github/release-please.yml b/.github/release-please.yml index 466597e5..6def37a8 100644 --- a/.github/release-please.yml +++ b/.github/release-please.yml @@ -1,2 +1,8 @@ releaseType: python handleGHRelease: true +# NOTE: this section is generated by synthtool.languages.python +# See https://github.com/googleapis/synthtool/blob/master/synthtool/languages/python.py +branches: +- branch: v0 + handleGHRelease: true + releaseType: python diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 62eb5a77..46d23716 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -22,7 +22,7 @@ repos: - id: end-of-file-fixer - id: check-yaml - repo: https://github.com/psf/black - rev: 19.10b0 + rev: 22.3.0 hooks: - id: black - repo: https://gitlab.com/pycqa/flake8 diff --git a/.repo-metadata.json b/.repo-metadata.json index a0f2eca2..a42bec3c 100644 --- a/.repo-metadata.json +++ b/.repo-metadata.json @@ -1,6 +1,6 @@ { "name": "clouderrorreporting", - "name_pretty": "Cloud Error Reporting", + "name_pretty": "Error Reporting", "product_documentation": "https://cloud.google.com/error-reporting", "client_documentation": "https://cloud.google.com/python/docs/reference/clouderrorreporting/latest", "issue_tracker": "https://issuetracker.google.com/savedsearches/559780", diff --git a/CHANGELOG.md b/CHANGELOG.md index a935a4aa..3c87476b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,13 @@ [1]: https://pypi.org/project/google-cloud-error-reporting/#history +### [1.5.2](https://github.com/googleapis/python-error-reporting/compare/v1.5.1...v1.5.2) (2022-04-16) + + +### Bug Fixes + +* Reenable staleness bot ([#264](https://github.com/googleapis/python-error-reporting/issues/264)) ([393141a](https://github.com/googleapis/python-error-reporting/commit/393141ac2c661485fdafb8f21fe13a6b2c854d07)) + ### [1.5.1](https://github.com/googleapis/python-error-reporting/compare/v1.5.0...v1.5.1) (2022-03-07) diff --git a/README.rst b/README.rst index fce2927d..fb72fc83 100644 --- a/README.rst +++ b/README.rst @@ -1,9 +1,9 @@ -Python Client for Cloud Error Reporting +Python Client for Error Reporting ============================================= |beta| |pypi| |versions| -The Cloud `Error Reporting`_ API counts, analyzes and aggregates the +The `Error Reporting`_ API counts, analyzes and aggregates the crashes in your running cloud services. A centralized error management interface displays the results with sorting and filtering capabilities. A dedicated view shows the error details: time chart, occurrences, affected user diff --git a/docs/conf.py b/docs/conf.py index e56d4c58..c8f4857a 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -361,7 +361,10 @@ intersphinx_mapping = { "python": ("https://python.readthedocs.org/en/latest/", None), "google-auth": ("https://googleapis.dev/python/google-auth/latest/", None), - "google.api_core": ("https://googleapis.dev/python/google-api-core/latest/", None,), + "google.api_core": ( + "https://googleapis.dev/python/google-api-core/latest/", + None, + ), "grpc": ("https://grpc.github.io/grpc/python/", None), "proto-plus": ("https://proto-plus-python.readthedocs.io/en/latest/", None), "protobuf": ("https://googleapis.dev/python/protobuf/latest/", None), diff --git a/docs/usage.rst b/docs/usage.rst index 40d4365f..7f1dc4f7 100644 --- a/docs/usage.rst +++ b/docs/usage.rst @@ -1,4 +1,4 @@ -Using Cloud Error Reporting +Using Error Reporting ================================= After configuring your environment, create a @@ -35,7 +35,7 @@ also optionally specify a version for that service, which defaults to Reporting an exception ----------------------- -Report a stacktrace to Cloud Error Reporting after an exception: +Report a stacktrace to Error Reporting after an exception: .. code-block:: python @@ -54,7 +54,7 @@ the client's constructor, or the default service of "python". The user and HTTP context can also be included in the exception. The HTTP context can be constructed using :class:`google.cloud.error_reporting.HTTPContext`. This will be used by -Cloud Error Reporting to help group exceptions. +Error Reporting to help group exceptions. .. code-block:: python @@ -88,7 +88,7 @@ object is provided. Reporting an error without an exception ----------------------------------------- -Errors can also be reported to Cloud Error Reporting outside the context +Errors can also be reported to Error Reporting outside the context of an exception. The library will include the file path, function name, and line number of the location where the error was reported. diff --git a/google/cloud/error_reporting/_gapic.py b/google/cloud/error_reporting/_gapic.py index 9c7f95c8..d38adf29 100644 --- a/google/cloud/error_reporting/_gapic.py +++ b/google/cloud/error_reporting/_gapic.py @@ -66,8 +66,10 @@ def report_error_event(self, error_report): # Since error_report uses camel case for key names (like serviceContext), # but ReportedErrorEvent uses snake case for key names (like service_context), # we need to route throught json. - error_report_payload = google.cloud.errorreporting_v1beta1.ReportedErrorEvent.from_json( - json.dumps(error_report) + error_report_payload = ( + google.cloud.errorreporting_v1beta1.ReportedErrorEvent.from_json( + json.dumps(error_report) + ) ) self._gapic_api.report_error_event( diff --git a/google/cloud/error_reporting/client.py b/google/cloud/error_reporting/client.py index e44c5c92..440262da 100644 --- a/google/cloud/error_reporting/client.py +++ b/google/cloud/error_reporting/client.py @@ -246,7 +246,7 @@ def _build_error_report( :rtype: dict :returns: A dict payload ready to be serialized to JSON and sent to the API. - """ + """ payload = { "serviceContext": {"service": self.service}, "message": "{0}".format(message), @@ -315,7 +315,7 @@ def _send_error_report( self.report_errors_api.report_error_event(error_report) def report(self, message, http_context=None, user=None): - """ Reports a message to Error Reporting + """Reports a message to Error Reporting https://cloud.google.com/error-reporting/docs/formatting-error-messages @@ -360,27 +360,27 @@ def report(self, message, http_context=None, user=None): ) def report_exception(self, http_context=None, user=None): - """ Reports the details of the latest exceptions to Error Reporting. - - :type http_context: :class`google.cloud.error_reporting.HTTPContext` - :param http_context: The HTTP request which was processed when the - error was triggered. - - :type user: str - :param user: The user who caused or was affected by the crash. This - can be a user ID, an email address, or an arbitrary - token that uniquely identifies the user. When sending an - error report, leave this field empty if the user was - not logged in. In this case the Error Reporting system - will use other data, such as remote IP address, - to distinguish affected users. - - Example:: - - >>> try: - >>> raise NameError - >>> except Exception: - >>> client.report_exception() + """Reports the details of the latest exceptions to Error Reporting. + + :type http_context: :class`google.cloud.error_reporting.HTTPContext` + :param http_context: The HTTP request which was processed when the + error was triggered. + + :type user: str + :param user: The user who caused or was affected by the crash. This + can be a user ID, an email address, or an arbitrary + token that uniquely identifies the user. When sending an + error report, leave this field empty if the user was + not logged in. In this case the Error Reporting system + will use other data, such as remote IP address, + to distinguish affected users. + + Example:: + + >>> try: + >>> raise NameError + >>> except Exception: + >>> client.report_exception() """ self._send_error_report( traceback.format_exc(), http_context=http_context, user=user diff --git a/google/cloud/errorreporting_v1beta1/services/error_group_service/async_client.py b/google/cloud/errorreporting_v1beta1/services/error_group_service/async_client.py index af06be3b..6316e62a 100644 --- a/google/cloud/errorreporting_v1beta1/services/error_group_service/async_client.py +++ b/google/cloud/errorreporting_v1beta1/services/error_group_service/async_client.py @@ -16,7 +16,7 @@ from collections import OrderedDict import functools import re -from typing import Dict, Optional, Sequence, Tuple, Type, Union +from typing import Dict, Mapping, Optional, Sequence, Tuple, Type, Union import pkg_resources from google.api_core.client_options import ClientOptions @@ -295,7 +295,12 @@ def sample_get_group(): ) # Send the request. - response = await rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = await rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # Done; return the response. return response @@ -312,7 +317,6 @@ async def update_group( r"""Replace the data for the specified group. Fails if the group does not exist. - .. code-block:: python from google.cloud import errorreporting_v1beta1 @@ -388,7 +392,12 @@ def sample_update_group(): ) # Send the request. - response = await rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = await rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # Done; return the response. return response diff --git a/google/cloud/errorreporting_v1beta1/services/error_group_service/client.py b/google/cloud/errorreporting_v1beta1/services/error_group_service/client.py index 0984b289..eec0a0ae 100644 --- a/google/cloud/errorreporting_v1beta1/services/error_group_service/client.py +++ b/google/cloud/errorreporting_v1beta1/services/error_group_service/client.py @@ -16,7 +16,7 @@ from collections import OrderedDict import os import re -from typing import Dict, Optional, Sequence, Tuple, Type, Union +from typing import Dict, Mapping, Optional, Sequence, Tuple, Type, Union import pkg_resources from google.api_core import client_options as client_options_lib @@ -56,7 +56,8 @@ class ErrorGroupServiceClientMeta(type): _transport_registry["grpc_asyncio"] = ErrorGroupServiceGrpcAsyncIOTransport def get_transport_class( - cls, label: str = None, + cls, + label: str = None, ) -> Type[ErrorGroupServiceTransport]: """Returns an appropriate transport class. @@ -162,9 +163,15 @@ def transport(self) -> ErrorGroupServiceTransport: return self._transport @staticmethod - def error_group_path(project: str, group: str,) -> str: + def error_group_path( + project: str, + group: str, + ) -> str: """Returns a fully-qualified error_group string.""" - return "projects/{project}/groups/{group}".format(project=project, group=group,) + return "projects/{project}/groups/{group}".format( + project=project, + group=group, + ) @staticmethod def parse_error_group_path(path: str) -> Dict[str, str]: @@ -173,7 +180,9 @@ def parse_error_group_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_billing_account_path(billing_account: str,) -> str: + def common_billing_account_path( + billing_account: str, + ) -> str: """Returns a fully-qualified billing_account string.""" return "billingAccounts/{billing_account}".format( billing_account=billing_account, @@ -186,9 +195,13 @@ def parse_common_billing_account_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_folder_path(folder: str,) -> str: + def common_folder_path( + folder: str, + ) -> str: """Returns a fully-qualified folder string.""" - return "folders/{folder}".format(folder=folder,) + return "folders/{folder}".format( + folder=folder, + ) @staticmethod def parse_common_folder_path(path: str) -> Dict[str, str]: @@ -197,9 +210,13 @@ def parse_common_folder_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_organization_path(organization: str,) -> str: + def common_organization_path( + organization: str, + ) -> str: """Returns a fully-qualified organization string.""" - return "organizations/{organization}".format(organization=organization,) + return "organizations/{organization}".format( + organization=organization, + ) @staticmethod def parse_common_organization_path(path: str) -> Dict[str, str]: @@ -208,9 +225,13 @@ def parse_common_organization_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_project_path(project: str,) -> str: + def common_project_path( + project: str, + ) -> str: """Returns a fully-qualified project string.""" - return "projects/{project}".format(project=project,) + return "projects/{project}".format( + project=project, + ) @staticmethod def parse_common_project_path(path: str) -> Dict[str, str]: @@ -219,10 +240,14 @@ def parse_common_project_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_location_path(project: str, location: str,) -> str: + def common_location_path( + project: str, + location: str, + ) -> str: """Returns a fully-qualified location string.""" return "projects/{project}/locations/{location}".format( - project=project, location=location, + project=project, + location=location, ) @staticmethod @@ -487,7 +512,12 @@ def sample_get_group(): ) # Send the request. - response = rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # Done; return the response. return response @@ -504,7 +534,6 @@ def update_group( r"""Replace the data for the specified group. Fails if the group does not exist. - .. code-block:: python from google.cloud import errorreporting_v1beta1 @@ -580,7 +609,12 @@ def sample_update_group(): ) # Send the request. - response = rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # Done; return the response. return response diff --git a/google/cloud/errorreporting_v1beta1/services/error_group_service/transports/base.py b/google/cloud/errorreporting_v1beta1/services/error_group_service/transports/base.py index 51d36328..d7f0edd8 100644 --- a/google/cloud/errorreporting_v1beta1/services/error_group_service/transports/base.py +++ b/google/cloud/errorreporting_v1beta1/services/error_group_service/transports/base.py @@ -81,6 +81,7 @@ def __init__( always_use_jwt_access (Optional[bool]): Whether self signed JWT should be used for service account credentials. """ + # Save the hostname. Default to port 443 (HTTPS) if none is specified. if ":" not in host: host += ":443" @@ -122,19 +123,23 @@ def _prep_wrapped_messages(self, client_info): # Precompute the wrapped methods. self._wrapped_methods = { self.get_group: gapic_v1.method.wrap_method( - self.get_group, default_timeout=None, client_info=client_info, + self.get_group, + default_timeout=None, + client_info=client_info, ), self.update_group: gapic_v1.method.wrap_method( - self.update_group, default_timeout=None, client_info=client_info, + self.update_group, + default_timeout=None, + client_info=client_info, ), } def close(self): """Closes resources associated with the transport. - .. warning:: - Only call this method if the transport is NOT shared - with other clients - this may cause errors in other clients! + .. warning:: + Only call this method if the transport is NOT shared + with other clients - this may cause errors in other clients! """ raise NotImplementedError() @@ -156,5 +161,9 @@ def update_group( ]: raise NotImplementedError() + @property + def kind(self) -> str: + raise NotImplementedError() + __all__ = ("ErrorGroupServiceTransport",) diff --git a/google/cloud/errorreporting_v1beta1/services/error_group_service/transports/grpc.py b/google/cloud/errorreporting_v1beta1/services/error_group_service/transports/grpc.py index 695f89fd..c90e37f7 100644 --- a/google/cloud/errorreporting_v1beta1/services/error_group_service/transports/grpc.py +++ b/google/cloud/errorreporting_v1beta1/services/error_group_service/transports/grpc.py @@ -225,8 +225,7 @@ def create_channel( @property def grpc_channel(self) -> grpc.Channel: - """Return the channel designed to connect to this service. - """ + """Return the channel designed to connect to this service.""" return self._grpc_channel @property @@ -285,5 +284,9 @@ def update_group( def close(self): self.grpc_channel.close() + @property + def kind(self) -> str: + return "grpc" + __all__ = ("ErrorGroupServiceGrpcTransport",) diff --git a/google/cloud/errorreporting_v1beta1/services/error_stats_service/async_client.py b/google/cloud/errorreporting_v1beta1/services/error_stats_service/async_client.py index a31c0335..13cd9f08 100644 --- a/google/cloud/errorreporting_v1beta1/services/error_stats_service/async_client.py +++ b/google/cloud/errorreporting_v1beta1/services/error_stats_service/async_client.py @@ -16,7 +16,7 @@ from collections import OrderedDict import functools import re -from typing import Dict, Optional, Sequence, Tuple, Type, Union +from typing import Dict, Mapping, Optional, Sequence, Tuple, Type, Union import pkg_resources from google.api_core.client_options import ClientOptions @@ -320,12 +320,20 @@ def sample_list_group_stats(): ) # Send the request. - response = await rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = await rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # This method is paged; wrap the response in a pager, which provides # an `__aiter__` convenience method. response = pagers.ListGroupStatsAsyncPager( - method=rpc, request=request, response=response, metadata=metadata, + method=rpc, + request=request, + response=response, + metadata=metadata, ) # Done; return the response. @@ -437,12 +445,20 @@ def sample_list_events(): ) # Send the request. - response = await rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = await rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # This method is paged; wrap the response in a pager, which provides # an `__aiter__` convenience method. response = pagers.ListEventsAsyncPager( - method=rpc, request=request, response=response, metadata=metadata, + method=rpc, + request=request, + response=response, + metadata=metadata, ) # Done; return the response. @@ -538,7 +554,12 @@ def sample_delete_events(): ) # Send the request. - response = await rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = await rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # Done; return the response. return response diff --git a/google/cloud/errorreporting_v1beta1/services/error_stats_service/client.py b/google/cloud/errorreporting_v1beta1/services/error_stats_service/client.py index fd14ada0..f3289f77 100644 --- a/google/cloud/errorreporting_v1beta1/services/error_stats_service/client.py +++ b/google/cloud/errorreporting_v1beta1/services/error_stats_service/client.py @@ -16,7 +16,7 @@ from collections import OrderedDict import os import re -from typing import Dict, Optional, Sequence, Tuple, Type, Union +from typing import Dict, Mapping, Optional, Sequence, Tuple, Type, Union import pkg_resources from google.api_core import client_options as client_options_lib @@ -57,7 +57,8 @@ class ErrorStatsServiceClientMeta(type): _transport_registry["grpc_asyncio"] = ErrorStatsServiceGrpcAsyncIOTransport def get_transport_class( - cls, label: str = None, + cls, + label: str = None, ) -> Type[ErrorStatsServiceTransport]: """Returns an appropriate transport class. @@ -165,9 +166,15 @@ def transport(self) -> ErrorStatsServiceTransport: return self._transport @staticmethod - def error_group_path(project: str, group: str,) -> str: + def error_group_path( + project: str, + group: str, + ) -> str: """Returns a fully-qualified error_group string.""" - return "projects/{project}/groups/{group}".format(project=project, group=group,) + return "projects/{project}/groups/{group}".format( + project=project, + group=group, + ) @staticmethod def parse_error_group_path(path: str) -> Dict[str, str]: @@ -176,7 +183,9 @@ def parse_error_group_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_billing_account_path(billing_account: str,) -> str: + def common_billing_account_path( + billing_account: str, + ) -> str: """Returns a fully-qualified billing_account string.""" return "billingAccounts/{billing_account}".format( billing_account=billing_account, @@ -189,9 +198,13 @@ def parse_common_billing_account_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_folder_path(folder: str,) -> str: + def common_folder_path( + folder: str, + ) -> str: """Returns a fully-qualified folder string.""" - return "folders/{folder}".format(folder=folder,) + return "folders/{folder}".format( + folder=folder, + ) @staticmethod def parse_common_folder_path(path: str) -> Dict[str, str]: @@ -200,9 +213,13 @@ def parse_common_folder_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_organization_path(organization: str,) -> str: + def common_organization_path( + organization: str, + ) -> str: """Returns a fully-qualified organization string.""" - return "organizations/{organization}".format(organization=organization,) + return "organizations/{organization}".format( + organization=organization, + ) @staticmethod def parse_common_organization_path(path: str) -> Dict[str, str]: @@ -211,9 +228,13 @@ def parse_common_organization_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_project_path(project: str,) -> str: + def common_project_path( + project: str, + ) -> str: """Returns a fully-qualified project string.""" - return "projects/{project}".format(project=project,) + return "projects/{project}".format( + project=project, + ) @staticmethod def parse_common_project_path(path: str) -> Dict[str, str]: @@ -222,10 +243,14 @@ def parse_common_project_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_location_path(project: str, location: str,) -> str: + def common_location_path( + project: str, + location: str, + ) -> str: """Returns a fully-qualified location string.""" return "projects/{project}/locations/{location}".format( - project=project, location=location, + project=project, + location=location, ) @staticmethod @@ -512,12 +537,20 @@ def sample_list_group_stats(): ) # Send the request. - response = rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # This method is paged; wrap the response in a pager, which provides # an `__iter__` convenience method. response = pagers.ListGroupStatsPager( - method=rpc, request=request, response=response, metadata=metadata, + method=rpc, + request=request, + response=response, + metadata=metadata, ) # Done; return the response. @@ -629,12 +662,20 @@ def sample_list_events(): ) # Send the request. - response = rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # This method is paged; wrap the response in a pager, which provides # an `__iter__` convenience method. response = pagers.ListEventsPager( - method=rpc, request=request, response=response, metadata=metadata, + method=rpc, + request=request, + response=response, + metadata=metadata, ) # Done; return the response. @@ -730,7 +771,12 @@ def sample_delete_events(): ) # Send the request. - response = rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # Done; return the response. return response diff --git a/google/cloud/errorreporting_v1beta1/services/error_stats_service/transports/base.py b/google/cloud/errorreporting_v1beta1/services/error_stats_service/transports/base.py index 02ebb197..0bdbe002 100644 --- a/google/cloud/errorreporting_v1beta1/services/error_stats_service/transports/base.py +++ b/google/cloud/errorreporting_v1beta1/services/error_stats_service/transports/base.py @@ -80,6 +80,7 @@ def __init__( always_use_jwt_access (Optional[bool]): Whether self signed JWT should be used for service account credentials. """ + # Save the hostname. Default to port 443 (HTTPS) if none is specified. if ":" not in host: host += ":443" @@ -121,22 +122,28 @@ def _prep_wrapped_messages(self, client_info): # Precompute the wrapped methods. self._wrapped_methods = { self.list_group_stats: gapic_v1.method.wrap_method( - self.list_group_stats, default_timeout=None, client_info=client_info, + self.list_group_stats, + default_timeout=None, + client_info=client_info, ), self.list_events: gapic_v1.method.wrap_method( - self.list_events, default_timeout=None, client_info=client_info, + self.list_events, + default_timeout=None, + client_info=client_info, ), self.delete_events: gapic_v1.method.wrap_method( - self.delete_events, default_timeout=None, client_info=client_info, + self.delete_events, + default_timeout=None, + client_info=client_info, ), } def close(self): """Closes resources associated with the transport. - .. warning:: - Only call this method if the transport is NOT shared - with other clients - this may cause errors in other clients! + .. warning:: + Only call this method if the transport is NOT shared + with other clients - this may cause errors in other clients! """ raise NotImplementedError() @@ -176,5 +183,9 @@ def delete_events( ]: raise NotImplementedError() + @property + def kind(self) -> str: + raise NotImplementedError() + __all__ = ("ErrorStatsServiceTransport",) diff --git a/google/cloud/errorreporting_v1beta1/services/error_stats_service/transports/grpc.py b/google/cloud/errorreporting_v1beta1/services/error_stats_service/transports/grpc.py index fb4b7746..8b9510b1 100644 --- a/google/cloud/errorreporting_v1beta1/services/error_stats_service/transports/grpc.py +++ b/google/cloud/errorreporting_v1beta1/services/error_stats_service/transports/grpc.py @@ -225,8 +225,7 @@ def create_channel( @property def grpc_channel(self) -> grpc.Channel: - """Return the channel designed to connect to this service. - """ + """Return the channel designed to connect to this service.""" return self._grpc_channel @property @@ -318,5 +317,9 @@ def delete_events( def close(self): self.grpc_channel.close() + @property + def kind(self) -> str: + return "grpc" + __all__ = ("ErrorStatsServiceGrpcTransport",) diff --git a/google/cloud/errorreporting_v1beta1/services/report_errors_service/async_client.py b/google/cloud/errorreporting_v1beta1/services/report_errors_service/async_client.py index c5bf86ae..a7ab63d2 100644 --- a/google/cloud/errorreporting_v1beta1/services/report_errors_service/async_client.py +++ b/google/cloud/errorreporting_v1beta1/services/report_errors_service/async_client.py @@ -16,7 +16,7 @@ from collections import OrderedDict import functools import re -from typing import Dict, Optional, Sequence, Tuple, Type, Union +from typing import Dict, Mapping, Optional, Sequence, Tuple, Type, Union import pkg_resources from google.api_core.client_options import ClientOptions @@ -227,7 +227,6 @@ async def report_error_event( For more information, see `Using Error Reporting with regionalized logs `__. - .. code-block:: python from google.cloud import errorreporting_v1beta1 @@ -322,7 +321,12 @@ def sample_report_error_event(): ) # Send the request. - response = await rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = await rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # Done; return the response. return response diff --git a/google/cloud/errorreporting_v1beta1/services/report_errors_service/client.py b/google/cloud/errorreporting_v1beta1/services/report_errors_service/client.py index cce7eb3c..297c8d8e 100644 --- a/google/cloud/errorreporting_v1beta1/services/report_errors_service/client.py +++ b/google/cloud/errorreporting_v1beta1/services/report_errors_service/client.py @@ -16,7 +16,7 @@ from collections import OrderedDict import os import re -from typing import Dict, Optional, Sequence, Tuple, Type, Union +from typing import Dict, Mapping, Optional, Sequence, Tuple, Type, Union import pkg_resources from google.api_core import client_options as client_options_lib @@ -55,7 +55,8 @@ class ReportErrorsServiceClientMeta(type): _transport_registry["grpc_asyncio"] = ReportErrorsServiceGrpcAsyncIOTransport def get_transport_class( - cls, label: str = None, + cls, + label: str = None, ) -> Type[ReportErrorsServiceTransport]: """Returns an appropriate transport class. @@ -161,7 +162,9 @@ def transport(self) -> ReportErrorsServiceTransport: return self._transport @staticmethod - def common_billing_account_path(billing_account: str,) -> str: + def common_billing_account_path( + billing_account: str, + ) -> str: """Returns a fully-qualified billing_account string.""" return "billingAccounts/{billing_account}".format( billing_account=billing_account, @@ -174,9 +177,13 @@ def parse_common_billing_account_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_folder_path(folder: str,) -> str: + def common_folder_path( + folder: str, + ) -> str: """Returns a fully-qualified folder string.""" - return "folders/{folder}".format(folder=folder,) + return "folders/{folder}".format( + folder=folder, + ) @staticmethod def parse_common_folder_path(path: str) -> Dict[str, str]: @@ -185,9 +192,13 @@ def parse_common_folder_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_organization_path(organization: str,) -> str: + def common_organization_path( + organization: str, + ) -> str: """Returns a fully-qualified organization string.""" - return "organizations/{organization}".format(organization=organization,) + return "organizations/{organization}".format( + organization=organization, + ) @staticmethod def parse_common_organization_path(path: str) -> Dict[str, str]: @@ -196,9 +207,13 @@ def parse_common_organization_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_project_path(project: str,) -> str: + def common_project_path( + project: str, + ) -> str: """Returns a fully-qualified project string.""" - return "projects/{project}".format(project=project,) + return "projects/{project}".format( + project=project, + ) @staticmethod def parse_common_project_path(path: str) -> Dict[str, str]: @@ -207,10 +222,14 @@ def parse_common_project_path(path: str) -> Dict[str, str]: return m.groupdict() if m else {} @staticmethod - def common_location_path(project: str, location: str,) -> str: + def common_location_path( + project: str, + location: str, + ) -> str: """Returns a fully-qualified location string.""" return "projects/{project}/locations/{location}".format( - project=project, location=location, + project=project, + location=location, ) @staticmethod @@ -411,7 +430,6 @@ def report_error_event( For more information, see `Using Error Reporting with regionalized logs `__. - .. code-block:: python from google.cloud import errorreporting_v1beta1 @@ -506,7 +524,12 @@ def sample_report_error_event(): ) # Send the request. - response = rpc(request, retry=retry, timeout=timeout, metadata=metadata,) + response = rpc( + request, + retry=retry, + timeout=timeout, + metadata=metadata, + ) # Done; return the response. return response diff --git a/google/cloud/errorreporting_v1beta1/services/report_errors_service/transports/base.py b/google/cloud/errorreporting_v1beta1/services/report_errors_service/transports/base.py index c251f4a8..5da09490 100644 --- a/google/cloud/errorreporting_v1beta1/services/report_errors_service/transports/base.py +++ b/google/cloud/errorreporting_v1beta1/services/report_errors_service/transports/base.py @@ -80,6 +80,7 @@ def __init__( always_use_jwt_access (Optional[bool]): Whether self signed JWT should be used for service account credentials. """ + # Save the hostname. Default to port 443 (HTTPS) if none is specified. if ":" not in host: host += ":443" @@ -121,16 +122,18 @@ def _prep_wrapped_messages(self, client_info): # Precompute the wrapped methods. self._wrapped_methods = { self.report_error_event: gapic_v1.method.wrap_method( - self.report_error_event, default_timeout=None, client_info=client_info, + self.report_error_event, + default_timeout=None, + client_info=client_info, ), } def close(self): """Closes resources associated with the transport. - .. warning:: - Only call this method if the transport is NOT shared - with other clients - this may cause errors in other clients! + .. warning:: + Only call this method if the transport is NOT shared + with other clients - this may cause errors in other clients! """ raise NotImplementedError() @@ -146,5 +149,9 @@ def report_error_event( ]: raise NotImplementedError() + @property + def kind(self) -> str: + raise NotImplementedError() + __all__ = ("ReportErrorsServiceTransport",) diff --git a/google/cloud/errorreporting_v1beta1/services/report_errors_service/transports/grpc.py b/google/cloud/errorreporting_v1beta1/services/report_errors_service/transports/grpc.py index 2f225db7..aab08b85 100644 --- a/google/cloud/errorreporting_v1beta1/services/report_errors_service/transports/grpc.py +++ b/google/cloud/errorreporting_v1beta1/services/report_errors_service/transports/grpc.py @@ -224,8 +224,7 @@ def create_channel( @property def grpc_channel(self) -> grpc.Channel: - """Return the channel designed to connect to this service. - """ + """Return the channel designed to connect to this service.""" return self._grpc_channel @property @@ -275,5 +274,9 @@ def report_error_event( def close(self): self.grpc_channel.close() + @property + def kind(self) -> str: + return "grpc" + __all__ = ("ReportErrorsServiceGrpcTransport",) diff --git a/google/cloud/errorreporting_v1beta1/types/common.py b/google/cloud/errorreporting_v1beta1/types/common.py index 94a29554..1fbc87c6 100644 --- a/google/cloud/errorreporting_v1beta1/types/common.py +++ b/google/cloud/errorreporting_v1beta1/types/common.py @@ -63,12 +63,24 @@ class ErrorGroup(proto.Message): interpreted as OPEN """ - name = proto.Field(proto.STRING, number=1,) - group_id = proto.Field(proto.STRING, number=2,) + name = proto.Field( + proto.STRING, + number=1, + ) + group_id = proto.Field( + proto.STRING, + number=2, + ) tracking_issues = proto.RepeatedField( - proto.MESSAGE, number=3, message="TrackingIssue", + proto.MESSAGE, + number=3, + message="TrackingIssue", + ) + resolution_status = proto.Field( + proto.ENUM, + number=5, + enum="ResolutionStatus", ) - resolution_status = proto.Field(proto.ENUM, number=5, enum="ResolutionStatus",) class TrackingIssue(proto.Message): @@ -82,7 +94,10 @@ class TrackingIssue(proto.Message): ``https://github.com/user/project/issues/4`` """ - url = proto.Field(proto.STRING, number=1,) + url = proto.Field( + proto.STRING, + number=1, + ) class ErrorEvent(proto.Message): @@ -105,10 +120,25 @@ class ErrorEvent(proto.Message): occurred. """ - event_time = proto.Field(proto.MESSAGE, number=1, message=timestamp_pb2.Timestamp,) - service_context = proto.Field(proto.MESSAGE, number=2, message="ServiceContext",) - message = proto.Field(proto.STRING, number=3,) - context = proto.Field(proto.MESSAGE, number=5, message="ErrorContext",) + event_time = proto.Field( + proto.MESSAGE, + number=1, + message=timestamp_pb2.Timestamp, + ) + service_context = proto.Field( + proto.MESSAGE, + number=2, + message="ServiceContext", + ) + message = proto.Field( + proto.STRING, + number=3, + ) + context = proto.Field( + proto.MESSAGE, + number=5, + message="ErrorContext", + ) class ServiceContext(proto.Message): @@ -141,9 +171,18 @@ class ServiceContext(proto.Message): and must not be set when reporting errors. """ - service = proto.Field(proto.STRING, number=2,) - version = proto.Field(proto.STRING, number=3,) - resource_type = proto.Field(proto.STRING, number=4,) + service = proto.Field( + proto.STRING, + number=2, + ) + version = proto.Field( + proto.STRING, + number=3, + ) + resource_type = proto.Field( + proto.STRING, + number=4, + ) class ErrorContext(proto.Message): @@ -174,9 +213,20 @@ class ErrorContext(proto.Message): place where it was caught. """ - http_request = proto.Field(proto.MESSAGE, number=1, message="HttpRequestContext",) - user = proto.Field(proto.STRING, number=2,) - report_location = proto.Field(proto.MESSAGE, number=3, message="SourceLocation",) + http_request = proto.Field( + proto.MESSAGE, + number=1, + message="HttpRequestContext", + ) + user = proto.Field( + proto.STRING, + number=2, + ) + report_location = proto.Field( + proto.MESSAGE, + number=3, + message="SourceLocation", + ) class HttpRequestContext(proto.Message): @@ -208,12 +258,30 @@ class HttpRequestContext(proto.Message): report. """ - method = proto.Field(proto.STRING, number=1,) - url = proto.Field(proto.STRING, number=2,) - user_agent = proto.Field(proto.STRING, number=3,) - referrer = proto.Field(proto.STRING, number=4,) - response_status_code = proto.Field(proto.INT32, number=5,) - remote_ip = proto.Field(proto.STRING, number=6,) + method = proto.Field( + proto.STRING, + number=1, + ) + url = proto.Field( + proto.STRING, + number=2, + ) + user_agent = proto.Field( + proto.STRING, + number=3, + ) + referrer = proto.Field( + proto.STRING, + number=4, + ) + response_status_code = proto.Field( + proto.INT32, + number=5, + ) + remote_ip = proto.Field( + proto.STRING, + number=6, + ) class SourceLocation(proto.Message): @@ -237,9 +305,18 @@ class SourceLocation(proto.Message): example, ``my.package.MyClass.method`` in case of Java. """ - file_path = proto.Field(proto.STRING, number=1,) - line_number = proto.Field(proto.INT32, number=2,) - function_name = proto.Field(proto.STRING, number=4,) + file_path = proto.Field( + proto.STRING, + number=1, + ) + line_number = proto.Field( + proto.INT32, + number=2, + ) + function_name = proto.Field( + proto.STRING, + number=4, + ) __all__ = tuple(sorted(__protobuf__.manifest)) diff --git a/google/cloud/errorreporting_v1beta1/types/error_group_service.py b/google/cloud/errorreporting_v1beta1/types/error_group_service.py index b6890500..f40ad9a9 100644 --- a/google/cloud/errorreporting_v1beta1/types/error_group_service.py +++ b/google/cloud/errorreporting_v1beta1/types/error_group_service.py @@ -20,7 +20,10 @@ __protobuf__ = proto.module( package="google.devtools.clouderrorreporting.v1beta1", - manifest={"GetGroupRequest", "UpdateGroupRequest",}, + manifest={ + "GetGroupRequest", + "UpdateGroupRequest", + }, ) @@ -37,7 +40,10 @@ class GetGroupRequest(proto.Message): Example: ``projects/my-project-123/groups/my-group`` """ - group_name = proto.Field(proto.STRING, number=1,) + group_name = proto.Field( + proto.STRING, + number=1, + ) class UpdateGroupRequest(proto.Message): @@ -49,7 +55,11 @@ class UpdateGroupRequest(proto.Message): resource on the server. """ - group = proto.Field(proto.MESSAGE, number=1, message=common.ErrorGroup,) + group = proto.Field( + proto.MESSAGE, + number=1, + message=common.ErrorGroup, + ) __all__ = tuple(sorted(__protobuf__.manifest)) diff --git a/google/cloud/errorreporting_v1beta1/types/error_stats_service.py b/google/cloud/errorreporting_v1beta1/types/error_stats_service.py index aaa57016..15615596 100644 --- a/google/cloud/errorreporting_v1beta1/types/error_stats_service.py +++ b/google/cloud/errorreporting_v1beta1/types/error_stats_service.py @@ -108,22 +108,52 @@ class ListGroupStatsRequest(proto.Message): with the identical query parameters as the first request. """ - project_name = proto.Field(proto.STRING, number=1,) - group_id = proto.RepeatedField(proto.STRING, number=2,) + project_name = proto.Field( + proto.STRING, + number=1, + ) + group_id = proto.RepeatedField( + proto.STRING, + number=2, + ) service_filter = proto.Field( - proto.MESSAGE, number=3, message="ServiceContextFilter", + proto.MESSAGE, + number=3, + message="ServiceContextFilter", + ) + time_range = proto.Field( + proto.MESSAGE, + number=5, + message="QueryTimeRange", ) - time_range = proto.Field(proto.MESSAGE, number=5, message="QueryTimeRange",) timed_count_duration = proto.Field( - proto.MESSAGE, number=6, message=duration_pb2.Duration, + proto.MESSAGE, + number=6, + message=duration_pb2.Duration, + ) + alignment = proto.Field( + proto.ENUM, + number=7, + enum="TimedCountAlignment", ) - alignment = proto.Field(proto.ENUM, number=7, enum="TimedCountAlignment",) alignment_time = proto.Field( - proto.MESSAGE, number=8, message=timestamp_pb2.Timestamp, + proto.MESSAGE, + number=8, + message=timestamp_pb2.Timestamp, + ) + order = proto.Field( + proto.ENUM, + number=9, + enum="ErrorGroupOrder", + ) + page_size = proto.Field( + proto.INT32, + number=11, + ) + page_token = proto.Field( + proto.STRING, + number=12, ) - order = proto.Field(proto.ENUM, number=9, enum="ErrorGroupOrder",) - page_size = proto.Field(proto.INT32, number=11,) - page_token = proto.Field(proto.STRING, number=12,) class ListGroupStatsResponse(proto.Message): @@ -152,11 +182,18 @@ def raw_page(self): return self error_group_stats = proto.RepeatedField( - proto.MESSAGE, number=1, message="ErrorGroupStats", + proto.MESSAGE, + number=1, + message="ErrorGroupStats", + ) + next_page_token = proto.Field( + proto.STRING, + number=2, ) - next_page_token = proto.Field(proto.STRING, number=2,) time_range_begin = proto.Field( - proto.MESSAGE, number=4, message=timestamp_pb2.Timestamp, + proto.MESSAGE, + number=4, + message=timestamp_pb2.Timestamp, ) @@ -217,21 +254,48 @@ class ErrorGroupStats(proto.Message): characteristics of the group as a whole. """ - group = proto.Field(proto.MESSAGE, number=1, message=common.ErrorGroup,) - count = proto.Field(proto.INT64, number=2,) - affected_users_count = proto.Field(proto.INT64, number=3,) - timed_counts = proto.RepeatedField(proto.MESSAGE, number=4, message="TimedCount",) + group = proto.Field( + proto.MESSAGE, + number=1, + message=common.ErrorGroup, + ) + count = proto.Field( + proto.INT64, + number=2, + ) + affected_users_count = proto.Field( + proto.INT64, + number=3, + ) + timed_counts = proto.RepeatedField( + proto.MESSAGE, + number=4, + message="TimedCount", + ) first_seen_time = proto.Field( - proto.MESSAGE, number=5, message=timestamp_pb2.Timestamp, + proto.MESSAGE, + number=5, + message=timestamp_pb2.Timestamp, ) last_seen_time = proto.Field( - proto.MESSAGE, number=6, message=timestamp_pb2.Timestamp, + proto.MESSAGE, + number=6, + message=timestamp_pb2.Timestamp, ) affected_services = proto.RepeatedField( - proto.MESSAGE, number=7, message=common.ServiceContext, + proto.MESSAGE, + number=7, + message=common.ServiceContext, + ) + num_affected_services = proto.Field( + proto.INT32, + number=8, + ) + representative = proto.Field( + proto.MESSAGE, + number=9, + message=common.ErrorEvent, ) - num_affected_services = proto.Field(proto.INT32, number=8,) - representative = proto.Field(proto.MESSAGE, number=9, message=common.ErrorEvent,) class TimedCount(proto.Message): @@ -250,9 +314,20 @@ class TimedCount(proto.Message): End of the time period to which ``count`` refers (excluded). """ - count = proto.Field(proto.INT64, number=1,) - start_time = proto.Field(proto.MESSAGE, number=2, message=timestamp_pb2.Timestamp,) - end_time = proto.Field(proto.MESSAGE, number=3, message=timestamp_pb2.Timestamp,) + count = proto.Field( + proto.INT64, + number=1, + ) + start_time = proto.Field( + proto.MESSAGE, + number=2, + message=timestamp_pb2.Timestamp, + ) + end_time = proto.Field( + proto.MESSAGE, + number=3, + message=timestamp_pb2.Timestamp, + ) class ListEventsRequest(proto.Message): @@ -287,14 +362,32 @@ class ListEventsRequest(proto.Message): response. """ - project_name = proto.Field(proto.STRING, number=1,) - group_id = proto.Field(proto.STRING, number=2,) + project_name = proto.Field( + proto.STRING, + number=1, + ) + group_id = proto.Field( + proto.STRING, + number=2, + ) service_filter = proto.Field( - proto.MESSAGE, number=3, message="ServiceContextFilter", + proto.MESSAGE, + number=3, + message="ServiceContextFilter", + ) + time_range = proto.Field( + proto.MESSAGE, + number=4, + message="QueryTimeRange", + ) + page_size = proto.Field( + proto.INT32, + number=6, + ) + page_token = proto.Field( + proto.STRING, + number=7, ) - time_range = proto.Field(proto.MESSAGE, number=4, message="QueryTimeRange",) - page_size = proto.Field(proto.INT32, number=6,) - page_token = proto.Field(proto.STRING, number=7,) class ListEventsResponse(proto.Message): @@ -319,11 +412,18 @@ def raw_page(self): return self error_events = proto.RepeatedField( - proto.MESSAGE, number=1, message=common.ErrorEvent, + proto.MESSAGE, + number=1, + message=common.ErrorEvent, + ) + next_page_token = proto.Field( + proto.STRING, + number=2, ) - next_page_token = proto.Field(proto.STRING, number=2,) time_range_begin = proto.Field( - proto.MESSAGE, number=4, message=timestamp_pb2.Timestamp, + proto.MESSAGE, + number=4, + message=timestamp_pb2.Timestamp, ) @@ -346,7 +446,11 @@ class Period(proto.Enum): PERIOD_1_WEEK = 4 PERIOD_30_DAYS = 5 - period = proto.Field(proto.ENUM, number=1, enum=Period,) + period = proto.Field( + proto.ENUM, + number=1, + enum=Period, + ) class ServiceContextFilter(proto.Message): @@ -367,9 +471,18 @@ class ServiceContextFilter(proto.Message): ```ServiceContext.resource_type`` `__. """ - service = proto.Field(proto.STRING, number=2,) - version = proto.Field(proto.STRING, number=3,) - resource_type = proto.Field(proto.STRING, number=4,) + service = proto.Field( + proto.STRING, + number=2, + ) + version = proto.Field( + proto.STRING, + number=3, + ) + resource_type = proto.Field( + proto.STRING, + number=4, + ) class DeleteEventsRequest(proto.Message): @@ -385,12 +498,14 @@ class DeleteEventsRequest(proto.Message): Example: ``projects/my-project-123``. """ - project_name = proto.Field(proto.STRING, number=1,) + project_name = proto.Field( + proto.STRING, + number=1, + ) class DeleteEventsResponse(proto.Message): - r"""Response message for deleting error events. - """ + r"""Response message for deleting error events.""" __all__ = tuple(sorted(__protobuf__.manifest)) diff --git a/google/cloud/errorreporting_v1beta1/types/report_errors_service.py b/google/cloud/errorreporting_v1beta1/types/report_errors_service.py index 17f7de99..22b901a4 100644 --- a/google/cloud/errorreporting_v1beta1/types/report_errors_service.py +++ b/google/cloud/errorreporting_v1beta1/types/report_errors_service.py @@ -44,8 +44,15 @@ class ReportErrorEventRequest(proto.Message): Required. The error event to be reported. """ - project_name = proto.Field(proto.STRING, number=1,) - event = proto.Field(proto.MESSAGE, number=2, message="ReportedErrorEvent",) + project_name = proto.Field( + proto.STRING, + number=1, + ) + event = proto.Field( + proto.MESSAGE, + number=2, + message="ReportedErrorEvent", + ) class ReportErrorEventResponse(proto.Message): @@ -99,12 +106,25 @@ class ReportedErrorEvent(proto.Message): which the error occurred. """ - event_time = proto.Field(proto.MESSAGE, number=1, message=timestamp_pb2.Timestamp,) + event_time = proto.Field( + proto.MESSAGE, + number=1, + message=timestamp_pb2.Timestamp, + ) service_context = proto.Field( - proto.MESSAGE, number=2, message=common.ServiceContext, + proto.MESSAGE, + number=2, + message=common.ServiceContext, + ) + message = proto.Field( + proto.STRING, + number=3, + ) + context = proto.Field( + proto.MESSAGE, + number=4, + message=common.ErrorContext, ) - message = proto.Field(proto.STRING, number=3,) - context = proto.Field(proto.MESSAGE, number=4, message=common.ErrorContext,) __all__ = tuple(sorted(__protobuf__.manifest)) diff --git a/noxfile.py b/noxfile.py index 2a2001c4..6ee5e8ab 100644 --- a/noxfile.py +++ b/noxfile.py @@ -20,16 +20,40 @@ import os import pathlib import shutil +import warnings import nox - -BLACK_VERSION = "black==19.10b0" +BLACK_VERSION = "black==22.3.0" BLACK_PATHS = ["docs", "google", "tests", "noxfile.py", "setup.py"] DEFAULT_PYTHON_VERSION = "3.8" -SYSTEM_TEST_PYTHON_VERSIONS = ["3.8"] + UNIT_TEST_PYTHON_VERSIONS = ["3.6", "3.7", "3.8", "3.9", "3.10"] +UNIT_TEST_STANDARD_DEPENDENCIES = [ + "mock", + "asyncmock", + "pytest", + "pytest-cov", + "pytest-asyncio", +] +UNIT_TEST_EXTERNAL_DEPENDENCIES = [] +UNIT_TEST_LOCAL_DEPENDENCIES = [] +UNIT_TEST_DEPENDENCIES = [] +UNIT_TEST_EXTRAS = [] +UNIT_TEST_EXTRAS_BY_PYTHON = {} + +SYSTEM_TEST_PYTHON_VERSIONS = ["3.8"] +SYSTEM_TEST_STANDARD_DEPENDENCIES = [ + "mock", + "pytest", + "google-cloud-testutils", +] +SYSTEM_TEST_EXTERNAL_DEPENDENCIES = [] +SYSTEM_TEST_LOCAL_DEPENDENCIES = [] +SYSTEM_TEST_DEPENDENCIES = [] +SYSTEM_TEST_EXTRAS = [] +SYSTEM_TEST_EXTRAS_BY_PYTHON = {} CURRENT_DIRECTORY = pathlib.Path(__file__).parent.absolute() @@ -57,7 +81,9 @@ def lint(session): """ session.install("flake8", BLACK_VERSION) session.run( - "black", "--check", *BLACK_PATHS, + "black", + "--check", + *BLACK_PATHS, ) session.run("flake8", "google", "tests") @@ -67,7 +93,8 @@ def blacken(session): """Run black. Format code to uniform standard.""" session.install(BLACK_VERSION) session.run( - "black", *BLACK_PATHS, + "black", + *BLACK_PATHS, ) @@ -78,23 +105,41 @@ def lint_setup_py(session): session.run("python", "setup.py", "check", "--restructuredtext", "--strict") +def install_unittest_dependencies(session, *constraints): + standard_deps = UNIT_TEST_STANDARD_DEPENDENCIES + UNIT_TEST_DEPENDENCIES + session.install(*standard_deps, *constraints) + + if UNIT_TEST_EXTERNAL_DEPENDENCIES: + warnings.warn( + "'unit_test_external_dependencies' is deprecated. Instead, please " + "use 'unit_test_dependencies' or 'unit_test_local_dependencies'.", + DeprecationWarning, + ) + session.install(*UNIT_TEST_EXTERNAL_DEPENDENCIES, *constraints) + + if UNIT_TEST_LOCAL_DEPENDENCIES: + session.install(*UNIT_TEST_LOCAL_DEPENDENCIES, *constraints) + + if UNIT_TEST_EXTRAS_BY_PYTHON: + extras = UNIT_TEST_EXTRAS_BY_PYTHON.get(session.python, []) + elif UNIT_TEST_EXTRAS: + extras = UNIT_TEST_EXTRAS + else: + extras = [] + + if extras: + session.install("-e", f".[{','.join(extras)}]", *constraints) + else: + session.install("-e", ".", *constraints) + + def default(session): # Install all test dependencies, then install this package in-place. constraints_path = str( CURRENT_DIRECTORY / "testing" / f"constraints-{session.python}.txt" ) - session.install( - "mock", - "asyncmock", - "pytest", - "pytest-cov", - "pytest-asyncio", - "-c", - constraints_path, - ) - - session.install("-e", ".", "-c", constraints_path) + install_unittest_dependencies(session, "-c", constraints_path) # Run py.test against the unit tests. session.run( @@ -118,6 +163,35 @@ def unit(session): default(session) +def install_systemtest_dependencies(session, *constraints): + + # Use pre-release gRPC for system tests. + session.install("--pre", "grpcio") + + session.install(*SYSTEM_TEST_STANDARD_DEPENDENCIES, *constraints) + + if SYSTEM_TEST_EXTERNAL_DEPENDENCIES: + session.install(*SYSTEM_TEST_EXTERNAL_DEPENDENCIES, *constraints) + + if SYSTEM_TEST_LOCAL_DEPENDENCIES: + session.install("-e", *SYSTEM_TEST_LOCAL_DEPENDENCIES, *constraints) + + if SYSTEM_TEST_DEPENDENCIES: + session.install("-e", *SYSTEM_TEST_DEPENDENCIES, *constraints) + + if SYSTEM_TEST_EXTRAS_BY_PYTHON: + extras = SYSTEM_TEST_EXTRAS_BY_PYTHON.get(session.python, []) + elif SYSTEM_TEST_EXTRAS: + extras = SYSTEM_TEST_EXTRAS + else: + extras = [] + + if extras: + session.install("-e", f".[{','.join(extras)}]", *constraints) + else: + session.install("-e", ".", *constraints) + + @nox.session(python=SYSTEM_TEST_PYTHON_VERSIONS) def system(session): """Run the system test suite.""" @@ -140,13 +214,7 @@ def system(session): if not system_test_exists and not system_test_folder_exists: session.skip("System tests were not found") - # Use pre-release gRPC for system tests. - session.install("--pre", "grpcio") - - # Install all test dependencies, then install this package into the - # virtualenv's dist-packages. - session.install("mock", "pytest", "google-cloud-testutils", "-c", constraints_path) - session.install("-e", ".", "-c", constraints_path) + install_systemtest_dependencies(session, "-c", constraints_path) # Run py.test against the system tests. if system_test_exists: diff --git a/owlbot.py b/owlbot.py index a2f17a66..5bc3f034 100644 --- a/owlbot.py +++ b/owlbot.py @@ -34,13 +34,14 @@ microgenerator=True, cov_level=100, ) -s.move(templated_files, excludes=[".coveragerc"]) # microgenerator has a good .coveragerc file +s.move(templated_files, excludes=[".coveragerc", ".github/auto-label.yaml"]) # microgenerator has a good .coveragerc file # ---------------------------------------------------------------------------- # Samples templates # ---------------------------------------------------------------------------- python.py_samples(skip_readmes=True) +python.configure_previous_major_version_branches() s.shell.run(["nox", "-s", "blacken"], hide_output=False) diff --git a/samples/generated_samples/snippet_metadata_errorreporting_v1beta1.json b/samples/generated_samples/snippet_metadata_errorreporting_v1beta1.json index b493c226..6b5f5926 100644 --- a/samples/generated_samples/snippet_metadata_errorreporting_v1beta1.json +++ b/samples/generated_samples/snippet_metadata_errorreporting_v1beta1.json @@ -1,16 +1,61 @@ { + "clientLibrary": { + "apis": [ + { + "id": "google.devtools.clouderrorreporting.v1beta1", + "version": "v1beta1" + } + ], + "language": "PYTHON", + "name": "google-cloud-errorreporting" + }, "snippets": [ { + "canonical": true, "clientMethod": { "async": true, + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorGroupServiceAsyncClient", + "shortName": "ErrorGroupServiceAsyncClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorGroupServiceAsyncClient.get_group", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorGroupService.GetGroup", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorGroupService", "shortName": "ErrorGroupService" }, "shortName": "GetGroup" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.GetGroupRequest" + }, + { + "name": "group_name", + "type": "str" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.types.ErrorGroup", + "shortName": "get_group" }, + "description": "Sample for GetGroup", "file": "clouderrorreporting_v1beta1_generated_error_group_service_get_group_async.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorGroupService_GetGroup_async", "segments": [ { @@ -43,18 +88,54 @@ "start": 42, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_group_service_get_group_async.py" }, { + "canonical": true, "clientMethod": { + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorGroupServiceClient", + "shortName": "ErrorGroupServiceClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorGroupServiceClient.get_group", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorGroupService.GetGroup", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorGroupService", "shortName": "ErrorGroupService" }, "shortName": "GetGroup" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.GetGroupRequest" + }, + { + "name": "group_name", + "type": "str" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.types.ErrorGroup", + "shortName": "get_group" }, + "description": "Sample for GetGroup", "file": "clouderrorreporting_v1beta1_generated_error_group_service_get_group_sync.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorGroupService_GetGroup_sync", "segments": [ { @@ -87,19 +168,55 @@ "start": 42, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_group_service_get_group_sync.py" }, { + "canonical": true, "clientMethod": { "async": true, + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorGroupServiceAsyncClient", + "shortName": "ErrorGroupServiceAsyncClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorGroupServiceAsyncClient.update_group", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorGroupService.UpdateGroup", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorGroupService", "shortName": "ErrorGroupService" }, "shortName": "UpdateGroup" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.UpdateGroupRequest" + }, + { + "name": "group", + "type": "google.cloud.errorreporting_v1beta1.types.ErrorGroup" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.types.ErrorGroup", + "shortName": "update_group" }, + "description": "Sample for UpdateGroup", "file": "clouderrorreporting_v1beta1_generated_error_group_service_update_group_async.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorGroupService_UpdateGroup_async", "segments": [ { @@ -132,18 +249,54 @@ "start": 41, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_group_service_update_group_async.py" }, { + "canonical": true, "clientMethod": { + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorGroupServiceClient", + "shortName": "ErrorGroupServiceClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorGroupServiceClient.update_group", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorGroupService.UpdateGroup", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorGroupService", "shortName": "ErrorGroupService" }, "shortName": "UpdateGroup" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.UpdateGroupRequest" + }, + { + "name": "group", + "type": "google.cloud.errorreporting_v1beta1.types.ErrorGroup" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.types.ErrorGroup", + "shortName": "update_group" }, + "description": "Sample for UpdateGroup", "file": "clouderrorreporting_v1beta1_generated_error_group_service_update_group_sync.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorGroupService_UpdateGroup_sync", "segments": [ { @@ -176,19 +329,55 @@ "start": 41, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_group_service_update_group_sync.py" }, { + "canonical": true, "clientMethod": { "async": true, + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceAsyncClient", + "shortName": "ErrorStatsServiceAsyncClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceAsyncClient.delete_events", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService.DeleteEvents", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService", "shortName": "ErrorStatsService" }, "shortName": "DeleteEvents" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.DeleteEventsRequest" + }, + { + "name": "project_name", + "type": "str" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.types.DeleteEventsResponse", + "shortName": "delete_events" }, + "description": "Sample for DeleteEvents", "file": "clouderrorreporting_v1beta1_generated_error_stats_service_delete_events_async.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorStatsService_DeleteEvents_async", "segments": [ { @@ -221,18 +410,54 @@ "start": 42, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_stats_service_delete_events_async.py" }, { + "canonical": true, "clientMethod": { + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceClient", + "shortName": "ErrorStatsServiceClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceClient.delete_events", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService.DeleteEvents", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService", "shortName": "ErrorStatsService" }, "shortName": "DeleteEvents" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.DeleteEventsRequest" + }, + { + "name": "project_name", + "type": "str" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.types.DeleteEventsResponse", + "shortName": "delete_events" }, + "description": "Sample for DeleteEvents", "file": "clouderrorreporting_v1beta1_generated_error_stats_service_delete_events_sync.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorStatsService_DeleteEvents_sync", "segments": [ { @@ -265,19 +490,59 @@ "start": 42, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_stats_service_delete_events_sync.py" }, { + "canonical": true, "clientMethod": { "async": true, + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceAsyncClient", + "shortName": "ErrorStatsServiceAsyncClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceAsyncClient.list_events", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService.ListEvents", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService", "shortName": "ErrorStatsService" }, "shortName": "ListEvents" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.ListEventsRequest" + }, + { + "name": "project_name", + "type": "str" + }, + { + "name": "group_id", + "type": "str" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.services.error_stats_service.pagers.ListEventsAsyncPager", + "shortName": "list_events" }, + "description": "Sample for ListEvents", "file": "clouderrorreporting_v1beta1_generated_error_stats_service_list_events_async.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorStatsService_ListEvents_async", "segments": [ { @@ -310,18 +575,58 @@ "start": 43, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_stats_service_list_events_async.py" }, { + "canonical": true, "clientMethod": { + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceClient", + "shortName": "ErrorStatsServiceClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceClient.list_events", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService.ListEvents", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService", "shortName": "ErrorStatsService" }, "shortName": "ListEvents" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.ListEventsRequest" + }, + { + "name": "project_name", + "type": "str" + }, + { + "name": "group_id", + "type": "str" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.services.error_stats_service.pagers.ListEventsPager", + "shortName": "list_events" }, + "description": "Sample for ListEvents", "file": "clouderrorreporting_v1beta1_generated_error_stats_service_list_events_sync.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorStatsService_ListEvents_sync", "segments": [ { @@ -354,19 +659,59 @@ "start": 43, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_stats_service_list_events_sync.py" }, { + "canonical": true, "clientMethod": { "async": true, + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceAsyncClient", + "shortName": "ErrorStatsServiceAsyncClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceAsyncClient.list_group_stats", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService.ListGroupStats", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService", "shortName": "ErrorStatsService" }, "shortName": "ListGroupStats" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.ListGroupStatsRequest" + }, + { + "name": "project_name", + "type": "str" + }, + { + "name": "time_range", + "type": "google.cloud.errorreporting_v1beta1.types.QueryTimeRange" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.services.error_stats_service.pagers.ListGroupStatsAsyncPager", + "shortName": "list_group_stats" }, + "description": "Sample for ListGroupStats", "file": "clouderrorreporting_v1beta1_generated_error_stats_service_list_group_stats_async.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorStatsService_ListGroupStats_async", "segments": [ { @@ -399,18 +744,58 @@ "start": 42, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_stats_service_list_group_stats_async.py" }, { + "canonical": true, "clientMethod": { + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceClient", + "shortName": "ErrorStatsServiceClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ErrorStatsServiceClient.list_group_stats", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService.ListGroupStats", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ErrorStatsService", "shortName": "ErrorStatsService" }, "shortName": "ListGroupStats" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.ListGroupStatsRequest" + }, + { + "name": "project_name", + "type": "str" + }, + { + "name": "time_range", + "type": "google.cloud.errorreporting_v1beta1.types.QueryTimeRange" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.services.error_stats_service.pagers.ListGroupStatsPager", + "shortName": "list_group_stats" }, + "description": "Sample for ListGroupStats", "file": "clouderrorreporting_v1beta1_generated_error_stats_service_list_group_stats_sync.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ErrorStatsService_ListGroupStats_sync", "segments": [ { @@ -443,19 +828,59 @@ "start": 42, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_error_stats_service_list_group_stats_sync.py" }, { + "canonical": true, "clientMethod": { "async": true, + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ReportErrorsServiceAsyncClient", + "shortName": "ReportErrorsServiceAsyncClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ReportErrorsServiceAsyncClient.report_error_event", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ReportErrorsService.ReportErrorEvent", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ReportErrorsService", "shortName": "ReportErrorsService" }, "shortName": "ReportErrorEvent" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.ReportErrorEventRequest" + }, + { + "name": "project_name", + "type": "str" + }, + { + "name": "event", + "type": "google.cloud.errorreporting_v1beta1.types.ReportedErrorEvent" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.types.ReportErrorEventResponse", + "shortName": "report_error_event" }, + "description": "Sample for ReportErrorEvent", "file": "clouderrorreporting_v1beta1_generated_report_errors_service_report_error_event_async.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ReportErrorsService_ReportErrorEvent_async", "segments": [ { @@ -488,18 +913,58 @@ "start": 46, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_report_errors_service_report_error_event_async.py" }, { + "canonical": true, "clientMethod": { + "client": { + "fullName": "google.cloud.errorreporting_v1beta1.ReportErrorsServiceClient", + "shortName": "ReportErrorsServiceClient" + }, + "fullName": "google.cloud.errorreporting_v1beta1.ReportErrorsServiceClient.report_error_event", "method": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ReportErrorsService.ReportErrorEvent", "service": { + "fullName": "google.devtools.clouderrorreporting.v1beta1.ReportErrorsService", "shortName": "ReportErrorsService" }, "shortName": "ReportErrorEvent" - } + }, + "parameters": [ + { + "name": "request", + "type": "google.cloud.errorreporting_v1beta1.types.ReportErrorEventRequest" + }, + { + "name": "project_name", + "type": "str" + }, + { + "name": "event", + "type": "google.cloud.errorreporting_v1beta1.types.ReportedErrorEvent" + }, + { + "name": "retry", + "type": "google.api_core.retry.Retry" + }, + { + "name": "timeout", + "type": "float" + }, + { + "name": "metadata", + "type": "Sequence[Tuple[str, str]" + } + ], + "resultType": "google.cloud.errorreporting_v1beta1.types.ReportErrorEventResponse", + "shortName": "report_error_event" }, + "description": "Sample for ReportErrorEvent", "file": "clouderrorreporting_v1beta1_generated_report_errors_service_report_error_event_sync.py", + "language": "PYTHON", + "origin": "API_DEFINITION", "regionTag": "clouderrorreporting_v1beta1_generated_ReportErrorsService_ReportErrorEvent_sync", "segments": [ { @@ -532,7 +997,8 @@ "start": 46, "type": "RESPONSE_HANDLING" } - ] + ], + "title": "clouderrorreporting_v1beta1_generated_report_errors_service_report_error_event_sync.py" } ] } diff --git a/samples/snippets/api/noxfile.py b/samples/snippets/api/noxfile.py index 4c808af7..949e0fde 100644 --- a/samples/snippets/api/noxfile.py +++ b/samples/snippets/api/noxfile.py @@ -29,7 +29,7 @@ # WARNING - WARNING - WARNING - WARNING - WARNING # WARNING - WARNING - WARNING - WARNING - WARNING -BLACK_VERSION = "black==19.10b0" +BLACK_VERSION = "black==22.3.0" # Copy `noxfile_config.py` to your directory and modify it instead. diff --git a/samples/snippets/api/requirements-test.txt b/samples/snippets/api/requirements-test.txt index c2845bff..4f6bf643 100644 --- a/samples/snippets/api/requirements-test.txt +++ b/samples/snippets/api/requirements-test.txt @@ -1 +1 @@ -pytest==7.0.1 +pytest==7.1.1 diff --git a/samples/snippets/api/requirements.txt b/samples/snippets/api/requirements.txt index 774b773e..285dc70c 100644 --- a/samples/snippets/api/requirements.txt +++ b/samples/snippets/api/requirements.txt @@ -1 +1 @@ -google-cloud-error-reporting==1.5.0 +google-cloud-error-reporting==1.5.1 diff --git a/samples/snippets/fluent_on_compute/noxfile.py b/samples/snippets/fluent_on_compute/noxfile.py index 4c808af7..949e0fde 100644 --- a/samples/snippets/fluent_on_compute/noxfile.py +++ b/samples/snippets/fluent_on_compute/noxfile.py @@ -29,7 +29,7 @@ # WARNING - WARNING - WARNING - WARNING - WARNING # WARNING - WARNING - WARNING - WARNING - WARNING -BLACK_VERSION = "black==19.10b0" +BLACK_VERSION = "black==22.3.0" # Copy `noxfile_config.py` to your directory and modify it instead. diff --git a/samples/snippets/fluent_on_compute/requirements-test.txt b/samples/snippets/fluent_on_compute/requirements-test.txt index 4bd417eb..5e29de93 100644 --- a/samples/snippets/fluent_on_compute/requirements-test.txt +++ b/samples/snippets/fluent_on_compute/requirements-test.txt @@ -1,2 +1,2 @@ -pytest==7.0.1 +pytest==7.1.1 mock==4.0.3 diff --git a/setup.py b/setup.py index 9dc541c2..a2a137e0 100644 --- a/setup.py +++ b/setup.py @@ -22,7 +22,7 @@ name = "google-cloud-error-reporting" description = "Error Reporting API client library" -version = "1.5.1" +version = "1.5.2" # Should be one of: # 'Development Status :: 3 - Alpha' # 'Development Status :: 4 - Beta' diff --git a/tests/unit/gapic/errorreporting_v1beta1/test_error_group_service.py b/tests/unit/gapic/errorreporting_v1beta1/test_error_group_service.py index 09d3652a..a9dce8c8 100644 --- a/tests/unit/gapic/errorreporting_v1beta1/test_error_group_service.py +++ b/tests/unit/gapic/errorreporting_v1beta1/test_error_group_service.py @@ -90,20 +90,26 @@ def test__get_default_mtls_endpoint(): @pytest.mark.parametrize( - "client_class", [ErrorGroupServiceClient, ErrorGroupServiceAsyncClient,] + "client_class,transport_name", + [ + (ErrorGroupServiceClient, "grpc"), + (ErrorGroupServiceAsyncClient, "grpc_asyncio"), + ], ) -def test_error_group_service_client_from_service_account_info(client_class): +def test_error_group_service_client_from_service_account_info( + client_class, transport_name +): creds = ga_credentials.AnonymousCredentials() with mock.patch.object( service_account.Credentials, "from_service_account_info" ) as factory: factory.return_value = creds info = {"valid": True} - client = client_class.from_service_account_info(info) + client = client_class.from_service_account_info(info, transport=transport_name) assert client.transport._credentials == creds assert isinstance(client, client_class) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") @pytest.mark.parametrize( @@ -132,23 +138,33 @@ def test_error_group_service_client_service_account_always_use_jwt( @pytest.mark.parametrize( - "client_class", [ErrorGroupServiceClient, ErrorGroupServiceAsyncClient,] + "client_class,transport_name", + [ + (ErrorGroupServiceClient, "grpc"), + (ErrorGroupServiceAsyncClient, "grpc_asyncio"), + ], ) -def test_error_group_service_client_from_service_account_file(client_class): +def test_error_group_service_client_from_service_account_file( + client_class, transport_name +): creds = ga_credentials.AnonymousCredentials() with mock.patch.object( service_account.Credentials, "from_service_account_file" ) as factory: factory.return_value = creds - client = client_class.from_service_account_file("dummy/file/path.json") + client = client_class.from_service_account_file( + "dummy/file/path.json", transport=transport_name + ) assert client.transport._credentials == creds assert isinstance(client, client_class) - client = client_class.from_service_account_json("dummy/file/path.json") + client = client_class.from_service_account_json( + "dummy/file/path.json", transport=transport_name + ) assert client.transport._credentials == creds assert isinstance(client, client_class) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") def test_error_group_service_client_get_transport_class(): @@ -506,7 +522,9 @@ def test_error_group_service_client_client_options_scopes( client_class, transport_class, transport_name ): # Check the case scopes are provided. - options = client_options.ClientOptions(scopes=["1", "2"],) + options = client_options.ClientOptions( + scopes=["1", "2"], + ) with mock.patch.object(transport_class, "__init__") as patched: patched.return_value = None client = client_class(client_options=options, transport=transport_name) @@ -646,10 +664,17 @@ def test_error_group_service_client_create_channel_credentials_file( ) -@pytest.mark.parametrize("request_type", [error_group_service.GetGroupRequest, dict,]) +@pytest.mark.parametrize( + "request_type", + [ + error_group_service.GetGroupRequest, + dict, + ], +) def test_get_group(request_type, transport: str = "grpc"): client = ErrorGroupServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -682,7 +707,8 @@ def test_get_group_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 = ErrorGroupServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc", ) # Mock the actual call within the gRPC stub, and fake the request. @@ -698,7 +724,8 @@ async def test_get_group_async( transport: str = "grpc_asyncio", request_type=error_group_service.GetGroupRequest ): client = ErrorGroupServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -735,7 +762,9 @@ async def test_get_group_async_from_dict(): def test_get_group_field_headers(): - client = ErrorGroupServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorGroupServiceClient( + credentials=ga_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. @@ -755,7 +784,10 @@ def test_get_group_field_headers(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "group_name=group_name/value",) in kw["metadata"] + assert ( + "x-goog-request-params", + "group_name=group_name/value", + ) in kw["metadata"] @pytest.mark.asyncio @@ -782,11 +814,16 @@ async def test_get_group_field_headers_async(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "group_name=group_name/value",) in kw["metadata"] + assert ( + "x-goog-request-params", + "group_name=group_name/value", + ) in kw["metadata"] def test_get_group_flattened(): - client = ErrorGroupServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorGroupServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.get_group), "__call__") as call: @@ -794,7 +831,9 @@ def test_get_group_flattened(): call.return_value = common.ErrorGroup() # Call the method with a truthy value for each flattened field, # using the keyword arguments to the method. - client.get_group(group_name="group_name_value",) + client.get_group( + group_name="group_name_value", + ) # Establish that the underlying call was made with the expected # request object values. @@ -806,13 +845,16 @@ def test_get_group_flattened(): def test_get_group_flattened_error(): - client = ErrorGroupServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorGroupServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Attempting to call a method with both a request object and flattened # fields is an error. with pytest.raises(ValueError): client.get_group( - error_group_service.GetGroupRequest(), group_name="group_name_value", + error_group_service.GetGroupRequest(), + group_name="group_name_value", ) @@ -830,7 +872,9 @@ async def test_get_group_flattened_async(): call.return_value = grpc_helpers_async.FakeUnaryUnaryCall(common.ErrorGroup()) # Call the method with a truthy value for each flattened field, # using the keyword arguments to the method. - response = await client.get_group(group_name="group_name_value",) + response = await client.get_group( + group_name="group_name_value", + ) # Establish that the underlying call was made with the expected # request object values. @@ -851,16 +895,22 @@ async def test_get_group_flattened_error_async(): # fields is an error. with pytest.raises(ValueError): await client.get_group( - error_group_service.GetGroupRequest(), group_name="group_name_value", + error_group_service.GetGroupRequest(), + group_name="group_name_value", ) @pytest.mark.parametrize( - "request_type", [error_group_service.UpdateGroupRequest, dict,] + "request_type", + [ + error_group_service.UpdateGroupRequest, + dict, + ], ) def test_update_group(request_type, transport: str = "grpc"): client = ErrorGroupServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -893,7 +943,8 @@ def test_update_group_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 = ErrorGroupServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc", ) # Mock the actual call within the gRPC stub, and fake the request. @@ -909,7 +960,8 @@ async def test_update_group_async( transport: str = "grpc_asyncio", request_type=error_group_service.UpdateGroupRequest ): client = ErrorGroupServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -946,7 +998,9 @@ async def test_update_group_async_from_dict(): def test_update_group_field_headers(): - client = ErrorGroupServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorGroupServiceClient( + credentials=ga_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. @@ -966,7 +1020,10 @@ def test_update_group_field_headers(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "group.name=group.name/value",) in kw["metadata"] + assert ( + "x-goog-request-params", + "group.name=group.name/value", + ) in kw["metadata"] @pytest.mark.asyncio @@ -993,11 +1050,16 @@ async def test_update_group_field_headers_async(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "group.name=group.name/value",) in kw["metadata"] + assert ( + "x-goog-request-params", + "group.name=group.name/value", + ) in kw["metadata"] def test_update_group_flattened(): - client = ErrorGroupServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorGroupServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.update_group), "__call__") as call: @@ -1005,7 +1067,9 @@ def test_update_group_flattened(): call.return_value = common.ErrorGroup() # Call the method with a truthy value for each flattened field, # using the keyword arguments to the method. - client.update_group(group=common.ErrorGroup(name="name_value"),) + client.update_group( + group=common.ErrorGroup(name="name_value"), + ) # Establish that the underlying call was made with the expected # request object values. @@ -1017,7 +1081,9 @@ def test_update_group_flattened(): def test_update_group_flattened_error(): - client = ErrorGroupServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorGroupServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Attempting to call a method with both a request object and flattened # fields is an error. @@ -1077,7 +1143,8 @@ def test_credentials_transport_error(): ) with pytest.raises(ValueError): client = ErrorGroupServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # It is an error to provide a credentials file and a transport instance. @@ -1097,7 +1164,10 @@ def test_credentials_transport_error(): options = client_options.ClientOptions() options.api_key = "api_key" with pytest.raises(ValueError): - client = ErrorGroupServiceClient(client_options=options, transport=transport,) + client = ErrorGroupServiceClient( + client_options=options, + transport=transport, + ) # It is an error to provide an api_key and a credential. options = mock.Mock() @@ -1113,7 +1183,8 @@ def test_credentials_transport_error(): ) with pytest.raises(ValueError): client = ErrorGroupServiceClient( - client_options={"scopes": ["1", "2"]}, transport=transport, + client_options={"scopes": ["1", "2"]}, + transport=transport, ) @@ -1156,10 +1227,28 @@ def test_transport_adc(transport_class): adc.assert_called_once() +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + ], +) +def test_transport_kind(transport_name): + transport = ErrorGroupServiceClient.get_transport_class(transport_name)( + credentials=ga_credentials.AnonymousCredentials(), + ) + assert transport.kind == transport_name + + def test_transport_grpc_default(): # A client should use the gRPC transport by default. - client = ErrorGroupServiceClient(credentials=ga_credentials.AnonymousCredentials(),) - assert isinstance(client.transport, transports.ErrorGroupServiceGrpcTransport,) + client = ErrorGroupServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) + assert isinstance( + client.transport, + transports.ErrorGroupServiceGrpcTransport, + ) def test_error_group_service_base_transport_error(): @@ -1194,6 +1283,14 @@ def test_error_group_service_base_transport(): with pytest.raises(NotImplementedError): transport.close() + # Catch all for all remaining methods and properties + remainder = [ + "kind", + ] + for r in remainder: + with pytest.raises(NotImplementedError): + getattr(transport, r)() + def test_error_group_service_base_transport_with_credentials_file(): # Instantiate the base transport with a credentials file @@ -1205,7 +1302,8 @@ def test_error_group_service_base_transport_with_credentials_file(): Transport.return_value = None load_creds.return_value = (ga_credentials.AnonymousCredentials(), None) transport = transports.ErrorGroupServiceTransport( - credentials_file="credentials.json", quota_project_id="octopus", + credentials_file="credentials.json", + quota_project_id="octopus", ) load_creds.assert_called_once_with( "credentials.json", @@ -1340,24 +1438,40 @@ def test_error_group_service_grpc_transport_client_cert_source_for_mtls( ) -def test_error_group_service_host_no_port(): +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + "grpc_asyncio", + ], +) +def test_error_group_service_host_no_port(transport_name): client = ErrorGroupServiceClient( credentials=ga_credentials.AnonymousCredentials(), client_options=client_options.ClientOptions( api_endpoint="clouderrorreporting.googleapis.com" ), + transport=transport_name, ) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") -def test_error_group_service_host_with_port(): +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + "grpc_asyncio", + ], +) +def test_error_group_service_host_with_port(transport_name): client = ErrorGroupServiceClient( credentials=ga_credentials.AnonymousCredentials(), client_options=client_options.ClientOptions( api_endpoint="clouderrorreporting.googleapis.com:8000" ), + transport=transport_name, ) - assert client.transport._host == "clouderrorreporting.googleapis.com:8000" + assert client.transport._host == ("clouderrorreporting.googleapis.com:8000") def test_error_group_service_grpc_transport_channel(): @@ -1365,7 +1479,8 @@ def test_error_group_service_grpc_transport_channel(): # Check that channel is used if provided. transport = transports.ErrorGroupServiceGrpcTransport( - host="squid.clam.whelk", channel=channel, + host="squid.clam.whelk", + channel=channel, ) assert transport.grpc_channel == channel assert transport._host == "squid.clam.whelk:443" @@ -1377,7 +1492,8 @@ def test_error_group_service_grpc_asyncio_transport_channel(): # Check that channel is used if provided. transport = transports.ErrorGroupServiceGrpcAsyncIOTransport( - host="squid.clam.whelk", channel=channel, + host="squid.clam.whelk", + channel=channel, ) assert transport.grpc_channel == channel assert transport._host == "squid.clam.whelk:443" @@ -1487,7 +1603,10 @@ def test_error_group_service_transport_channel_mtls_with_adc(transport_class): def test_error_group_path(): project = "squid" group = "clam" - expected = "projects/{project}/groups/{group}".format(project=project, group=group,) + expected = "projects/{project}/groups/{group}".format( + project=project, + group=group, + ) actual = ErrorGroupServiceClient.error_group_path(project, group) assert expected == actual @@ -1526,7 +1645,9 @@ def test_parse_common_billing_account_path(): def test_common_folder_path(): folder = "cuttlefish" - expected = "folders/{folder}".format(folder=folder,) + expected = "folders/{folder}".format( + folder=folder, + ) actual = ErrorGroupServiceClient.common_folder_path(folder) assert expected == actual @@ -1544,7 +1665,9 @@ def test_parse_common_folder_path(): def test_common_organization_path(): organization = "winkle" - expected = "organizations/{organization}".format(organization=organization,) + expected = "organizations/{organization}".format( + organization=organization, + ) actual = ErrorGroupServiceClient.common_organization_path(organization) assert expected == actual @@ -1562,7 +1685,9 @@ def test_parse_common_organization_path(): def test_common_project_path(): project = "scallop" - expected = "projects/{project}".format(project=project,) + expected = "projects/{project}".format( + project=project, + ) actual = ErrorGroupServiceClient.common_project_path(project) assert expected == actual @@ -1582,7 +1707,8 @@ def test_common_location_path(): project = "squid" location = "clam" expected = "projects/{project}/locations/{location}".format( - project=project, location=location, + project=project, + location=location, ) actual = ErrorGroupServiceClient.common_location_path(project, location) assert expected == actual @@ -1607,7 +1733,8 @@ def test_client_with_default_client_info(): transports.ErrorGroupServiceTransport, "_prep_wrapped_messages" ) as prep: client = ErrorGroupServiceClient( - credentials=ga_credentials.AnonymousCredentials(), client_info=client_info, + credentials=ga_credentials.AnonymousCredentials(), + client_info=client_info, ) prep.assert_called_once_with(client_info) @@ -1616,7 +1743,8 @@ def test_client_with_default_client_info(): ) as prep: transport_class = ErrorGroupServiceClient.get_transport_class() transport = transport_class( - credentials=ga_credentials.AnonymousCredentials(), client_info=client_info, + credentials=ga_credentials.AnonymousCredentials(), + client_info=client_info, ) prep.assert_called_once_with(client_info) @@ -1624,7 +1752,8 @@ def test_client_with_default_client_info(): @pytest.mark.asyncio async def test_transport_close_async(): client = ErrorGroupServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc_asyncio", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc_asyncio", ) with mock.patch.object( type(getattr(client.transport, "grpc_channel")), "close" diff --git a/tests/unit/gapic/errorreporting_v1beta1/test_error_stats_service.py b/tests/unit/gapic/errorreporting_v1beta1/test_error_stats_service.py index 83df90db..13f57f23 100644 --- a/tests/unit/gapic/errorreporting_v1beta1/test_error_stats_service.py +++ b/tests/unit/gapic/errorreporting_v1beta1/test_error_stats_service.py @@ -93,20 +93,26 @@ def test__get_default_mtls_endpoint(): @pytest.mark.parametrize( - "client_class", [ErrorStatsServiceClient, ErrorStatsServiceAsyncClient,] + "client_class,transport_name", + [ + (ErrorStatsServiceClient, "grpc"), + (ErrorStatsServiceAsyncClient, "grpc_asyncio"), + ], ) -def test_error_stats_service_client_from_service_account_info(client_class): +def test_error_stats_service_client_from_service_account_info( + client_class, transport_name +): creds = ga_credentials.AnonymousCredentials() with mock.patch.object( service_account.Credentials, "from_service_account_info" ) as factory: factory.return_value = creds info = {"valid": True} - client = client_class.from_service_account_info(info) + client = client_class.from_service_account_info(info, transport=transport_name) assert client.transport._credentials == creds assert isinstance(client, client_class) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") @pytest.mark.parametrize( @@ -135,23 +141,33 @@ def test_error_stats_service_client_service_account_always_use_jwt( @pytest.mark.parametrize( - "client_class", [ErrorStatsServiceClient, ErrorStatsServiceAsyncClient,] + "client_class,transport_name", + [ + (ErrorStatsServiceClient, "grpc"), + (ErrorStatsServiceAsyncClient, "grpc_asyncio"), + ], ) -def test_error_stats_service_client_from_service_account_file(client_class): +def test_error_stats_service_client_from_service_account_file( + client_class, transport_name +): creds = ga_credentials.AnonymousCredentials() with mock.patch.object( service_account.Credentials, "from_service_account_file" ) as factory: factory.return_value = creds - client = client_class.from_service_account_file("dummy/file/path.json") + client = client_class.from_service_account_file( + "dummy/file/path.json", transport=transport_name + ) assert client.transport._credentials == creds assert isinstance(client, client_class) - client = client_class.from_service_account_json("dummy/file/path.json") + client = client_class.from_service_account_json( + "dummy/file/path.json", transport=transport_name + ) assert client.transport._credentials == creds assert isinstance(client, client_class) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") def test_error_stats_service_client_get_transport_class(): @@ -509,7 +525,9 @@ def test_error_stats_service_client_client_options_scopes( client_class, transport_class, transport_name ): # Check the case scopes are provided. - options = client_options.ClientOptions(scopes=["1", "2"],) + options = client_options.ClientOptions( + scopes=["1", "2"], + ) with mock.patch.object(transport_class, "__init__") as patched: patched.return_value = None client = client_class(client_options=options, transport=transport_name) @@ -650,11 +668,16 @@ def test_error_stats_service_client_create_channel_credentials_file( @pytest.mark.parametrize( - "request_type", [error_stats_service.ListGroupStatsRequest, dict,] + "request_type", + [ + error_stats_service.ListGroupStatsRequest, + dict, + ], ) def test_list_group_stats(request_type, transport: str = "grpc"): client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -683,7 +706,8 @@ def test_list_group_stats_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 = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc", ) # Mock the actual call within the gRPC stub, and fake the request. @@ -700,7 +724,8 @@ async def test_list_group_stats_async( request_type=error_stats_service.ListGroupStatsRequest, ): client = ErrorStatsServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -733,7 +758,9 @@ async def test_list_group_stats_async_from_dict(): def test_list_group_stats_field_headers(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_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. @@ -753,9 +780,10 @@ def test_list_group_stats_field_headers(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "project_name=project_name/value",) in kw[ - "metadata" - ] + assert ( + "x-goog-request-params", + "project_name=project_name/value", + ) in kw["metadata"] @pytest.mark.asyncio @@ -784,13 +812,16 @@ async def test_list_group_stats_field_headers_async(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "project_name=project_name/value",) in kw[ - "metadata" - ] + assert ( + "x-goog-request-params", + "project_name=project_name/value", + ) in kw["metadata"] def test_list_group_stats_flattened(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.list_group_stats), "__call__") as call: @@ -820,7 +851,9 @@ def test_list_group_stats_flattened(): def test_list_group_stats_flattened_error(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Attempting to call a method with both a request object and flattened # fields is an error. @@ -891,7 +924,8 @@ async def test_list_group_stats_flattened_error_async(): def test_list_group_stats_pager(transport_name: str = "grpc"): client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials, transport=transport_name, + credentials=ga_credentials.AnonymousCredentials, + transport=transport_name, ) # Mock the actual call within the gRPC stub, and fake the request. @@ -907,10 +941,13 @@ def test_list_group_stats_pager(transport_name: str = "grpc"): next_page_token="abc", ), error_stats_service.ListGroupStatsResponse( - error_group_stats=[], next_page_token="def", + error_group_stats=[], + next_page_token="def", ), error_stats_service.ListGroupStatsResponse( - error_group_stats=[error_stats_service.ErrorGroupStats(),], + error_group_stats=[ + error_stats_service.ErrorGroupStats(), + ], next_page_token="ghi", ), error_stats_service.ListGroupStatsResponse( @@ -937,7 +974,8 @@ def test_list_group_stats_pager(transport_name: str = "grpc"): def test_list_group_stats_pages(transport_name: str = "grpc"): client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials, transport=transport_name, + credentials=ga_credentials.AnonymousCredentials, + transport=transport_name, ) # Mock the actual call within the gRPC stub, and fake the request. @@ -953,10 +991,13 @@ def test_list_group_stats_pages(transport_name: str = "grpc"): next_page_token="abc", ), error_stats_service.ListGroupStatsResponse( - error_group_stats=[], next_page_token="def", + error_group_stats=[], + next_page_token="def", ), error_stats_service.ListGroupStatsResponse( - error_group_stats=[error_stats_service.ErrorGroupStats(),], + error_group_stats=[ + error_stats_service.ErrorGroupStats(), + ], next_page_token="ghi", ), error_stats_service.ListGroupStatsResponse( @@ -993,10 +1034,13 @@ async def test_list_group_stats_async_pager(): next_page_token="abc", ), error_stats_service.ListGroupStatsResponse( - error_group_stats=[], next_page_token="def", + error_group_stats=[], + next_page_token="def", ), error_stats_service.ListGroupStatsResponse( - error_group_stats=[error_stats_service.ErrorGroupStats(),], + error_group_stats=[ + error_stats_service.ErrorGroupStats(), + ], next_page_token="ghi", ), error_stats_service.ListGroupStatsResponse( @@ -1007,10 +1051,12 @@ async def test_list_group_stats_async_pager(): ), RuntimeError, ) - async_pager = await client.list_group_stats(request={},) + async_pager = await client.list_group_stats( + request={}, + ) assert async_pager.next_page_token == "abc" responses = [] - async for response in async_pager: + async for response in async_pager: # pragma: no branch responses.append(response) assert len(responses) == 6 @@ -1040,10 +1086,13 @@ async def test_list_group_stats_async_pages(): next_page_token="abc", ), error_stats_service.ListGroupStatsResponse( - error_group_stats=[], next_page_token="def", + error_group_stats=[], + next_page_token="def", ), error_stats_service.ListGroupStatsResponse( - error_group_stats=[error_stats_service.ErrorGroupStats(),], + error_group_stats=[ + error_stats_service.ErrorGroupStats(), + ], next_page_token="ghi", ), error_stats_service.ListGroupStatsResponse( @@ -1055,16 +1104,25 @@ async def test_list_group_stats_async_pages(): RuntimeError, ) pages = [] - async for page_ in (await client.list_group_stats(request={})).pages: + async for page_ in ( + await client.list_group_stats(request={}) + ).pages: # pragma: no branch pages.append(page_) for page_, token in zip(pages, ["abc", "def", "ghi", ""]): assert page_.raw_page.next_page_token == token -@pytest.mark.parametrize("request_type", [error_stats_service.ListEventsRequest, dict,]) +@pytest.mark.parametrize( + "request_type", + [ + error_stats_service.ListEventsRequest, + dict, + ], +) def test_list_events(request_type, transport: str = "grpc"): client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -1093,7 +1151,8 @@ def test_list_events_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 = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc", ) # Mock the actual call within the gRPC stub, and fake the request. @@ -1109,7 +1168,8 @@ async def test_list_events_async( transport: str = "grpc_asyncio", request_type=error_stats_service.ListEventsRequest ): client = ErrorStatsServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -1142,7 +1202,9 @@ async def test_list_events_async_from_dict(): def test_list_events_field_headers(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_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. @@ -1162,9 +1224,10 @@ def test_list_events_field_headers(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "project_name=project_name/value",) in kw[ - "metadata" - ] + assert ( + "x-goog-request-params", + "project_name=project_name/value", + ) in kw["metadata"] @pytest.mark.asyncio @@ -1193,13 +1256,16 @@ async def test_list_events_field_headers_async(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "project_name=project_name/value",) in kw[ - "metadata" - ] + assert ( + "x-goog-request-params", + "project_name=project_name/value", + ) in kw["metadata"] def test_list_events_flattened(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.list_events), "__call__") as call: @@ -1208,7 +1274,8 @@ def test_list_events_flattened(): # Call the method with a truthy value for each flattened field, # using the keyword arguments to the method. client.list_events( - project_name="project_name_value", group_id="group_id_value", + project_name="project_name_value", + group_id="group_id_value", ) # Establish that the underlying call was made with the expected @@ -1224,7 +1291,9 @@ def test_list_events_flattened(): def test_list_events_flattened_error(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Attempting to call a method with both a request object and flattened # fields is an error. @@ -1253,7 +1322,8 @@ async def test_list_events_flattened_async(): # Call the method with a truthy value for each flattened field, # using the keyword arguments to the method. response = await client.list_events( - project_name="project_name_value", group_id="group_id_value", + project_name="project_name_value", + group_id="group_id_value", ) # Establish that the underlying call was made with the expected @@ -1286,7 +1356,8 @@ async def test_list_events_flattened_error_async(): def test_list_events_pager(transport_name: str = "grpc"): client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials, transport=transport_name, + credentials=ga_credentials.AnonymousCredentials, + transport=transport_name, ) # Mock the actual call within the gRPC stub, and fake the request. @@ -1302,13 +1373,20 @@ def test_list_events_pager(transport_name: str = "grpc"): next_page_token="abc", ), error_stats_service.ListEventsResponse( - error_events=[], next_page_token="def", + error_events=[], + next_page_token="def", ), error_stats_service.ListEventsResponse( - error_events=[common.ErrorEvent(),], next_page_token="ghi", + error_events=[ + common.ErrorEvent(), + ], + next_page_token="ghi", ), error_stats_service.ListEventsResponse( - error_events=[common.ErrorEvent(), common.ErrorEvent(),], + error_events=[ + common.ErrorEvent(), + common.ErrorEvent(), + ], ), RuntimeError, ) @@ -1328,7 +1406,8 @@ def test_list_events_pager(transport_name: str = "grpc"): def test_list_events_pages(transport_name: str = "grpc"): client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials, transport=transport_name, + credentials=ga_credentials.AnonymousCredentials, + transport=transport_name, ) # Mock the actual call within the gRPC stub, and fake the request. @@ -1344,13 +1423,20 @@ def test_list_events_pages(transport_name: str = "grpc"): next_page_token="abc", ), error_stats_service.ListEventsResponse( - error_events=[], next_page_token="def", + error_events=[], + next_page_token="def", ), error_stats_service.ListEventsResponse( - error_events=[common.ErrorEvent(),], next_page_token="ghi", + error_events=[ + common.ErrorEvent(), + ], + next_page_token="ghi", ), error_stats_service.ListEventsResponse( - error_events=[common.ErrorEvent(), common.ErrorEvent(),], + error_events=[ + common.ErrorEvent(), + common.ErrorEvent(), + ], ), RuntimeError, ) @@ -1380,20 +1466,29 @@ async def test_list_events_async_pager(): next_page_token="abc", ), error_stats_service.ListEventsResponse( - error_events=[], next_page_token="def", + error_events=[], + next_page_token="def", ), error_stats_service.ListEventsResponse( - error_events=[common.ErrorEvent(),], next_page_token="ghi", + error_events=[ + common.ErrorEvent(), + ], + next_page_token="ghi", ), error_stats_service.ListEventsResponse( - error_events=[common.ErrorEvent(), common.ErrorEvent(),], + error_events=[ + common.ErrorEvent(), + common.ErrorEvent(), + ], ), RuntimeError, ) - async_pager = await client.list_events(request={},) + async_pager = await client.list_events( + request={}, + ) assert async_pager.next_page_token == "abc" responses = [] - async for response in async_pager: + async for response in async_pager: # pragma: no branch responses.append(response) assert len(responses) == 6 @@ -1421,29 +1516,43 @@ async def test_list_events_async_pages(): next_page_token="abc", ), error_stats_service.ListEventsResponse( - error_events=[], next_page_token="def", + error_events=[], + next_page_token="def", ), error_stats_service.ListEventsResponse( - error_events=[common.ErrorEvent(),], next_page_token="ghi", + error_events=[ + common.ErrorEvent(), + ], + next_page_token="ghi", ), error_stats_service.ListEventsResponse( - error_events=[common.ErrorEvent(), common.ErrorEvent(),], + error_events=[ + common.ErrorEvent(), + common.ErrorEvent(), + ], ), RuntimeError, ) pages = [] - async for page_ in (await client.list_events(request={})).pages: + async for page_ in ( + await client.list_events(request={}) + ).pages: # pragma: no branch pages.append(page_) for page_, token in zip(pages, ["abc", "def", "ghi", ""]): assert page_.raw_page.next_page_token == token @pytest.mark.parametrize( - "request_type", [error_stats_service.DeleteEventsRequest, dict,] + "request_type", + [ + error_stats_service.DeleteEventsRequest, + dict, + ], ) def test_delete_events(request_type, transport: str = "grpc"): client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -1469,7 +1578,8 @@ def test_delete_events_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 = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc", ) # Mock the actual call within the gRPC stub, and fake the request. @@ -1486,7 +1596,8 @@ async def test_delete_events_async( request_type=error_stats_service.DeleteEventsRequest, ): client = ErrorStatsServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -1516,7 +1627,9 @@ async def test_delete_events_async_from_dict(): def test_delete_events_field_headers(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_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. @@ -1536,9 +1649,10 @@ def test_delete_events_field_headers(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "project_name=project_name/value",) in kw[ - "metadata" - ] + assert ( + "x-goog-request-params", + "project_name=project_name/value", + ) in kw["metadata"] @pytest.mark.asyncio @@ -1567,13 +1681,16 @@ async def test_delete_events_field_headers_async(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "project_name=project_name/value",) in kw[ - "metadata" - ] + assert ( + "x-goog-request-params", + "project_name=project_name/value", + ) in kw["metadata"] def test_delete_events_flattened(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Mock the actual call within the gRPC stub, and fake the request. with mock.patch.object(type(client.transport.delete_events), "__call__") as call: @@ -1581,7 +1698,9 @@ def test_delete_events_flattened(): call.return_value = error_stats_service.DeleteEventsResponse() # Call the method with a truthy value for each flattened field, # using the keyword arguments to the method. - client.delete_events(project_name="project_name_value",) + client.delete_events( + project_name="project_name_value", + ) # Establish that the underlying call was made with the expected # request object values. @@ -1593,7 +1712,9 @@ def test_delete_events_flattened(): def test_delete_events_flattened_error(): - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) + client = ErrorStatsServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) # Attempting to call a method with both a request object and flattened # fields is an error. @@ -1620,7 +1741,9 @@ async def test_delete_events_flattened_async(): ) # Call the method with a truthy value for each flattened field, # using the keyword arguments to the method. - response = await client.delete_events(project_name="project_name_value",) + response = await client.delete_events( + project_name="project_name_value", + ) # Establish that the underlying call was made with the expected # request object values. @@ -1653,7 +1776,8 @@ def test_credentials_transport_error(): ) with pytest.raises(ValueError): client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # It is an error to provide a credentials file and a transport instance. @@ -1673,7 +1797,10 @@ def test_credentials_transport_error(): options = client_options.ClientOptions() options.api_key = "api_key" with pytest.raises(ValueError): - client = ErrorStatsServiceClient(client_options=options, transport=transport,) + client = ErrorStatsServiceClient( + client_options=options, + transport=transport, + ) # It is an error to provide an api_key and a credential. options = mock.Mock() @@ -1689,7 +1816,8 @@ def test_credentials_transport_error(): ) with pytest.raises(ValueError): client = ErrorStatsServiceClient( - client_options={"scopes": ["1", "2"]}, transport=transport, + client_options={"scopes": ["1", "2"]}, + transport=transport, ) @@ -1732,10 +1860,28 @@ def test_transport_adc(transport_class): adc.assert_called_once() +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + ], +) +def test_transport_kind(transport_name): + transport = ErrorStatsServiceClient.get_transport_class(transport_name)( + credentials=ga_credentials.AnonymousCredentials(), + ) + assert transport.kind == transport_name + + def test_transport_grpc_default(): # A client should use the gRPC transport by default. - client = ErrorStatsServiceClient(credentials=ga_credentials.AnonymousCredentials(),) - assert isinstance(client.transport, transports.ErrorStatsServiceGrpcTransport,) + client = ErrorStatsServiceClient( + credentials=ga_credentials.AnonymousCredentials(), + ) + assert isinstance( + client.transport, + transports.ErrorStatsServiceGrpcTransport, + ) def test_error_stats_service_base_transport_error(): @@ -1771,6 +1917,14 @@ def test_error_stats_service_base_transport(): with pytest.raises(NotImplementedError): transport.close() + # Catch all for all remaining methods and properties + remainder = [ + "kind", + ] + for r in remainder: + with pytest.raises(NotImplementedError): + getattr(transport, r)() + def test_error_stats_service_base_transport_with_credentials_file(): # Instantiate the base transport with a credentials file @@ -1782,7 +1936,8 @@ def test_error_stats_service_base_transport_with_credentials_file(): Transport.return_value = None load_creds.return_value = (ga_credentials.AnonymousCredentials(), None) transport = transports.ErrorStatsServiceTransport( - credentials_file="credentials.json", quota_project_id="octopus", + credentials_file="credentials.json", + quota_project_id="octopus", ) load_creds.assert_called_once_with( "credentials.json", @@ -1917,24 +2072,40 @@ def test_error_stats_service_grpc_transport_client_cert_source_for_mtls( ) -def test_error_stats_service_host_no_port(): +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + "grpc_asyncio", + ], +) +def test_error_stats_service_host_no_port(transport_name): client = ErrorStatsServiceClient( credentials=ga_credentials.AnonymousCredentials(), client_options=client_options.ClientOptions( api_endpoint="clouderrorreporting.googleapis.com" ), + transport=transport_name, ) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") -def test_error_stats_service_host_with_port(): +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + "grpc_asyncio", + ], +) +def test_error_stats_service_host_with_port(transport_name): client = ErrorStatsServiceClient( credentials=ga_credentials.AnonymousCredentials(), client_options=client_options.ClientOptions( api_endpoint="clouderrorreporting.googleapis.com:8000" ), + transport=transport_name, ) - assert client.transport._host == "clouderrorreporting.googleapis.com:8000" + assert client.transport._host == ("clouderrorreporting.googleapis.com:8000") def test_error_stats_service_grpc_transport_channel(): @@ -1942,7 +2113,8 @@ def test_error_stats_service_grpc_transport_channel(): # Check that channel is used if provided. transport = transports.ErrorStatsServiceGrpcTransport( - host="squid.clam.whelk", channel=channel, + host="squid.clam.whelk", + channel=channel, ) assert transport.grpc_channel == channel assert transport._host == "squid.clam.whelk:443" @@ -1954,7 +2126,8 @@ def test_error_stats_service_grpc_asyncio_transport_channel(): # Check that channel is used if provided. transport = transports.ErrorStatsServiceGrpcAsyncIOTransport( - host="squid.clam.whelk", channel=channel, + host="squid.clam.whelk", + channel=channel, ) assert transport.grpc_channel == channel assert transport._host == "squid.clam.whelk:443" @@ -2064,7 +2237,10 @@ def test_error_stats_service_transport_channel_mtls_with_adc(transport_class): def test_error_group_path(): project = "squid" group = "clam" - expected = "projects/{project}/groups/{group}".format(project=project, group=group,) + expected = "projects/{project}/groups/{group}".format( + project=project, + group=group, + ) actual = ErrorStatsServiceClient.error_group_path(project, group) assert expected == actual @@ -2103,7 +2279,9 @@ def test_parse_common_billing_account_path(): def test_common_folder_path(): folder = "cuttlefish" - expected = "folders/{folder}".format(folder=folder,) + expected = "folders/{folder}".format( + folder=folder, + ) actual = ErrorStatsServiceClient.common_folder_path(folder) assert expected == actual @@ -2121,7 +2299,9 @@ def test_parse_common_folder_path(): def test_common_organization_path(): organization = "winkle" - expected = "organizations/{organization}".format(organization=organization,) + expected = "organizations/{organization}".format( + organization=organization, + ) actual = ErrorStatsServiceClient.common_organization_path(organization) assert expected == actual @@ -2139,7 +2319,9 @@ def test_parse_common_organization_path(): def test_common_project_path(): project = "scallop" - expected = "projects/{project}".format(project=project,) + expected = "projects/{project}".format( + project=project, + ) actual = ErrorStatsServiceClient.common_project_path(project) assert expected == actual @@ -2159,7 +2341,8 @@ def test_common_location_path(): project = "squid" location = "clam" expected = "projects/{project}/locations/{location}".format( - project=project, location=location, + project=project, + location=location, ) actual = ErrorStatsServiceClient.common_location_path(project, location) assert expected == actual @@ -2184,7 +2367,8 @@ def test_client_with_default_client_info(): transports.ErrorStatsServiceTransport, "_prep_wrapped_messages" ) as prep: client = ErrorStatsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), client_info=client_info, + credentials=ga_credentials.AnonymousCredentials(), + client_info=client_info, ) prep.assert_called_once_with(client_info) @@ -2193,7 +2377,8 @@ def test_client_with_default_client_info(): ) as prep: transport_class = ErrorStatsServiceClient.get_transport_class() transport = transport_class( - credentials=ga_credentials.AnonymousCredentials(), client_info=client_info, + credentials=ga_credentials.AnonymousCredentials(), + client_info=client_info, ) prep.assert_called_once_with(client_info) @@ -2201,7 +2386,8 @@ def test_client_with_default_client_info(): @pytest.mark.asyncio async def test_transport_close_async(): client = ErrorStatsServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc_asyncio", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc_asyncio", ) with mock.patch.object( type(getattr(client.transport, "grpc_channel")), "close" diff --git a/tests/unit/gapic/errorreporting_v1beta1/test_report_errors_service.py b/tests/unit/gapic/errorreporting_v1beta1/test_report_errors_service.py index 61f9ed9d..2fd72f9f 100644 --- a/tests/unit/gapic/errorreporting_v1beta1/test_report_errors_service.py +++ b/tests/unit/gapic/errorreporting_v1beta1/test_report_errors_service.py @@ -93,20 +93,26 @@ def test__get_default_mtls_endpoint(): @pytest.mark.parametrize( - "client_class", [ReportErrorsServiceClient, ReportErrorsServiceAsyncClient,] + "client_class,transport_name", + [ + (ReportErrorsServiceClient, "grpc"), + (ReportErrorsServiceAsyncClient, "grpc_asyncio"), + ], ) -def test_report_errors_service_client_from_service_account_info(client_class): +def test_report_errors_service_client_from_service_account_info( + client_class, transport_name +): creds = ga_credentials.AnonymousCredentials() with mock.patch.object( service_account.Credentials, "from_service_account_info" ) as factory: factory.return_value = creds info = {"valid": True} - client = client_class.from_service_account_info(info) + client = client_class.from_service_account_info(info, transport=transport_name) assert client.transport._credentials == creds assert isinstance(client, client_class) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") @pytest.mark.parametrize( @@ -135,23 +141,33 @@ def test_report_errors_service_client_service_account_always_use_jwt( @pytest.mark.parametrize( - "client_class", [ReportErrorsServiceClient, ReportErrorsServiceAsyncClient,] + "client_class,transport_name", + [ + (ReportErrorsServiceClient, "grpc"), + (ReportErrorsServiceAsyncClient, "grpc_asyncio"), + ], ) -def test_report_errors_service_client_from_service_account_file(client_class): +def test_report_errors_service_client_from_service_account_file( + client_class, transport_name +): creds = ga_credentials.AnonymousCredentials() with mock.patch.object( service_account.Credentials, "from_service_account_file" ) as factory: factory.return_value = creds - client = client_class.from_service_account_file("dummy/file/path.json") + client = client_class.from_service_account_file( + "dummy/file/path.json", transport=transport_name + ) assert client.transport._credentials == creds assert isinstance(client, client_class) - client = client_class.from_service_account_json("dummy/file/path.json") + client = client_class.from_service_account_json( + "dummy/file/path.json", transport=transport_name + ) assert client.transport._credentials == creds assert isinstance(client, client_class) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") def test_report_errors_service_client_get_transport_class(): @@ -517,7 +533,9 @@ def test_report_errors_service_client_client_options_scopes( client_class, transport_class, transport_name ): # Check the case scopes are provided. - options = client_options.ClientOptions(scopes=["1", "2"],) + options = client_options.ClientOptions( + scopes=["1", "2"], + ) with mock.patch.object(transport_class, "__init__") as patched: patched.return_value = None client = client_class(client_options=options, transport=transport_name) @@ -658,11 +676,16 @@ def test_report_errors_service_client_create_channel_credentials_file( @pytest.mark.parametrize( - "request_type", [report_errors_service.ReportErrorEventRequest, dict,] + "request_type", + [ + report_errors_service.ReportErrorEventRequest, + dict, + ], ) def test_report_error_event(request_type, transport: str = "grpc"): client = ReportErrorsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -690,7 +713,8 @@ def test_report_error_event_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 = ReportErrorsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc", ) # Mock the actual call within the gRPC stub, and fake the request. @@ -709,7 +733,8 @@ async def test_report_error_event_async( request_type=report_errors_service.ReportErrorEventRequest, ): client = ReportErrorsServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # Everything is optional in proto3 as far as the runtime is concerned, @@ -765,9 +790,10 @@ def test_report_error_event_field_headers(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "project_name=project_name/value",) in kw[ - "metadata" - ] + assert ( + "x-goog-request-params", + "project_name=project_name/value", + ) in kw["metadata"] @pytest.mark.asyncio @@ -798,9 +824,10 @@ async def test_report_error_event_field_headers_async(): # Establish that the field header was sent. _, _, kw = call.mock_calls[0] - assert ("x-goog-request-params", "project_name=project_name/value",) in kw[ - "metadata" - ] + assert ( + "x-goog-request-params", + "project_name=project_name/value", + ) in kw["metadata"] def test_report_error_event_flattened(): @@ -918,7 +945,8 @@ def test_credentials_transport_error(): ) with pytest.raises(ValueError): client = ReportErrorsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), transport=transport, + credentials=ga_credentials.AnonymousCredentials(), + transport=transport, ) # It is an error to provide a credentials file and a transport instance. @@ -938,7 +966,10 @@ def test_credentials_transport_error(): options = client_options.ClientOptions() options.api_key = "api_key" with pytest.raises(ValueError): - client = ReportErrorsServiceClient(client_options=options, transport=transport,) + client = ReportErrorsServiceClient( + client_options=options, + transport=transport, + ) # It is an error to provide an api_key and a credential. options = mock.Mock() @@ -954,7 +985,8 @@ def test_credentials_transport_error(): ) with pytest.raises(ValueError): client = ReportErrorsServiceClient( - client_options={"scopes": ["1", "2"]}, transport=transport, + client_options={"scopes": ["1", "2"]}, + transport=transport, ) @@ -997,12 +1029,28 @@ def test_transport_adc(transport_class): adc.assert_called_once() +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + ], +) +def test_transport_kind(transport_name): + transport = ReportErrorsServiceClient.get_transport_class(transport_name)( + credentials=ga_credentials.AnonymousCredentials(), + ) + assert transport.kind == transport_name + + def test_transport_grpc_default(): # A client should use the gRPC transport by default. client = ReportErrorsServiceClient( credentials=ga_credentials.AnonymousCredentials(), ) - assert isinstance(client.transport, transports.ReportErrorsServiceGrpcTransport,) + assert isinstance( + client.transport, + transports.ReportErrorsServiceGrpcTransport, + ) def test_report_errors_service_base_transport_error(): @@ -1034,6 +1082,14 @@ def test_report_errors_service_base_transport(): with pytest.raises(NotImplementedError): transport.close() + # Catch all for all remaining methods and properties + remainder = [ + "kind", + ] + for r in remainder: + with pytest.raises(NotImplementedError): + getattr(transport, r)() + def test_report_errors_service_base_transport_with_credentials_file(): # Instantiate the base transport with a credentials file @@ -1045,7 +1101,8 @@ def test_report_errors_service_base_transport_with_credentials_file(): Transport.return_value = None load_creds.return_value = (ga_credentials.AnonymousCredentials(), None) transport = transports.ReportErrorsServiceTransport( - credentials_file="credentials.json", quota_project_id="octopus", + credentials_file="credentials.json", + quota_project_id="octopus", ) load_creds.assert_called_once_with( "credentials.json", @@ -1180,24 +1237,40 @@ def test_report_errors_service_grpc_transport_client_cert_source_for_mtls( ) -def test_report_errors_service_host_no_port(): +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + "grpc_asyncio", + ], +) +def test_report_errors_service_host_no_port(transport_name): client = ReportErrorsServiceClient( credentials=ga_credentials.AnonymousCredentials(), client_options=client_options.ClientOptions( api_endpoint="clouderrorreporting.googleapis.com" ), + transport=transport_name, ) - assert client.transport._host == "clouderrorreporting.googleapis.com:443" + assert client.transport._host == ("clouderrorreporting.googleapis.com:443") -def test_report_errors_service_host_with_port(): +@pytest.mark.parametrize( + "transport_name", + [ + "grpc", + "grpc_asyncio", + ], +) +def test_report_errors_service_host_with_port(transport_name): client = ReportErrorsServiceClient( credentials=ga_credentials.AnonymousCredentials(), client_options=client_options.ClientOptions( api_endpoint="clouderrorreporting.googleapis.com:8000" ), + transport=transport_name, ) - assert client.transport._host == "clouderrorreporting.googleapis.com:8000" + assert client.transport._host == ("clouderrorreporting.googleapis.com:8000") def test_report_errors_service_grpc_transport_channel(): @@ -1205,7 +1278,8 @@ def test_report_errors_service_grpc_transport_channel(): # Check that channel is used if provided. transport = transports.ReportErrorsServiceGrpcTransport( - host="squid.clam.whelk", channel=channel, + host="squid.clam.whelk", + channel=channel, ) assert transport.grpc_channel == channel assert transport._host == "squid.clam.whelk:443" @@ -1217,7 +1291,8 @@ def test_report_errors_service_grpc_asyncio_transport_channel(): # Check that channel is used if provided. transport = transports.ReportErrorsServiceGrpcAsyncIOTransport( - host="squid.clam.whelk", channel=channel, + host="squid.clam.whelk", + channel=channel, ) assert transport.grpc_channel == channel assert transport._host == "squid.clam.whelk:443" @@ -1346,7 +1421,9 @@ def test_parse_common_billing_account_path(): def test_common_folder_path(): folder = "whelk" - expected = "folders/{folder}".format(folder=folder,) + expected = "folders/{folder}".format( + folder=folder, + ) actual = ReportErrorsServiceClient.common_folder_path(folder) assert expected == actual @@ -1364,7 +1441,9 @@ def test_parse_common_folder_path(): def test_common_organization_path(): organization = "oyster" - expected = "organizations/{organization}".format(organization=organization,) + expected = "organizations/{organization}".format( + organization=organization, + ) actual = ReportErrorsServiceClient.common_organization_path(organization) assert expected == actual @@ -1382,7 +1461,9 @@ def test_parse_common_organization_path(): def test_common_project_path(): project = "cuttlefish" - expected = "projects/{project}".format(project=project,) + expected = "projects/{project}".format( + project=project, + ) actual = ReportErrorsServiceClient.common_project_path(project) assert expected == actual @@ -1402,7 +1483,8 @@ def test_common_location_path(): project = "winkle" location = "nautilus" expected = "projects/{project}/locations/{location}".format( - project=project, location=location, + project=project, + location=location, ) actual = ReportErrorsServiceClient.common_location_path(project, location) assert expected == actual @@ -1427,7 +1509,8 @@ def test_client_with_default_client_info(): transports.ReportErrorsServiceTransport, "_prep_wrapped_messages" ) as prep: client = ReportErrorsServiceClient( - credentials=ga_credentials.AnonymousCredentials(), client_info=client_info, + credentials=ga_credentials.AnonymousCredentials(), + client_info=client_info, ) prep.assert_called_once_with(client_info) @@ -1436,7 +1519,8 @@ def test_client_with_default_client_info(): ) as prep: transport_class = ReportErrorsServiceClient.get_transport_class() transport = transport_class( - credentials=ga_credentials.AnonymousCredentials(), client_info=client_info, + credentials=ga_credentials.AnonymousCredentials(), + client_info=client_info, ) prep.assert_called_once_with(client_info) @@ -1444,7 +1528,8 @@ def test_client_with_default_client_info(): @pytest.mark.asyncio async def test_transport_close_async(): client = ReportErrorsServiceAsyncClient( - credentials=ga_credentials.AnonymousCredentials(), transport="grpc_asyncio", + credentials=ga_credentials.AnonymousCredentials(), + transport="grpc_asyncio", ) with mock.patch.object( type(getattr(client.transport, "grpc_channel")), "close"