Private
Public Access
0
0
Files
manual_slop/tests/test_persona_manager.py
T
ed 8f11340b38 refactor(consumers): migrate 85 'from src.models import' sites to direct subsystem imports
Per post_module_taxonomy_de_cruft_20260627 Phase 2 (FR7). Each
'from src.models import X' for a moved class is rewritten to
'from src.<destination> import X':

  Ticket, Track, WorkerContext, TrackState, TrackMetadata,
    ThinkingSegment, EMPTY_TRACK_STATE            -> src.mma
  ProjectContext, ProjectMeta, ProjectOutput, ProjectFiles,
    ProjectScreenshots, ProjectDiscussion, EMPTY_PROJECT_CONTEXT -> src.project
  FileItem, Preset, ContextPreset, ContextFileEntry,
    NamedViewPreset                                -> src.project_files
  Tool, ToolPreset                                 -> src.tool_presets
  BiasProfile                                      -> src.tool_bias
  TextEditorConfig, ExternalEditorConfig,
    EMPTY_TEXT_EDITOR_CONFIG                       -> src.external_editor
  Persona                                          -> src.personas
  WorkspaceProfile                                -> src.workspace_manager
  MCPServerConfig, MCPConfiguration, VectorStoreConfig,
    RAGConfig, load_mcp_config                      -> src.mcp_client

NOT touched (kept on src.models; Phase 3 or Phase 4 will move them):
  GenerateRequest, ConfirmRequest, DEFAULT_TOOL_CATEGORIES, Metadata, PROVIDERS

Migration was performed by the one-time script
scripts/tier2/artifacts/post_module_taxonomy_de_cruft_20260627/migrate_imports.py
which uses a class-to-module map and re.sub() to rewrite each
'from src.models import X' line.

Total: 85 import lines rewritten across 71 files.

Note: this commit depends on the v2 SHIPPED work
(origin/tier2/module_taxonomy_refactor_20260627) being merged into
this branch NEXT. On master (without the v2 SHIPPED commits), the
destination modules do not exist and these imports would fail.
2026-06-26 13:34:03 -04:00

82 lines
2.3 KiB
Python

import pytest
import tomli_w
from pathlib import Path
from src.personas import Persona
from src.personas import PersonaManager
from src import paths
@pytest.fixture
def temp_paths(tmp_path, monkeypatch):
global_dir = tmp_path / "global"
global_dir.mkdir()
project_dir = tmp_path / "project"
project_dir.mkdir()
global_path = global_dir / "personas.toml"
project_path = project_dir / "project_personas.toml"
monkeypatch.setattr(paths, "get_global_personas_path", lambda: global_path)
monkeypatch.setattr(paths, "get_project_personas_path", lambda _: project_path)
return {"global": global_path, "project": project_path, "project_root": project_dir}
def test_load_all_merged(temp_paths):
global_data = {
"personas": {
"default": {
"provider": "anthropic",
"model": "claude-3",
"system_prompt": "Global prompt"
},
"global_only": {
"provider": "gemini",
"system_prompt": "Gemini prompt"
}
}
}
with open(temp_paths["global"], "wb") as f:
tomli_w.dump(global_data, f)
project_data = {
"personas": {
"default": {
"provider": "anthropic",
"model": "claude-3.5", # Overrides global
"system_prompt": "Project prompt"
}
}
}
with open(temp_paths["project"], "wb") as f:
tomli_w.dump(project_data, f)
manager = PersonaManager(project_root=temp_paths["project_root"])
all_personas = manager.load_all()
assert "global_only" in all_personas
assert "default" in all_personas
assert all_personas["default"].model == "claude-3.5"
assert all_personas["default"].system_prompt == "Project prompt"
def test_save_persona(temp_paths):
manager = PersonaManager(project_root=temp_paths["project_root"])
persona = Persona(name="New", preferred_models=[{"provider": "gemini"}], system_prompt="Test")
manager.save_persona(persona, scope="project")
loaded = manager.load_all()
assert "New" in loaded
assert loaded["New"].provider == "gemini"
def test_delete_persona(temp_paths):
project_data = {
"personas": {
"to_delete": {"provider": "gemini", "system_prompt": "Del"}
}
}
with open(temp_paths["project"], "wb") as f:
tomli_w.dump(project_data, f)
manager = PersonaManager(project_root=temp_paths["project_root"])
manager.delete_persona("to_delete", scope="project")
loaded = manager.load_all()
assert "to_delete" not in loaded