Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding argument for metadata indexing by generate_inputs #367

Merged
merged 11 commits into from
Feb 2, 2024
16 changes: 14 additions & 2 deletions snakebids/core/input_generation.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ def generate_inputs(
participant_label: Iterable[str] | str | None = ...,
exclude_participant_label: Iterable[str] | str | None = ...,
use_bids_inputs: Literal[True] | None = ...,
index_metadata: bool = ...,
validate: bool = ...,
pybids_database_dir: Path | str | None = ...,
pybids_reset_database: bool = ...,
Expand All @@ -71,7 +72,8 @@ def generate_inputs(
limit_to: Iterable[str] | None = ...,
participant_label: Iterable[str] | str | None = ...,
exclude_participant_label: Iterable[str] | str | None = ...,
use_bids_inputs: Literal[False] = ...,
use_bids_inputs: Literal[False] = ...,
index_metadata: bool = ...,
validate: bool = ...,
pybids_database_dir: Path | str | None = ...,
pybids_reset_database: bool = ...,
Expand All @@ -90,6 +92,7 @@ def generate_inputs(
participant_label: Iterable[str] | str | None = None,
exclude_participant_label: Iterable[str] | str | None = None,
use_bids_inputs: bool | None = None,
index_metadata: bool = False,
validate: bool = False,
pybids_database_dir: Path | str | None = None,
pybids_reset_database: bool | None = None,
Expand Down Expand Up @@ -160,6 +163,10 @@ def generate_inputs(
:class`BidsDataset`. Setting to True is deprecated as of v0.8, as this is now
the default behaviour

index_metadata
If True indexes metadata of BIDS directory using pybids, otherwise skips
indexing.

validate
If True performs validation of BIDS directory using pybids, otherwise
skips validation.
Expand Down Expand Up @@ -274,6 +281,7 @@ def generate_inputs(
pybids_config=pybids_config,
pybidsdb_dir=pybidsdb_dir,
pybidsdb_reset=pybidsdb_reset,
index_metadata=index_metadata,
validate=validate,
)
if not _all_custom_paths(pybids_inputs)
Expand Down Expand Up @@ -389,6 +397,7 @@ def _gen_bids_layout(
pybidsdb_dir: Path | str | None,
pybidsdb_reset: bool,
pybids_config: Path | str | None = None,
index_metadata: bool = False,
validate: bool = False,
) -> BIDSLayout:
"""Create (or reindex) the BIDSLayout.
Expand All @@ -411,6 +420,9 @@ def _gen_bids_layout(
A boolean that determines whether to reset / overwrite
existing database.

index_metadata
A boolen that determines whether to parse and index metadata

validate
A boolean that determines whether to validate the bids dataset

Expand All @@ -435,7 +447,7 @@ def _gen_bids_layout(
config=pybids_config,
database_path=pybidsdb_dir,
reset_database=pybidsdb_reset,
indexer=BIDSLayoutIndexer(validate=False, index_metadata=False),
indexer=BIDSLayoutIndexer(validate=False, index_metadata=index_metadata),
)


Expand Down
26 changes: 26 additions & 0 deletions snakebids/tests/test_generate_inputs.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,14 @@
# ruff: noqa: PLR2004
from __future__ import annotations
from distutils import extension
myousif9 marked this conversation as resolved.
Show resolved Hide resolved

import filecmp
import functools as ft
import itertools as it
import json
import keyword
from multiprocessing.sharedctypes import Value
from operator import index
import os
import re
import shutil
Expand Down Expand Up @@ -865,6 +869,28 @@ def test_nonstandard_custom_pybids_config(tmpdir: Path):
)


def test_index_metadata(mocker: MockerFixture):
from snakebids.core import input_generation

spy = mocker.spy(input_generation,"BIDSLayoutIndexer")
mocker.patch.object(input_generation,"BIDSLayout",side_effect=ValueError)


# Simplest case -- one input type, using pybids
with pytest.raises(ValueError):
generate_inputs(
pybids_inputs={'foo':{}},
bids_dir=..., # type: ignore
derivatives=..., # type: ignore
index_metadata=True
)

spy.assert_called_once_with(
validate=False,
index_metadata=True,
)


def test_t1w():
# create config
real_bids_dir = "snakebids/tests/data/bids_t1w"
Expand Down
Loading