Skip to content
Open
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 7 additions & 3 deletions monai/transforms/io/array.py
Original file line number Diff line number Diff line change
Expand Up @@ -165,6 +165,10 @@ def __init__(
args: additional parameters for reader if providing a reader name.
kwargs: additional parameters for reader if providing a reader name.

Raises:
OptionalImportError: if a user-specified reader requires a package
that is not installed or has an incompatible version.

Note:

- The transform returns a MetaTensor, unless `set_track_meta(False)` has been used, in which case, a
Expand Down Expand Up @@ -210,10 +214,10 @@ def __init__(
the_reader = look_up_option(_r.lower(), SUPPORTED_READERS)
try:
self.register(the_reader(*args, **kwargs))
except OptionalImportError:
warnings.warn(
except OptionalImportError as e:
raise OptionalImportError(
f"required package for reader {_r} is not installed, or the version doesn't match requirement."
)
) from e
except TypeError: # the reader doesn't have the corresponding args/kwargs
warnings.warn(f"{_r} is not supported with the given parameters {args} {kwargs}.")
self.register(the_reader())
Expand Down
7 changes: 7 additions & 0 deletions tests/data/test_image_rw.py
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,13 @@ def test_3d(self, reader, writer):
test_data = np.random.randn(8, 8, 8).astype(np.float32)
self.nrrd_rw(test_data, reader, writer, np.float32)

class TestLoadImageReaderError(unittest.TestCase):
def test_missing_reader_package_raises_error(self):
class FakeReader:
def __init__(self):
raise OptionalImportError("fake_package is not installed")

with self.assertRaises(OptionalImportError):
LoadImage(reader=FakeReader)
if __name__ == "__main__":
unittest.main()
Loading