Skip to content

Commit

Permalink
Merge pull request #403 from datalad/allow-dicts
Browse files Browse the repository at this point in the history
Allow python dictionaries to be passed as `metadata` argument
  • Loading branch information
jsheunis authored Dec 12, 2023
2 parents 1676376 + 4b3252d commit 18538d1
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 0 deletions.
8 changes: 8 additions & 0 deletions datalad_catalog/constraints.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,10 @@
WithDescription,
)

from datalad_next.constraints.basic import (
EnsureDType,
)

__docformat__ = "restructuredtext"


Expand All @@ -31,6 +35,10 @@
# - a JSON serialized string
metadata_constraint = WithDescription(
AnyOf(
WithDescription(
EnsureDType(dict),
error_message="not a valid Python dictionary",
),
WithDescription(
EnsureJSON(),
error_message="not valid JSON content",
Expand Down
25 changes: 25 additions & 0 deletions datalad_catalog/tests/test_add.py
Original file line number Diff line number Diff line change
Expand Up @@ -114,3 +114,28 @@ def test_add_from_json_str(demo_catalog, test_data):
status="ok",
path=demo_catalog.location,
)


def test_add_from_dict(demo_catalog):
"""Add catalog metadata from a json serialized string"""
mdata = {
"dataset_id": "deabeb9b-7a37-4062-a1e0-8fcef7909609",
"dataset_version": "0321dbde969d2f5d6b533e35b5c5c51ac0b15758",
"type": "dataset",
"metadata_sources": {
"key_source_map": {},
"sources": [{"source_name": "", "source_version": ""}],
},
}
res = catalog_add(
catalog=demo_catalog,
metadata=mdata,
on_failure="ignore",
return_type="list",
)
assert_in_results(
res,
action="catalog_add",
status="ok",
path=demo_catalog.location,
)
24 changes: 24 additions & 0 deletions datalad_catalog/tests/test_validate.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,3 +89,27 @@ def test_validate_without_catalog(demo_catalog, test_data):
status="error",
path=Path.cwd(),
)


def test_validate_metadata_dict(demo_catalog):
mdata = {
"dataset_id": "deabeb9b-7a37-4062-a1e0-8fcef7909609",
"dataset_version": "0321dbde969d2f5d6b533e35b5c5c51ac0b15758",
"type": "dataset",
"metadata_sources": {
"key_source_map": {},
"sources": [{"source_name": "", "source_version": ""}],
},
}
res = catalog_validate(
catalog=demo_catalog,
metadata=mdata,
on_failure="ignore",
return_type="list",
)
assert_in_results(
res,
action="catalog_validate",
status="ok",
path=demo_catalog.location,
)

0 comments on commit 18538d1

Please # to comment.