This commit is contained in:
@@ -4,10 +4,13 @@ from slic.utils.snapshot import snapshot
|
||||
from slic.core.adjustable import Adjustable
|
||||
|
||||
class FakeAdjustable(Adjustable):
|
||||
"""Mock implémentant toutes les méthodes abstraites"""
|
||||
"""Mock sans repr problématique"""
|
||||
_instances = set()
|
||||
|
||||
def __init__(self, ID, name=None, internal=False):
|
||||
super().__init__(ID=ID, name=name or ID, internal=internal)
|
||||
self._value = 0
|
||||
self.__class__._instances.add(self)
|
||||
|
||||
def get_current_value(self):
|
||||
return self._value
|
||||
@@ -18,15 +21,28 @@ class FakeAdjustable(Adjustable):
|
||||
def set_target_value(self, value, *args, **kwargs):
|
||||
return value
|
||||
|
||||
def __repr__(self):
|
||||
return f"<Adjustable {self.name}>"
|
||||
@classmethod
|
||||
def clear(cls):
|
||||
cls._instances = set()
|
||||
|
||||
def __hash__(self):
|
||||
return hash((self.ID, self.name))
|
||||
|
||||
def __eq__(self, other):
|
||||
return (self.ID, self.name) == (other.ID, other.name)
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
||||
# Tous les cas de test avec IDs explicites
|
||||
@pytest.fixture(autouse=True)
|
||||
def clean_registry():
|
||||
"""Reset avant chaque test"""
|
||||
FakeAdjustable.clear()
|
||||
yield
|
||||
FakeAdjustable.clear()
|
||||
|
||||
test_cases = [
|
||||
# Exclusion des internes par défaut
|
||||
# Exclusion des internes
|
||||
pytest.param(
|
||||
[("v1", "Visible", False), ("h1", "Hidden", True)],
|
||||
["Visible"],
|
||||
@@ -50,59 +66,61 @@ test_cases = [
|
||||
id="empty_case"
|
||||
),
|
||||
|
||||
# Tous les types de tri
|
||||
pytest.param(
|
||||
[("3", "C"), ("1", "A"), ("2", "B")],
|
||||
["A", "B", "C"],
|
||||
{"sort_key": repr},
|
||||
id="sort_by_repr"
|
||||
),
|
||||
# Tri par string
|
||||
pytest.param(
|
||||
[("3", "C"), ("1", "A"), ("2", "B")],
|
||||
["A", "B", "C"],
|
||||
{"sort_key": str},
|
||||
id="sort_by_str"
|
||||
),
|
||||
|
||||
# Tri par ID
|
||||
pytest.param(
|
||||
[("3", "Z"), ("1", "A"), ("2", "M")],
|
||||
["A", "M", "Z"],
|
||||
{"sort_key": lambda a: a.ID},
|
||||
id="sort_by_id"
|
||||
),
|
||||
|
||||
# Tri case-insensitive
|
||||
pytest.param(
|
||||
[("3", "Charlie"), ("1", "alpha"), ("2", "Beta")],
|
||||
["alpha", "Beta", "Charlie"],
|
||||
{"sort_key": lambda a: a.name.lower()},
|
||||
id="sort_case_insensitive"
|
||||
),
|
||||
|
||||
# Tri par longueur
|
||||
pytest.param(
|
||||
[("1", "A"), ("2", "BB"), ("3", "CCC")],
|
||||
["A", "BB", "CCC"],
|
||||
{"sort_key": lambda a: len(a.name)},
|
||||
id="sort_by_length"
|
||||
),
|
||||
|
||||
# Tri combiné
|
||||
pytest.param(
|
||||
[("2", "B", False), ("3", "C", True), ("1", "A", False)],
|
||||
["A", "B", "C"],
|
||||
{"sort_key": lambda a: (a.internal, a.name)},
|
||||
id="sort_by_internal_then_name"
|
||||
id="sort_complex"
|
||||
)
|
||||
]
|
||||
|
||||
@pytest.mark.parametrize("test_input,expected,kwargs", test_cases)
|
||||
def test_snapshot(test_input, expected, kwargs):
|
||||
"""Test complet avec isolation et tous les types de tri"""
|
||||
# Création des objets
|
||||
test_objs = [FakeAdjustable(*x) for x in test_input]
|
||||
"""Tests complets sans utiliser repr"""
|
||||
for args in test_input:
|
||||
FakeAdjustable(*args)
|
||||
|
||||
# Mocking
|
||||
with patch('slic.utils.registry.instances', return_value=test_objs):
|
||||
with patch('slic.utils.registry.instances',
|
||||
return_value=list(FakeAdjustable._instances)):
|
||||
result = snapshot(**kwargs)
|
||||
|
||||
# Vérification adaptée au type de test
|
||||
if kwargs.get('include_internal'):
|
||||
assert len(result) == len(expected)
|
||||
if 'sort_key' in kwargs:
|
||||
assert [x.name for x in result] == expected
|
||||
if not expected:
|
||||
assert result == []
|
||||
elif 'sort_key' in kwargs:
|
||||
assert [x.name for x in result] == expected, (
|
||||
f"Erreur de tri. Obtenu: {[x.name for x in result]}")
|
||||
else:
|
||||
assert {x.name for x in result} == set(expected)
|
||||
Reference in New Issue
Block a user