bacddc8549
TIER-2 READ AGENTS.md conductor/workflow.md conductor/edit_workflow.md conductor/tier2/githooks/forbidden-files.txt conductor/tracks/tier2_leak_prevention_20260620/spec.md conductor/code_styleguides/data_oriented_design.md conductor/code_styleguides/error_handling.md conductor/code_styleguides/type_aliases.md before Phase 0 Tasks 0.1, 0.2, 0.4. Phase 0 of metadata_promotion_20260624. 11 NEW per-aggregate dataclasses added to src/type_aliases.py (CommsLogEntry, HistoryMessage, FileItem, ToolDefinition, SessionInsights, DiscussionSettings, CustomSlice, MMAUsageStats, ProviderPayload, UIPanelConfig, PathInfo) + RAGChunk added to src/rag_engine.py. Metadata: TypeAlias = dict[str, Any] preserved unchanged as the catch-all for collapsed codepaths. Each dataclass has paired to_dict()/from_dict() methods. 11 regression-guard test files created with 5-7 tests each (~70 tests total). All tests PASS. The existing tests/test_type_aliases.py was updated to reflect the NEW design (CommsLogEntry etc. are now classes, not aliases to Metadata). Conventions: 1-space indentation, CRLF preserved, no comments.
51 lines
1.3 KiB
Python
51 lines
1.3 KiB
Python
"""Tests for DiscussionSettings in src/type_aliases.py
|
|
|
|
Per-aggregate dataclass regression-guard for the metadata_promotion_20260624 track.
|
|
|
|
CONVENTION: 1-space indentation. NO COMMENTS.
|
|
"""
|
|
from __future__ import annotations
|
|
|
|
from dataclasses import FrozenInstanceError
|
|
|
|
import pytest
|
|
|
|
from src.type_aliases import DiscussionSettings
|
|
|
|
|
|
def test_constructor_with_kwargs() -> None:
|
|
ds = DiscussionSettings(temperature=0.5, top_p=0.9, max_output_tokens=2048)
|
|
assert ds.temperature == 0.5
|
|
assert ds.top_p == 0.9
|
|
assert ds.max_output_tokens == 2048
|
|
|
|
|
|
def test_field_access() -> None:
|
|
ds = DiscussionSettings(temperature=0.0)
|
|
assert ds.temperature == 0.0
|
|
|
|
|
|
def test_frozen_raises_on_mutation() -> None:
|
|
ds = DiscussionSettings()
|
|
with pytest.raises(FrozenInstanceError):
|
|
ds.temperature = 0.5
|
|
|
|
|
|
def test_to_dict_roundtrip() -> None:
|
|
ds = DiscussionSettings(temperature=0.3, top_p=0.7, max_output_tokens=1024)
|
|
d = ds.to_dict()
|
|
assert d["temperature"] == 0.3
|
|
assert d["top_p"] == 0.7
|
|
assert d["max_output_tokens"] == 1024
|
|
|
|
|
|
def test_default_values() -> None:
|
|
ds = DiscussionSettings()
|
|
assert ds.temperature == 0.7
|
|
assert ds.top_p == 1.0
|
|
assert ds.max_output_tokens == 0
|
|
|
|
|
|
def test_hashability() -> None:
|
|
ds = DiscussionSettings(temperature=0.5)
|
|
assert hash(ds) is not None |