bookmark - Refactor
This commit is contained in:
@@ -19,11 +19,11 @@ class TestAppState:
|
||||
|
||||
def test_load_test(self):
|
||||
state = AppState()
|
||||
loaded = state.load_test(FIXTURE_DATA)
|
||||
session = state.load_test(FIXTURE_DATA)
|
||||
assert not state.is_empty
|
||||
assert loaded.test_id == "IMPAKT_SYNTH_001"
|
||||
assert loaded.channel_count == 26
|
||||
assert state.primary_test is loaded
|
||||
assert session.test_id == "IMPAKT_SYNTH_001"
|
||||
assert len(session) == 26
|
||||
assert state.primary_test is session
|
||||
|
||||
def test_load_multiple_tests(self):
|
||||
state = AppState()
|
||||
@@ -32,13 +32,13 @@ class TestAppState:
|
||||
if (MME_DATA / "VW1FGS15").exists():
|
||||
t2 = state.load_test(MME_DATA / "VW1FGS15")
|
||||
assert len(state.tests) == 2
|
||||
assert state.primary_test is t1 # First loaded is primary
|
||||
assert state.primary_test is t1
|
||||
assert state.total_channels == 26 + 10
|
||||
|
||||
def test_remove_test(self):
|
||||
state = AppState()
|
||||
loaded = state.load_test(FIXTURE_DATA)
|
||||
state.remove_test(loaded.test_id)
|
||||
session = state.load_test(FIXTURE_DATA)
|
||||
state.remove_test(session.test_id)
|
||||
assert state.is_empty
|
||||
|
||||
def test_get_channel(self):
|
||||
@@ -54,38 +54,38 @@ class TestAppState:
|
||||
ch = state.get_channel("IMPAKT_SYNTH_001", "NONEXISTENT")
|
||||
assert ch is None
|
||||
|
||||
def test_resolve_channel_with_key(self):
|
||||
def test_get_channel_via_session(self):
|
||||
"""Channels can be accessed through the Session scripting API."""
|
||||
state = AppState()
|
||||
state.load_test(FIXTURE_DATA)
|
||||
ch = state.resolve_channel("IMPAKT_SYNTH_001::11HEAD0000ACXA")
|
||||
assert ch is not None
|
||||
session = state.primary_test
|
||||
assert session is not None
|
||||
ch_handle = session.channel("11HEAD0000ACXA")
|
||||
assert ch_handle.name == "11HEAD0000ACXA"
|
||||
|
||||
def test_resolve_channel_primary_default(self):
|
||||
def test_session_fluent_transforms(self):
|
||||
"""Fluent transform chaining works through the Session API."""
|
||||
state = AppState()
|
||||
state.load_test(FIXTURE_DATA)
|
||||
ch = state.resolve_channel("11HEAD0000ACXA")
|
||||
assert ch is not None
|
||||
session = state.primary_test
|
||||
ch = session.channel("11HEAD0000ACXA")
|
||||
filtered = ch.transform.cfc(600).transform.y_align()
|
||||
assert filtered.raw.cfc_class == 600
|
||||
assert len(filtered.raw.transform_history) == 2
|
||||
|
||||
def test_resolve_channel_with_cfc(self):
|
||||
def test_session_compute_criteria(self):
|
||||
"""Session.compute_criteria() auto-detects channels."""
|
||||
state = AppState()
|
||||
state.load_test(FIXTURE_DATA)
|
||||
ch = state.resolve_channel("11HEAD0000ACXA", cfc_class=600)
|
||||
assert ch is not None
|
||||
assert ch.cfc_class == 600
|
||||
|
||||
def test_flat_channel_list(self):
|
||||
state = AppState()
|
||||
state.load_test(FIXTURE_DATA)
|
||||
items = state.flat_channel_list()
|
||||
assert len(items) == 26
|
||||
assert all("value" in item and "label" in item for item in items)
|
||||
criteria = state.primary_test.compute_criteria()
|
||||
assert len(criteria) > 0
|
||||
assert "HIC15" in criteria or "Chest Deflection" in criteria
|
||||
|
||||
def test_build_channel_tree(self):
|
||||
state = AppState()
|
||||
state.load_test(FIXTURE_DATA)
|
||||
tree = state.build_channel_tree()
|
||||
assert "IMPAKT_SYNTH_001" in tree
|
||||
# Should have hierarchical structure
|
||||
test_tree = tree["IMPAKT_SYNTH_001"]
|
||||
assert len(test_tree) > 0
|
||||
|
||||
@@ -94,15 +94,23 @@ class TestAppState:
|
||||
class TestAppStateRealData:
|
||||
def test_load_real_mme(self):
|
||||
state = AppState()
|
||||
loaded = state.load_test(MME_DATA / "3239")
|
||||
assert loaded.test_id == "3239"
|
||||
assert loaded.channel_count == 133
|
||||
session = state.load_test(MME_DATA / "3239")
|
||||
assert session.test_id == "3239"
|
||||
assert len(session) == 133
|
||||
|
||||
def test_channel_tree_real_data(self):
|
||||
state = AppState()
|
||||
state.load_test(MME_DATA / "3239")
|
||||
tree = state.build_channel_tree()
|
||||
assert "3239" in tree
|
||||
# Should contain "Driver" in some key
|
||||
test_tree = tree["3239"]
|
||||
assert any("Driver" in k for k in test_tree)
|
||||
|
||||
def test_session_evaluate_real_data(self):
|
||||
"""Full pipeline through Session API on real data."""
|
||||
state = AppState()
|
||||
state.load_test(MME_DATA / "3239")
|
||||
result = state.primary_test.evaluate("euro_ncap")
|
||||
assert result.stars is not None
|
||||
assert result.stars >= 0
|
||||
assert len(result.region_scores) > 0
|
||||
|
||||
Reference in New Issue
Block a user