nWave/skills/nw-buddy-ssot-knowledge/SKILL.md
Single Source of Truth detection — where truth lives in an nWave repo and how to avoid contradicting it.
npx skillsauth add nwave-ai/nwave nw-buddy-ssot-knowledgeInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Large projects accumulate multiple copies of "the same" information: a version in pyproject.toml, a version in a VERSION file, a version in the README, a version in a changelog. When these disagree, the buddy agent must know which one is authoritative. This skill is the SSOT map for nWave projects.
Answering a user's question with a stale secondary copy is worse than saying "I don't know": it spreads wrong information with a confident tone. The buddy's job is to read the authoritative source every time, and to flag contradictions when the copies diverge.
Each concept below has one authoritative file. Read that file first. Treat everything else as a cache that may be stale.
pyproject.toml [project] version = "..." (or the equivalent field in the package manifest for non-Python projects).VERSION file, README badges, docs footer, release notes.pyproject.toml. If asked about a cache that disagrees, report the discrepancy.BACKLOG.md at the repo root.BACKLOG.md is not planned. Don't invent items. If the user mentions something not on the backlog, point that out and suggest they add it.docs/architecture/architecture-design.md (or whichever file the project uses as the single architecture doc — usually linked from CLAUDE.md or README.md).docs/feature/ with wave subdirectories, ADRs in docs/adrs/, diagrams in docs/, comments in code.pyproject.toml, .pre-commit-config.yaml, ci.yml, whichever applies).framework-catalog.yaml or equivalent) if the project uses one.git status, git log, git branch.When two sources disagree and it isn't obvious which wins, use this hierarchy from most to least authoritative:
BACKLOG.md, architecture-design.md, etc.).Reporting a conflict is a valuable answer. "The README says X but the code does Y — you probably want to update the README" is more useful than picking one silently.
Signals that a doc is out of date:
pyproject.toml.When you spot one, mention it in the answer and suggest it be updated or deleted.
Before any concrete answer:
Don't answer from memory. The buddy agent's memory is not an SSOT; the repo is.
If you don't find the information, say so and suggest where the user might add it. Never fabricate a file path, a function name, a version number, or a backlog item. Fabrication destroys trust; "I couldn't find this" preserves it.
User asks: "what version are we on and what's next?"
Good answer:
We're on v2.17.5 (
pyproject.toml:3). The top three items inBACKLOG.mdare:
- Finish the D-PLUGIN-00b delivery (
BACKLOG.md:12)- Docker validation matrix refresh (
BACKLOG.md:27)- CI matrix expansion (
BACKLOG.md:34)Note: the README badge shows v2.17.3 — probably stale, consider updating.
Bad answer:
I think we're on v2.17 something and you're working on the plugin feature.
The good answer is sourced, cited, and adds a finding. The bad answer is vibes.
testing
Runs feature-scoped mutation testing to validate test suite quality. Use after implementation to verify tests catch real bugs (kill rate >= 80%).
development
Canonical AT completeness gate — research-anchored 7-category taxonomy (C1-C7) + 15-item mechanical checklist. Paradigm-neutral. Drives acceptance-designer reviewer verdict deterministically.
development
Canonical AT completeness gate — research-anchored 7-category taxonomy (C1-C7) + 15-item mechanical checklist. Paradigm-neutral. Drives acceptance-designer reviewer verdict deterministically.
testing
Methodology for minimizing test count while maximizing behavioral coverage - behavior definition, anti-pattern catalog, consolidation patterns, stopping criterion, coverage-preserving validation