From 960abecfb0bcd2ac2a825e3b0dc2da141197bd6f Mon Sep 17 00:00:00 2001 From: vincentsarago Date: Tue, 21 May 2024 11:24:15 +0200 Subject: [PATCH] make datetime required in `StacCommonMetadata` --- stac_pydantic/item.py | 12 +----------- stac_pydantic/shared.py | 2 +- tests/test_models.py | 10 ++++++++++ 3 files changed, 12 insertions(+), 12 deletions(-) diff --git a/stac_pydantic/item.py b/stac_pydantic/item.py index 4fc24d5..6bc03ef 100644 --- a/stac_pydantic/item.py +++ b/stac_pydantic/item.py @@ -4,13 +4,7 @@ from pydantic import AnyUrl, ConfigDict, Field, model_serializer, model_validator from stac_pydantic.links import Links -from stac_pydantic.shared import ( - SEMVER_REGEX, - Asset, - StacBaseModel, - StacCommonMetadata, - UtcDatetime, -) +from stac_pydantic.shared import SEMVER_REGEX, Asset, StacBaseModel, StacCommonMetadata from stac_pydantic.version import STAC_VERSION @@ -19,10 +13,6 @@ class ItemProperties(StacCommonMetadata): https://github.com/radiantearth/stac-spec/blob/v1.0.0/item-spec/item-spec.md#properties-object """ - # Overide the datetime field to be required - datetime: Optional[UtcDatetime] = Field(...) - - # Check https://docs.pydantic.dev/dev-v2/migration/#changes-to-config for more information. model_config = ConfigDict(extra="allow") diff --git a/stac_pydantic/shared.py b/stac_pydantic/shared.py index 5903cf3..eede150 100644 --- a/stac_pydantic/shared.py +++ b/stac_pydantic/shared.py @@ -134,7 +134,7 @@ class StacCommonMetadata(StacBaseModel): title: Optional[str] = None description: Optional[str] = None # Date and Time - datetime: Optional[UtcDatetime] = None + datetime: Optional[UtcDatetime] = Field(...) created: Optional[UtcDatetime] = None updated: Optional[UtcDatetime] = None # Date and Time Range diff --git a/tests/test_models.py b/tests/test_models.py index 6472bee..d5c08f8 100644 --- a/tests/test_models.py +++ b/tests/test_models.py @@ -180,6 +180,16 @@ def test_stac_common_dates(args) -> None: StacCommonMetadata(**args) +def test_stac_null_datetime_required() -> None: + with pytest.raises(ValidationError): + StacCommonMetadata( + **{ + "start_datetime": "2024-01-01T00:00:00Z", + "end_datetime": "2024-01-02T00:00:00Z", + } + ) + + @pytest.mark.parametrize( "args", [