mirror of
https://github.com/ruvnet/RuView
synced 2026-06-23 12:33:18 +00:00
81cc241b9e
The Rust port at v2/ has been the primary codebase since the rename in #427. The Python implementation at v1/ is no longer the active target; the only load-bearing path is the deterministic proof bundle at v1/data/proof/ (per ADR-011 / ADR-028 witness verification). Move the whole Python tree into archive/v1/ and document the policy in archive/README.md: no new features, bug fixes only when they affect a still-load-bearing path (currently just the proof), CI continues to verify the proof on every push and PR. Path references updated in 26 files via path-pattern sed (only matches v1/<known-child> patterns, never bare v1 or API URLs like /api/v1/). Two double-prefix typos (archive/archive/v1/) caught and hand-fixed in verify-pipeline.yml and ADR-011. Validated: - Python proof verify.py imports cleanly at archive/v1/data/proof/ (numpy/scipy still required; CI installs requirements-lock.txt from archive/v1/ now) - cargo test --workspace --no-default-features → 1,539 passed, 0 failed, 8 ignored (unaffected by Python tree relocation) - ESP32-S3 on COM7 untouched (no firmware paths changed) After-merge: contributors should re-run any local `python v1/...` commands as `python archive/v1/...` (CLAUDE.md and CHANGELOG already updated).
74 lines
2.9 KiB
Python
74 lines
2.9 KiB
Python
"""Tests for PoseService."""
|
|
|
|
import pytest
|
|
import asyncio
|
|
from unittest.mock import MagicMock, AsyncMock, patch
|
|
from datetime import datetime
|
|
|
|
|
|
class TestPoseServiceInit:
|
|
def test_init_sets_defaults(self, mock_settings, mock_domain_config):
|
|
with patch.dict("sys.modules", {
|
|
"torch": MagicMock(),
|
|
"src.models.densepose_head": MagicMock(),
|
|
"src.models.modality_translation": MagicMock(),
|
|
}):
|
|
from src.services.pose_service import PoseService
|
|
svc = PoseService(mock_settings, mock_domain_config)
|
|
assert svc.is_initialized is False
|
|
assert svc.is_running is False
|
|
assert svc.stats["total_processed"] == 0
|
|
|
|
def test_stats_are_zero_on_init(self, mock_settings, mock_domain_config):
|
|
with patch.dict("sys.modules", {
|
|
"torch": MagicMock(),
|
|
"src.models.densepose_head": MagicMock(),
|
|
"src.models.modality_translation": MagicMock(),
|
|
}):
|
|
from src.services.pose_service import PoseService
|
|
svc = PoseService(mock_settings, mock_domain_config)
|
|
assert svc.stats["successful_detections"] == 0
|
|
assert svc.stats["failed_detections"] == 0
|
|
assert svc.stats["average_confidence"] == 0.0
|
|
|
|
|
|
class TestPoseServiceLifecycle:
|
|
@pytest.mark.asyncio
|
|
async def test_initialize_sets_flag(self, mock_settings, mock_domain_config):
|
|
with patch.dict("sys.modules", {
|
|
"torch": MagicMock(),
|
|
"src.models.densepose_head": MagicMock(),
|
|
"src.models.modality_translation": MagicMock(),
|
|
}):
|
|
from src.services.pose_service import PoseService
|
|
svc = PoseService(mock_settings, mock_domain_config)
|
|
await svc.initialize()
|
|
assert svc.is_initialized is True
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_start_stop(self, mock_settings, mock_domain_config):
|
|
with patch.dict("sys.modules", {
|
|
"torch": MagicMock(),
|
|
"src.models.densepose_head": MagicMock(),
|
|
"src.models.modality_translation": MagicMock(),
|
|
}):
|
|
from src.services.pose_service import PoseService
|
|
svc = PoseService(mock_settings, mock_domain_config)
|
|
await svc.initialize()
|
|
await svc.start()
|
|
assert svc.is_running is True
|
|
await svc.stop()
|
|
assert svc.is_running is False
|
|
|
|
|
|
class TestPoseServiceStats:
|
|
def test_initial_classification(self, mock_settings, mock_domain_config):
|
|
with patch.dict("sys.modules", {
|
|
"torch": MagicMock(),
|
|
"src.models.densepose_head": MagicMock(),
|
|
"src.models.modality_translation": MagicMock(),
|
|
}):
|
|
from src.services.pose_service import PoseService
|
|
svc = PoseService(mock_settings, mock_domain_config)
|
|
assert svc.last_error is None
|