gstack/browse
Garry Tan 27954de0b0
test(security): classifier gating + status contract (9 tests)
Pure-function tests for security-classifier.ts that don't need a model
download, claude CLI, or network. Covers:

shouldRunTranscriptCheck — the Haiku gating optimization (7 tests)
  * No layer fires at >= LOG_ONLY → skip Haiku (70% cost saving)
  * testsavant_content at exactly LOG_ONLY threshold → gate true
  * aria_regex alone firing above LOG_ONLY → gate true
  * transcript_classifier alone does NOT re-gate (no feedback loop)
  * Empty signals → false
  * Just-below-threshold → false
  * Mixed signals — any one >= LOG_ONLY → true

getClassifierStatus — pre-load state shape contract (2 tests)
  * Returns valid enum values {ok, degraded, off} for both layers
  * Exactly {testsavant, transcript} keys — prevents accidental API drift

Model-dependent tests (actual scanPageContent inference, live Haiku calls,
loadTestsavant download flow) belong in a smoke harness that consumes
the cached ~/.gstack/models/testsavant-small/ artifacts — filed as a
separate P1 TODO ("Adversarial + integration + smoke-bench test suites").

Full security suite now 156 tests / 287 expectations, 112ms.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-04-20 04:21:17 +08:00
..
bin feat: multi-agent support — gstack works on Codex, Gemini CLI, and Cursor (v0.9.0) (#226) 2026-03-19 18:20:50 -07:00
scripts fix: ngrok Windows build + close CI error-swallowing gap (v0.18.0.1) (#1024) 2026-04-16 13:49:04 -07:00
src feat(security): wire logAttempt to gstack-telemetry-log (fire-and-forget) 2026-04-19 19:16:26 +08:00
test test(security): classifier gating + status contract (9 tests) 2026-04-20 04:21:17 +08:00
PLAN-snapshot-dropdown-interactive.md fix: snapshot -i auto-detects dropdown/popover interactive elements (#845) 2026-04-05 22:57:45 -07:00
SKILL.md feat(browse): Puppeteer parity — load-html, screenshot --selector, viewport --scale, file:// (v1.1.0.0) (#1062) 2026-04-18 23:25:33 +08:00
SKILL.md.tmpl feat(browse): Puppeteer parity — load-html, screenshot --selector, viewport --scale, file:// (v1.1.0.0) (#1062) 2026-04-18 23:25:33 +08:00