From 4df8491502bc65ae0589c6686b71756d205f4411 Mon Sep 17 00:00:00 2001 From: Heinz-Alexander Fuetterer <35225576+afuetterer@users.noreply.github.com> Date: Thu, 25 Apr 2024 14:34:25 +0200 Subject: [PATCH] docs: add references to exceptions in docstrings (#351) Fixes #332 --- src/oaipmh_scythe/client.py | 46 +++++++++++++++++---------------- src/oaipmh_scythe/exceptions.py | 2 +- 2 files changed, 25 insertions(+), 23 deletions(-) diff --git a/src/oaipmh_scythe/client.py b/src/oaipmh_scythe/client.py index b5856c8..f5f1e1e 100644 --- a/src/oaipmh_scythe/client.py +++ b/src/oaipmh_scythe/client.py @@ -162,7 +162,7 @@ def harvest(self, query: dict[str, str]) -> OAIResponse: An OAIResponse object encapsulating the server's response. Raises: - HTTPError: If the HTTP request fails after the maximum number of retries. + httpx.HTTPError: If the HTTP request fails after the maximum number of retries. """ http_response = self._request(query) for _ in range(self.max_retries): @@ -213,14 +213,15 @@ def list_records( ignore_deleted: If True, skip records flagged as deleted in the response. Yields: - An iterator over OAIResponse or Record objects, each representing an individual record or response from the server. + An iterator over OAIResponse or Record objects, each representing an individual record or response + from the server. Raises: - badArgument: If the arguments provided do not conform to the expectations of the OAI server. - badResumptionToken: If the provided resumption token is invalid or expired. - cannotDisseminateFormat: If the specified metadata_prefix is not supported by the OAI server. - noRecordsMatch: If no records match the provided criteria. - noSetHierarchy: If set-based harvesting is requested but the OAI server does not support sets. + BadArgument: If the arguments provided do not conform to the expectations of the OAI server. + BadResumptionToken: If the provided resumption token is invalid or expired. + CannotDisseminateFormat: If the specified metadata_prefix is not supported by the OAI server. + NoRecordsMatch: If no records match the provided criteria. + NoSetHierarchy: If set-based harvesting is requested but the OAI server does not support sets. """ _query = { @@ -256,7 +257,8 @@ def list_identifiers( until: An optional date string specifying the end of a date range for harvesting records. metadata_prefix: The metadata format for the records to be harvested. Defaults to "oai_dc". set_: An optional set identifier to restrict the harvest to records within a specific set. - resumption_token: An optional token for pagination, used to continue a request for the next page of identifiers. + resumption_token: An optional token for pagination, used to continue a request for the next page of + identifiers. ignore_deleted: If True, skip records flagged as deleted in the response. Yields: @@ -264,10 +266,10 @@ def list_identifiers( or response from the server. Raises: - badResumptionToken: If the provided resumption token is invalid or expired. - cannotDisseminateFormat: If the specified metadata_prefix is not supported by the OAI server. - noRecordsMatch: If no records match the provided criteria. - noSetHierarchy: If set-based harvesting is requested but the OAI server does not support sets. + BadResumptionToken: If the provided resumption token is invalid or expired. + CannotDisseminateFormat: If the specified metadata_prefix is not supported by the OAI server. + NoRecordsMatch: If no records match the provided criteria. + NoSetHierarchy: If set-based harvesting is requested but the OAI server does not support sets. """ _query = { @@ -298,8 +300,8 @@ def list_sets(self, resumption_token: str | None = None) -> Iterator[OAIResponse An iterator over OAIResponse or Set objects, representing an individual set or response from the server. Raises: - badResumptionToken: If the provided resumption token is invalid or expired. - noSetHierarchy: If the OAI server does not support sets or has no set hierarchy available. + BadResumptionToken: If the provided resumption token is invalid or expired. + NoSetHierarchy: If the OAI server does not support sets or has no set hierarchy available. """ _query = { @@ -319,8 +321,8 @@ def identify(self) -> Identify: Ref: Returns: - Identify: An object encapsulating the server's identify response, which contains various pieces of information - about the OAI server. + An object encapsulating the server's identify response, which contains various pieces of information about + the OAI server. """ query = {"verb": "Identify"} @@ -344,9 +346,9 @@ def get_record(self, identifier: str, metadata_prefix: str = "oai_dc") -> OAIRes An OAIResponse or Record object representing the requested record. Raises: - cannotDisseminateFormat: If the specified metadata_prefix is not supported by the OAI server - for the requested record. - idDoesNotExist: If the specified identifier does not correspond to any record in the OAI server. + CannotDisseminateFormat: If the specified metadata_prefix is not supported by the OAI server for + the requested record. + IdDoesNotExist: If the specified identifier does not correspond to any record in the OAI server. """ query = { @@ -372,11 +374,11 @@ def list_metadata_formats(self, identifier: str | None = None) -> Iterator[OAIRe Yields: An iterator over OAIResponse or MetadataFormat objects, each representing an individual metadata format - or response from the server. + or response from the server. Raises: - idDoesNotExist: If the specified identifier does not correspond to any record in the OAI server. - noMetadataFormats: If there are no metadata formats available for the requested record or repository. + IdDoesNotExist: If the specified identifier does not correspond to any record in the OAI server. + NoMetadataFormats: If there are no metadata formats available for the requested record or repository. """ _query = { diff --git a/src/oaipmh_scythe/exceptions.py b/src/oaipmh_scythe/exceptions.py index e6251b0..e49f5df 100644 --- a/src/oaipmh_scythe/exceptions.py +++ b/src/oaipmh_scythe/exceptions.py @@ -18,7 +18,7 @@ CannotDisseminateFormat: Raised when a requested metadata format is not supported. IdDoesNotExist: Raised when an identifier does not exist or is illegal in a repository. NoSetHierarchy: Raised when a repository does not support set hierarchies. - NoMetadataFormat: Raised when no metadata formats are available for an item. + NoMetadataFormats: Raised when no metadata formats are available for an item. NoRecordsMatch: Raised when a query yields no results due to specific argument combinations. These custom exceptions enhance the robustness and clarity of error handling in OAI-PMH client implementations,