8f11340b38
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.
24 lines
964 B
Python
24 lines
964 B
Python
import pytest
|
|
from src.mma import Ticket
|
|
|
|
def test_ticket_has_manual_block_field():
|
|
t = Ticket(id="T-001", description="Test")
|
|
assert hasattr(t, 'manual_block'), "Ticket must have manual_block field"
|
|
assert t.manual_block == False, "manual_block should default to False"
|
|
|
|
def test_mark_manual_block_method():
|
|
t = Ticket(id="T-001", description="Test")
|
|
t.mark_manual_block("Test reason")
|
|
assert t.status == "blocked", "Status should be blocked"
|
|
assert t.manual_block == True, "manual_block should be True"
|
|
assert "[MANUAL]" in t.blocked_reason, "blocked_reason should contain [MANUAL]"
|
|
|
|
def test_clear_manual_block_method():
|
|
t = Ticket(id="T-001", description="Test")
|
|
t.mark_manual_block("Test reason")
|
|
assert t.manual_block == True
|
|
t.clear_manual_block()
|
|
assert t.status == "todo", "Status should be restored to todo"
|
|
assert t.manual_block == False, "manual_block should be False"
|
|
assert t.blocked_reason is None, "blocked_reason should be cleared"
|