From db6f4cf6eee97dbcd727a2be98726fc8f71711a6 Mon Sep 17 00:00:00 2001 From: "John T. Wodder II" Date: Wed, 31 Jan 2024 14:41:08 -0500 Subject: [PATCH 1/2] Add notes to error messages & docs about `get_metadata()` vs. `get_raw_metadata()` --- dandi/dandiapi.py | 34 +++++++++++++++++++++++++++++++--- 1 file changed, 31 insertions(+), 3 deletions(-) diff --git a/dandi/dandiapi.py b/dandi/dandiapi.py index 7e9ab1178..0dcdbeede 100644 --- a/dandi/dandiapi.py +++ b/dandi/dandiapi.py @@ -18,7 +18,7 @@ import click from dandischema import models -from pydantic import BaseModel, Field, PrivateAttr +from pydantic import BaseModel, Field, PrivateAttr, ValidationError import requests import tenacity @@ -971,8 +971,22 @@ def get_metadata(self) -> models.Dandiset: """ Fetch the metadata for this version of the Dandiset as a `dandischema.models.Dandiset` instance + + .. note:: + + Only published Dandiset versions can be expected to have valid + metadata. Consider using `get_raw_metadata()` instead in order to + fetch unstructured, possibly-invalid metadata. """ - return models.Dandiset.parse_obj(self.get_raw_metadata()) + try: + return models.Dandiset.parse_obj(self.get_raw_metadata()) + except ValidationError as e: + raise ValueError( + f"{type(e).__name__}: {e}\n\nNote: Only metadata for published" + " Dandiset versions can be expected to be valid. Use" + " get_raw_metadata() instead to get unstructured," + " possibly-invalid metadata." + ) def get_raw_metadata(self) -> dict[str, Any]: """ @@ -1347,8 +1361,22 @@ def get_metadata(self) -> models.Asset: """ Fetch the metadata for the asset as a `dandischema.models.Asset` instance + + .. note:: + + Only assets in published Dandiset versions can be expected to have + valid metadata. Consider using `get_raw_metadata()` instead in + order to fetch unstructured, possibly-invalid metadata. """ - return models.Asset.parse_obj(self.get_raw_metadata()) + try: + return models.Asset.parse_obj(self.get_raw_metadata()) + except ValidationError as e: + raise ValueError( + f"{type(e).__name__}: {e}\n\nNote: Only metadata for assets in" + " published Dandiset versions can be expected to be valid. Use" + " get_raw_metadata() instead to get unstructured," + " possibly-invalid metadata." + ) def get_raw_metadata(self) -> dict[str, Any]: """Fetch the metadata for the asset as an unprocessed `dict`""" From 9e521e3746498e88047bf77429003cca0ef925a8 Mon Sep 17 00:00:00 2001 From: "John T. Wodder II" Date: Thu, 1 Feb 2024 12:32:31 -0500 Subject: [PATCH 2/2] Remove note from error messages --- dandi/dandiapi.py | 22 +++------------------- 1 file changed, 3 insertions(+), 19 deletions(-) diff --git a/dandi/dandiapi.py b/dandi/dandiapi.py index 0dcdbeede..d50b94827 100644 --- a/dandi/dandiapi.py +++ b/dandi/dandiapi.py @@ -18,7 +18,7 @@ import click from dandischema import models -from pydantic import BaseModel, Field, PrivateAttr, ValidationError +from pydantic import BaseModel, Field, PrivateAttr import requests import tenacity @@ -978,15 +978,7 @@ def get_metadata(self) -> models.Dandiset: metadata. Consider using `get_raw_metadata()` instead in order to fetch unstructured, possibly-invalid metadata. """ - try: - return models.Dandiset.parse_obj(self.get_raw_metadata()) - except ValidationError as e: - raise ValueError( - f"{type(e).__name__}: {e}\n\nNote: Only metadata for published" - " Dandiset versions can be expected to be valid. Use" - " get_raw_metadata() instead to get unstructured," - " possibly-invalid metadata." - ) + return models.Dandiset.parse_obj(self.get_raw_metadata()) def get_raw_metadata(self) -> dict[str, Any]: """ @@ -1368,15 +1360,7 @@ def get_metadata(self) -> models.Asset: valid metadata. Consider using `get_raw_metadata()` instead in order to fetch unstructured, possibly-invalid metadata. """ - try: - return models.Asset.parse_obj(self.get_raw_metadata()) - except ValidationError as e: - raise ValueError( - f"{type(e).__name__}: {e}\n\nNote: Only metadata for assets in" - " published Dandiset versions can be expected to be valid. Use" - " get_raw_metadata() instead to get unstructured," - " possibly-invalid metadata." - ) + return models.Asset.parse_obj(self.get_raw_metadata()) def get_raw_metadata(self) -> dict[str, Any]: """Fetch the metadata for the asset as an unprocessed `dict`"""