File: basename_unit_test.py

package info (click to toggle)
python-sigima 1.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 24,956 kB
  • sloc: python: 33,326; makefile: 3
file content (126 lines) | stat: -rw-r--r-- 4,088 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
# Copyright (c) DataLab Platform Developers, BSD 3-Clause license, see LICENSE file.

"""Unit tests for :py:func:`sigima.io.common.basename.format_basenames`."""

from __future__ import annotations

import pytest

from sigima.io.common.basename import format_basenames
from sigima.objects.image import ImageObj
from sigima.objects.signal import SignalObj


def make_signal(
    title: str = "",
    xlabel: str = "",
    xunit: str = "",
    ylabel: str = "",
    yunit: str = "",
    metadata: dict | None = None,
) -> SignalObj:
    """Create a SignalObj with specified attributes for testing.

    Args:
        title: Title of the signal.
        xlabel: Label for the x-axis.
        xunit: Unit for the x-axis.
        ylabel: Label for the y-axis.
        yunit: Unit for the y-axis.
        metadata: Metadata dictionary.

    Returns:
        Configured SignalObj instance.
    """
    sig = SignalObj()
    sig.title = title
    sig.xlabel = xlabel
    sig.xunit = xunit
    sig.ylabel = ylabel
    sig.yunit = yunit
    sig.metadata = {} if metadata is None else metadata
    return sig


def make_image(title: str = "", metadata: dict | None = None) -> ImageObj:
    """Create an ImageObj with specified attributes for testing.

    Args:
        title: Title of the image.
        metadata: Metadata dictionary.

    Returns:
        Configured ImageObj instance.
    """
    img = ImageObj()
    img.title = title
    img.metadata = {} if metadata is None else metadata
    return img


def test_format_basenames_with_indices_and_total_count():
    """Test with indexing and total count placeholders."""
    objs = [make_signal("sig1"), make_signal("sig2"), make_signal("sig3")]
    names = format_basenames(objs, fmt="{index:02d}_of_{count:02d}")
    assert names == ["01_of_03", "02_of_03", "03_of_03"]


def test_format_basenames_with_metadata_and_axes_placeholders():
    """Test with metadata and axis placeholders."""
    sig = make_signal(
        title="My/Signal",
        xlabel="Time",
        xunit="s",
        ylabel="Amp",
        yunit="V",
        metadata={"id": 42},
    )
    names = format_basenames(
        [sig], fmt="{title}_{xlabel}[{xunit}]_{ylabel}[{yunit}]_{metadata[id]}"
    )
    assert names == ["My_Signal_Time[s]_Amp[V]_42"]


def test_format_basenames_sanitization():
    """Test with sanitization for titles."""
    objs = [make_signal("A/B"), make_image("C/D")]  # '/' must be sanitized on all OSes
    names = format_basenames(objs, fmt="{title}")
    assert names == ["A_B", "C_D"]


def test_format_basenames_sanitization_with_custom_replacement():
    """Test with custom replacement character."""
    objs = [make_signal("a/b"), make_image("c/d")]
    names = format_basenames(objs, fmt="{title}", replacement="-")
    assert names == ["a-b", "c-d"]


def test_format_basenames_with_unknown_metadata_key():
    """Test that requesting a missing metadata key raises a KeyError."""
    sig = make_signal(title="T", metadata={"other": 1})
    with pytest.raises(KeyError):
        format_basenames([sig], fmt="{metadata[id]}")


def test_format_basenames_with_unknown_placeholder():
    """Test with unknown placeholder should raise a KeyError."""
    with pytest.raises(KeyError):
        format_basenames([make_signal("x")], fmt="{unknown}")


def test_format_basenames_with_direct_metadata_use():
    """Test that direct {metadata} use returns empty string (silently ignored)."""
    sig = make_signal(title="Test", metadata={"key1": "value1", "key2": "value2"})
    names = format_basenames([sig], fmt="{title} {metadata}")
    # The {metadata} placeholder should be replaced with empty string
    # The trailing space gets sanitized away
    assert names == ["Test"]


if __name__ == "__main__":
    test_format_basenames_with_indices_and_total_count()
    test_format_basenames_with_metadata_and_axes_placeholders()
    test_format_basenames_sanitization()
    test_format_basenames_sanitization_with_custom_replacement()
    test_format_basenames_with_unknown_placeholder()
    test_format_basenames_with_direct_metadata_use()