mirror of
https://github.com/ruvnet/RuView
synced 2026-06-28 13:23:19 +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).
71 lines
2.5 KiB
Python
71 lines
2.5 KiB
Python
"""Tests for MetricsService."""
|
|
|
|
import pytest
|
|
from datetime import timedelta
|
|
from unittest.mock import MagicMock, patch
|
|
|
|
|
|
class TestMetricSeries:
|
|
def test_add_point(self):
|
|
from src.services.metrics import MetricSeries
|
|
ms = MetricSeries(name="test", description="desc", unit="ms")
|
|
ms.add_point(42.0)
|
|
assert len(ms.points) == 1
|
|
assert ms.points[0].value == 42.0
|
|
|
|
def test_get_latest(self):
|
|
from src.services.metrics import MetricSeries
|
|
ms = MetricSeries(name="test", description="desc", unit="ms")
|
|
ms.add_point(1.0)
|
|
ms.add_point(2.0)
|
|
latest = ms.get_latest()
|
|
assert latest is not None
|
|
assert latest.value == 2.0
|
|
|
|
def test_get_latest_empty(self):
|
|
from src.services.metrics import MetricSeries
|
|
ms = MetricSeries(name="test", description="desc", unit="ms")
|
|
assert ms.get_latest() is None
|
|
|
|
def test_get_average(self):
|
|
from src.services.metrics import MetricSeries
|
|
ms = MetricSeries(name="test", description="desc", unit="ms")
|
|
for v in [10.0, 20.0, 30.0]:
|
|
ms.add_point(v)
|
|
avg = ms.get_average(timedelta(minutes=5))
|
|
assert avg == pytest.approx(20.0)
|
|
|
|
def test_get_average_empty(self):
|
|
from src.services.metrics import MetricSeries
|
|
ms = MetricSeries(name="test", description="desc", unit="ms")
|
|
assert ms.get_average(timedelta(minutes=5)) is None
|
|
|
|
def test_get_max(self):
|
|
from src.services.metrics import MetricSeries
|
|
ms = MetricSeries(name="test", description="desc", unit="ms")
|
|
for v in [10.0, 50.0, 30.0]:
|
|
ms.add_point(v)
|
|
mx = ms.get_max(timedelta(minutes=5))
|
|
assert mx == 50.0
|
|
|
|
def test_labels(self):
|
|
from src.services.metrics import MetricSeries
|
|
ms = MetricSeries(name="test", description="desc", unit="ms")
|
|
ms.add_point(1.0, {"region": "us-east"})
|
|
assert ms.points[0].labels["region"] == "us-east"
|
|
|
|
def test_maxlen(self):
|
|
from src.services.metrics import MetricSeries
|
|
ms = MetricSeries(name="test", description="desc", unit="ms")
|
|
for i in range(1100):
|
|
ms.add_point(float(i))
|
|
assert len(ms.points) == 1000
|
|
|
|
|
|
class TestMetricsService:
|
|
def test_init(self, mock_settings):
|
|
with patch("src.services.metrics.psutil"):
|
|
from src.services.metrics import MetricsService
|
|
svc = MetricsService(mock_settings)
|
|
assert svc._metrics is not None
|