Skip to content

Commit

Permalink
Adapt tests
Browse files Browse the repository at this point in the history
  • Loading branch information
sfmig committed Dec 4, 2024
1 parent d7ae46b commit bd3d790
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 4 deletions.
2 changes: 1 addition & 1 deletion tests/test_unit/test_load_bboxes.py
Original file line number Diff line number Diff line change
Expand Up @@ -340,7 +340,7 @@ def test_from_via_tracks_file(
),
(
r"_(0\d*)_$",
ValueError,
AttributeError,
"/crab_1/00000.jpg (row 0): "
"The frame regexp did not return any matches and a "
"frame number could not be extracted from the filename. "
Expand Down
16 changes: 13 additions & 3 deletions tests/test_unit/test_validators/test_files_validators.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,10 +68,11 @@ def test_deeplabcut_csv_validator_with_invalid_input(


@pytest.mark.parametrize(
"invalid_input, log_message",
"invalid_input, expected_exception, log_message",
[
(
"via_tracks_csv_with_invalid_header",
pytest.raises(ValueError),
".csv header row does not match the known format for "
"VIA tracks .csv files. "
"Expected "
Expand All @@ -82,13 +83,15 @@ def test_deeplabcut_csv_validator_with_invalid_input(
),
(
"frame_number_in_file_attribute_not_integer",
pytest.raises(ValueError),
"04.09.2023-04-Right_RE_test_frame_A.png (row 0): "
"'frame' file attribute cannot be cast as an integer. "
"Please review the file attributes: "
"{'clip': 123, 'frame': 'FOO'}.",
),
(
"frame_number_in_filename_wrong_pattern",
pytest.raises(AttributeError),
"04.09.2023-04-Right_RE_test_frame_1.png (row 0): "
"The frame regexp did not return any matches and a "
"frame number could not be extracted from the "
Expand All @@ -98,24 +101,28 @@ def test_deeplabcut_csv_validator_with_invalid_input(
),
(
"more_frame_numbers_than_filenames",
pytest.raises(ValueError),
"The number of unique frame numbers does not match the number "
"of unique image files. Please review the VIA tracks .csv file "
"and ensure a unique frame number is defined for each file. ",
),
(
"less_frame_numbers_than_filenames",
pytest.raises(ValueError),
"The number of unique frame numbers does not match the number "
"of unique image files. Please review the VIA tracks .csv file "
"and ensure a unique frame number is defined for each file. ",
),
(
"region_shape_attribute_not_rect",
pytest.raises(ValueError),
"04.09.2023-04-Right_RE_test_frame_01.png (row 0): "
"bounding box shape must be 'rect' (rectangular) "
"but instead got 'circle'.",
),
(
"region_shape_attribute_missing_x",
pytest.raises(ValueError),
"04.09.2023-04-Right_RE_test_frame_01.png (row 0): "
"at least one bounding box shape parameter is missing. "
"Expected 'x', 'y', 'width', 'height' to exist as "
Expand All @@ -124,28 +131,31 @@ def test_deeplabcut_csv_validator_with_invalid_input(
),
(
"region_attribute_missing_track",
pytest.raises(ValueError),
"04.09.2023-04-Right_RE_test_frame_01.png (row 0): "
"bounding box does not have a 'track' attribute defined "
"under 'region_attributes'. "
"Please review the VIA tracks .csv file.",
),
(
"track_id_not_castable_as_int",
pytest.raises(ValueError),
"04.09.2023-04-Right_RE_test_frame_01.png (row 0): "
"the track ID for the bounding box cannot be cast "
"as an integer. "
"Please review the VIA tracks .csv file.",
),
(
"track_ids_not_unique_per_frame",
pytest.raises(ValueError),
"04.09.2023-04-Right_RE_test_frame_01.png: "
"multiple bounding boxes in this file have the same track ID. "
"Please review the VIA tracks .csv file.",
),
],
)
def test_via_tracks_csv_validator_with_invalid_input(
invalid_input, log_message, request
invalid_input, expected_exception, log_message, request
):
"""Test that invalid VIA tracks .csv files raise the appropriate errors.
Expand All @@ -162,7 +172,7 @@ def test_via_tracks_csv_validator_with_invalid_input(
- error if bboxes IDs are not 1-based integers
"""
file_path = request.getfixturevalue(invalid_input)
with pytest.raises(ValueError) as excinfo:
with expected_exception as excinfo:
ValidVIATracksCSV(file_path)

assert str(excinfo.value) == log_message

0 comments on commit bd3d790

Please sign in to comment.