diff --git a/sdcflows/utils/tests/test_wrangler.py b/sdcflows/utils/tests/test_wrangler.py index 5d6ec120ad..edac6f3103 100644 --- a/sdcflows/utils/tests/test_wrangler.py +++ b/sdcflows/utils/tests/test_wrangler.py @@ -47,13 +47,13 @@ "EchoTime": 1.2, "PhaseEncodingDirection": "j-", "TotalReadoutTime": 0.8, - "IntendedFor": "ses-02/func/sub-01_ses-02_task-rest_bold.nii.gz" + "IntendedFor": "bids::sub-01/ses-02/func/sub-01_ses-02_task-rest_bold.nii.gz" }}, {"suffix": "epi", "dir": "PA", "metadata": { "EchoTime": 1.2, "PhaseEncodingDirection": "j", "TotalReadoutTime": 0.8, - "IntendedFor": "ses-02/func/sub-01_ses-02_task-rest_bold.nii.gz" + "IntendedFor": "bids::sub-01/ses-02/func/sub-01_ses-02_task-rest_bold.nii.gz" }} ], "func": [ @@ -76,13 +76,13 @@ "EchoTime": 1.2, "PhaseEncodingDirection": "j-", "TotalReadoutTime": 0.8, - "IntendedFor": "ses-03/func/sub-01_ses-03_task-rest_bold.nii.gz" + "IntendedFor": "bids::sub-01/ses-03/func/sub-01_ses-03_task-rest_bold.nii.gz" }}, {"suffix": "epi", "dir": "PA", "metadata": { "EchoTime": 1.2, "PhaseEncodingDirection": "j", "TotalReadoutTime": 0.8, - "IntendedFor": "ses-03/func/sub-01_ses-03_task-rest_bold.nii.gz" + "IntendedFor": "bids::sub-01/ses-03/func/sub-01_ses-03_task-rest_bold.nii.gz" }} ], "func": [ @@ -176,7 +176,7 @@ "metadata": { "EchoTime1": 1.2, "EchoTime2": 1.4, - "IntendedFor": "ses-02/func/sub-01_ses-02_task-rest_bold.nii.gz" + "IntendedFor": "bids::sub-01/ses-02/func/sub-01_ses-02_task-rest_bold.nii.gz" } }, {"suffix": "magnitude1", "metadata": {"EchoTime": 1.2}}, @@ -203,7 +203,7 @@ "metadata": { "EchoTime1": 1.2, "EchoTime2": 1.4, - "IntendedFor": "ses-03/func/sub-01_ses-03_task-rest_bold.nii.gz" + "IntendedFor": "bids::sub-01/ses-03/func/sub-01_ses-03_task-rest_bold.nii.gz" } }, {"suffix": "magnitude1", "metadata": {"EchoTime": 1.2}}, @@ -255,6 +255,17 @@ def test_wrangler_filter(tmpdir, name, skeleton, estimations): assert len(est) == estimations clear_registry() +@pytest.mark.parametrize('name,skeleton,estimations', [ + ('pepolar', pepolar, 3), + ('phasediff', phasediff, 3), +]) +def test_wrangler_URIs(tmpdir, name, skeleton, estimations): + bids_dir = str(tmpdir / name) + generate_bids_skeleton(bids_dir, skeleton) + layout = gen_layout(bids_dir) + est = find_estimators(layout=layout, subject='01') + assert len(est) == estimations + clear_registry() def test_single_reverse_pedir(tmp_path): bids_dir = tmp_path / "bids" diff --git a/sdcflows/utils/wrangler.py b/sdcflows/utils/wrangler.py index 4ec346b372..cf06f31d30 100644 --- a/sdcflows/utils/wrangler.py +++ b/sdcflows/utils/wrangler.py @@ -21,6 +21,7 @@ # https://www.nipreps.org/community/licensing/ # """Find fieldmaps on the BIDS inputs for :abbr:`SDC (susceptibility distortion correction)`.""" +from __future__ import annotations import logging from functools import reduce from itertools import product @@ -33,6 +34,19 @@ from .. import fieldmaps as fm +def _resolve_intent( + intent: str, + layout: BIDSLayout, + subject: str +) -> str | None: + root = Path(layout.root) + if intent.startswith("bids::"): + return str(root / intent[6:]) + if not intent.startswith("bids:"): + return str(root / f"sub-{subject}" / intent) + return intent + + def find_estimators( *, layout: BIDSLayout, @@ -426,7 +440,7 @@ def find_estimators( # Find existing IntendedFor targets and warn if missing all_targets = [] for intent in listify(epi_base_md["IntendedFor"]): - target = layout.get_file(str(subject_root / intent)) + target = layout.get_file(_resolve_intent(intent, layout, subject)) if target is None: logger.debug("Single PE target %s not found", intent) continue