savepoint 1.0.3 → 1.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +10 -3
- package/{savepoint → savepoint.exe} +0 -0
- package/.claude/settings.local.json +0 -38
- package/.golangci.yml +0 -11
- package/.prettierignore +0 -4
- package/.savepoint/Design.md +0 -206
- package/.savepoint/PRD.md +0 -58
- package/.savepoint/config.yml +0 -27
- package/.savepoint/releases/v1/epics/E01-go-setup/E01-Detail.md +0 -39
- package/.savepoint/releases/v1/epics/E01-go-setup/tasks/T001-init-module.md +0 -42
- package/.savepoint/releases/v1/epics/E01-go-setup/tasks/T002-entrypoint.md +0 -23
- package/.savepoint/releases/v1/epics/E01-go-setup/tasks/T003-directory-structure.md +0 -24
- package/.savepoint/releases/v1/epics/E01-go-setup/tasks/T004-makefile.md +0 -23
- package/.savepoint/releases/v1/epics/E02-data-readers/E02-Detail.md +0 -61
- package/.savepoint/releases/v1/epics/E02-data-readers/tasks/T001-task-struct.md +0 -29
- package/.savepoint/releases/v1/epics/E02-data-readers/tasks/T002-frontmatter-parser.md +0 -30
- package/.savepoint/releases/v1/epics/E02-data-readers/tasks/T003-router-reader.md +0 -29
- package/.savepoint/releases/v1/epics/E02-data-readers/tasks/T004-config-reader.md +0 -29
- package/.savepoint/releases/v1/epics/E02-data-readers/tasks/T005-discovery.md +0 -30
- package/.savepoint/releases/v1/epics/E03-board-tui-core/E03-Detail.md +0 -38
- package/.savepoint/releases/v1/epics/E03-board-tui-core/tasks/T001-model.md +0 -29
- package/.savepoint/releases/v1/epics/E03-board-tui-core/tasks/T002-update-loop.md +0 -30
- package/.savepoint/releases/v1/epics/E03-board-tui-core/tasks/T003-view.md +0 -34
- package/.savepoint/releases/v1/epics/E03-board-tui-core/tasks/T004-styles.md +0 -29
- package/.savepoint/releases/v1/epics/E03-board-tui-core/tasks/T005-layout.md +0 -42
- package/.savepoint/releases/v1/epics/E04-board-components/E04-Detail.md +0 -44
- package/.savepoint/releases/v1/epics/E04-board-components/tasks/T001-column.md +0 -34
- package/.savepoint/releases/v1/epics/E04-board-components/tasks/T002-card.md +0 -33
- package/.savepoint/releases/v1/epics/E04-board-components/tasks/T003-epic-panel.md +0 -49
- package/.savepoint/releases/v1/epics/E04-board-components/tasks/T004-detail-overlay.md +0 -40
- package/.savepoint/releases/v1/epics/E04-board-components/tasks/T005-release-dropdown.md +0 -33
- package/.savepoint/releases/v1/epics/E04-board-components/tasks/T006-help-overlay.md +0 -34
- package/.savepoint/releases/v1/epics/E05-phase-transitions/E05-Detail.md +0 -38
- package/.savepoint/releases/v1/epics/E05-phase-transitions/tasks/T001-phase-stepping.md +0 -29
- package/.savepoint/releases/v1/epics/E05-phase-transitions/tasks/T002-gates.md +0 -31
- package/.savepoint/releases/v1/epics/E05-phase-transitions/tasks/T003-write-task.md +0 -31
- package/.savepoint/releases/v1/epics/E05-phase-transitions/tasks/T004-write-router.md +0 -31
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/E06-Detail.md +0 -62
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T001-color-system.md +0 -39
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T002-header-and-dividers.md +0 -52
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T003-footer-status-bar.md +0 -52
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T004-component-refinement.md +0 -53
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T005-restore-nav-hints.md +0 -39
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T007-detail-card-fixes.md +0 -36
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T008-checkbox-states.md +0 -40
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T009-router-priority-marker.md +0 -48
- package/.savepoint/releases/v1/epics/E06-atari-noir-layout/tasks/T010-auto-refresh-watcher.md +0 -66
- package/.savepoint/releases/v1/epics/_archived/E01-archive-and-reset/Design.md +0 -39
- package/.savepoint/releases/v1/epics/_archived/E01-archive-and-reset/tasks/T001-archive-epics.md +0 -20
- package/.savepoint/releases/v1/epics/_archived/E01-archive-and-reset/tasks/T002-rewrite-prd.md +0 -22
- package/.savepoint/releases/v1/epics/_archived/E01-archive-and-reset/tasks/T003-create-epic-stubs.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E01-archive-and-reset/tasks/T004-update-router.md +0 -22
- package/.savepoint/releases/v1/epics/_archived/E01-scaffolding/Design.md +0 -118
- package/.savepoint/releases/v1/epics/_archived/E01-scaffolding/handoff.md +0 -9
- package/.savepoint/releases/v1/epics/_archived/E01-scaffolding/tasks/T001-package-baseline.md +0 -45
- package/.savepoint/releases/v1/epics/_archived/E01-scaffolding/tasks/T002-typescript-build.md +0 -48
- package/.savepoint/releases/v1/epics/_archived/E01-scaffolding/tasks/T003-vitest-smoke.md +0 -43
- package/.savepoint/releases/v1/epics/_archived/E01-scaffolding/tasks/T004-lint-format-gates.md +0 -45
- package/.savepoint/releases/v1/epics/_archived/E01-scaffolding/tasks/T005-scaffold-verification.md +0 -40
- package/.savepoint/releases/v1/epics/_archived/E02-data-model/Design.md +0 -142
- package/.savepoint/releases/v1/epics/_archived/E02-data-model/tasks/T001-domain-ids-status.md +0 -27
- package/.savepoint/releases/v1/epics/_archived/E02-data-model/tasks/T002-markdown-frontmatter-boundary.md +0 -28
- package/.savepoint/releases/v1/epics/_archived/E02-data-model/tasks/T003-task-documents.md +0 -29
- package/.savepoint/releases/v1/epics/_archived/E02-data-model/tasks/T004-release-epic-router-config-readers.md +0 -30
- package/.savepoint/releases/v1/epics/_archived/E02-data-model/tasks/T005-dependency-validation.md +0 -29
- package/.savepoint/releases/v1/epics/_archived/E02-data-model/tasks/T006-epic-task-set-reader.md +0 -29
- package/.savepoint/releases/v1/epics/_archived/E02-data-model/tasks/T007-quality-gates.md +0 -31
- package/.savepoint/releases/v1/epics/_archived/E02-domain-phase-model/Design.md +0 -40
- package/.savepoint/releases/v1/epics/_archived/E02-domain-phase-model/tasks/T001-phase-types.md +0 -27
- package/.savepoint/releases/v1/epics/_archived/E02-domain-phase-model/tasks/T002-phase-frontmatter.md +0 -25
- package/.savepoint/releases/v1/epics/_archived/E02-domain-phase-model/tasks/T003-simplify-config.md +0 -26
- package/.savepoint/releases/v1/epics/_archived/E02-domain-phase-model/tasks/T004-simplify-router-domain.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E03-cli-foundation/Design.md +0 -122
- package/.savepoint/releases/v1/epics/_archived/E03-cli-foundation/tasks/T001-argument-parser-contract.md +0 -28
- package/.savepoint/releases/v1/epics/_archived/E03-cli-foundation/tasks/T002-help-text-generation.md +0 -28
- package/.savepoint/releases/v1/epics/_archived/E03-cli-foundation/tasks/T003-terminal-environment-detection.md +0 -27
- package/.savepoint/releases/v1/epics/_archived/E03-cli-foundation/tasks/T004-command-stub-modules.md +0 -29
- package/.savepoint/releases/v1/epics/_archived/E03-cli-foundation/tasks/T005-cli-runner-dispatch.md +0 -34
- package/.savepoint/releases/v1/epics/_archived/E03-cli-foundation/tasks/T006-entrypoint-quality-gates.md +0 -32
- package/.savepoint/releases/v1/epics/_archived/E03-cli-simplify/Design.md +0 -43
- package/.savepoint/releases/v1/epics/_archived/E03-cli-simplify/tasks/T001-strip-args.md +0 -26
- package/.savepoint/releases/v1/epics/_archived/E03-cli-simplify/tasks/T002-strip-help.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E03-cli-simplify/tasks/T003-strip-run.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E03-cli-simplify/tasks/T004-delete-commands.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E03-cli-simplify/tasks/T005-update-cli-tests.md +0 -22
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/Design.md +0 -48
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/tasks/T001-board-data-phases.md +0 -26
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/tasks/T002-phase-rendering.md +0 -28
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/tasks/T003-detail-pane-phases.md +0 -27
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/tasks/T004-phase-transitions.md +0 -42
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/tasks/T005-phase-gates.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/tasks/T006-phase-write-back.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/tasks/T007-remove-audit-flow.md +0 -27
- package/.savepoint/releases/v1/epics/_archived/E04-board-phase-integration/tasks/T008-board-tests.md +0 -25
- package/.savepoint/releases/v1/epics/_archived/E04-templates-and-prompts/Design.md +0 -85
- package/.savepoint/releases/v1/epics/_archived/E04-templates-and-prompts/tasks/T001-project-template-assets.md +0 -17
- package/.savepoint/releases/v1/epics/_archived/E04-templates-and-prompts/tasks/T002-release-and-prompt-assets.md +0 -20
- package/.savepoint/releases/v1/epics/_archived/E04-templates-and-prompts/tasks/T003-template-registry-renderer.md +0 -22
- package/.savepoint/releases/v1/epics/_archived/E04-templates-and-prompts/tasks/T004-template-integrity-tests.md +0 -17
- package/.savepoint/releases/v1/epics/_archived/E04-templates-and-prompts/tasks/T005-template-closeout-quality-gates.md +0 -16
- package/.savepoint/releases/v1/epics/_archived/E05-init-command/Design.md +0 -88
- package/.savepoint/releases/v1/epics/_archived/E05-init-command/tasks/T001-init-cli-contract.md +0 -22
- package/.savepoint/releases/v1/epics/_archived/E05-init-command/tasks/T002-target-validation.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E05-init-command/tasks/T003-scaffold-writer.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E05-init-command/tasks/T004-magic-prompt-and-clipboard.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E05-init-command/tasks/T005-dev-deps-install-option.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E05-init-command/tasks/T006-init-command-integration.md +0 -28
- package/.savepoint/releases/v1/epics/_archived/E05-project-cleanup/Design.md +0 -53
- package/.savepoint/releases/v1/epics/_archived/E05-project-cleanup/tasks/T001-delete-dead-src.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E05-project-cleanup/tasks/T002-delete-dead-tests.md +0 -26
- package/.savepoint/releases/v1/epics/_archived/E05-project-cleanup/tasks/T003-delete-assets.md +0 -25
- package/.savepoint/releases/v1/epics/_archived/E05-project-cleanup/tasks/T004-clean-savepoint.md +0 -28
- package/.savepoint/releases/v1/epics/_archived/E05-project-cleanup/tasks/T005-rewrite-agents-md.md +0 -28
- package/.savepoint/releases/v1/epics/_archived/E05-project-cleanup/tasks/T006-clean-package-json.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E05-project-cleanup/tasks/T007-verify.md +0 -25
- package/.savepoint/releases/v1/epics/_archived/E06-tui-board/Design.md +0 -104
- package/.savepoint/releases/v1/epics/_archived/E06-tui-board/tasks/T001-board-command-data.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E06-tui-board/tasks/T002-board-view-state.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E06-tui-board/tasks/T003-transition-gates-and-writes.md +0 -25
- package/.savepoint/releases/v1/epics/_archived/E06-tui-board/tasks/T004-terminal-theme.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E06-tui-board/tasks/T005-ink-board-ui.md +0 -26
- package/.savepoint/releases/v1/epics/_archived/E06-tui-board/tasks/T006-board-integration-audit-entry.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/Design.md +0 -88
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/tasks/T001-audit-cli-contract.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/tasks/T002-quality-gate-runner.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/tasks/T003-snapshot-and-prompt.md +0 -23
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/tasks/T004-audit-orchestration-router.md +0 -27
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/tasks/T005-proposal-validation-apply.md +0 -25
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/tasks/T006-audit-review-state.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/tasks/T007-audit-review-ui.md +0 -26
- package/.savepoint/releases/v1/epics/_archived/E07-audit-pipeline/tasks/T008-audit-pipeline-integration.md +0 -24
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/Design.md +0 -103
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/tasks/T001-acceptance-criteria-model.md +0 -30
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/tasks/T002-release-task-set-reader.md +0 -33
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/tasks/T003-board-data-and-plain-output.md +0 -34
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/tasks/T004-board-selection-state.md +0 -33
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/tasks/T005-ink-board-layout-cleanup.md +0 -37
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/tasks/T006-task-detail-popup.md +0 -36
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/tasks/T007-templates-acceptance-criteria.md +0 -34
- package/.savepoint/releases/v1/epics/_archived/E08-board-workflow-cleanup/tasks/T008-board-workflow-integration.md +0 -41
- package/.savepoint/releases/v1/epics/_archived/E09-doctor-command/Design.md +0 -70
- package/.savepoint/releases/v1/epics/_archived/E10-docs-and-packaging/Design.md +0 -68
- package/.savepoint/releases/v1/epics/_archived/E11-release-validation/Design.md +0 -68
- package/.savepoint/releases/v1/v1-PRD.md +0 -66
- package/.savepoint/releases/v1.1/epics/E01-tui-optimisation/E01-Detail.md +0 -40
- package/.savepoint/releases/v1.1/epics/E01-tui-optimisation/tasks/T001-next-activity-header.md +0 -56
- package/.savepoint/releases/v1.1/epics/E01-tui-optimisation/tasks/T002-rename-epic-design-files.md +0 -38
- package/.savepoint/releases/v1.1/epics/E01-tui-optimisation/tasks/T003-rename-release-prd.md +0 -28
- package/.savepoint/releases/v1.1/epics/E01-tui-optimisation/tasks/T004-update-instruction-files.md +0 -51
- package/.savepoint/releases/v1.1/epics/E01-tui-optimisation/tasks/T005-update-cross-references.md +0 -45
- package/.savepoint/releases/v1.1/epics/E01-tui-optimisation/tasks/T006-column-and-detail-scrolling.md +0 -68
- package/.savepoint/releases/v1.1/epics/E01-tui-optimisation/tasks/T007-column-focus-border-stability.md +0 -57
- package/.savepoint/releases/v1.1/epics/E02-cross-platform-compatibility/E02-Audit.md +0 -124
- package/.savepoint/releases/v1.1/epics/E02-cross-platform-compatibility/E02-Detail.md +0 -49
- package/.savepoint/releases/v1.1/epics/E02-cross-platform-compatibility/tasks/T001-fix-makefile.md +0 -37
- package/.savepoint/releases/v1.1/epics/E02-cross-platform-compatibility/tasks/T002-linux-build-target.md +0 -38
- package/.savepoint/releases/v1.1/epics/E02-cross-platform-compatibility/tasks/T003-macos-build-target.md +0 -36
- package/.savepoint/releases/v1.1/epics/E02-cross-platform-compatibility/tasks/T004-smoke-tests-and-artifacts.md +0 -59
- package/.savepoint/releases/v1.1/epics/E03-ui-visual-refinement/E03-Audit.md +0 -195
- package/.savepoint/releases/v1.1/epics/E03-ui-visual-refinement/E03-Detail.md +0 -45
- package/.savepoint/releases/v1.1/epics/E03-ui-visual-refinement/tasks/T001-border-resize-fix.md +0 -40
- package/.savepoint/releases/v1.1/epics/E03-ui-visual-refinement/tasks/T002-next-activity-below-header.md +0 -64
- package/.savepoint/releases/v1.1/epics/E03-ui-visual-refinement/tasks/T003-checkbox-rendering-fix.md +0 -56
- package/.savepoint/releases/v1.1/epics/E03-ui-visual-refinement/tasks/T005-unify-status-glyphs.md +0 -65
- package/.savepoint/releases/v1.1/epics/E03-ui-visual-refinement/tasks/T006-forced-256-color-profile.md +0 -36
- package/.savepoint/releases/v1.1/epics/E04-epic-navigation/E04-Audit.md +0 -167
- package/.savepoint/releases/v1.1/epics/E04-epic-navigation/E04-Detail.md +0 -51
- package/.savepoint/releases/v1.1/epics/E04-epic-navigation/tasks/T001-sidebar-focusable-navigation.md +0 -65
- package/.savepoint/releases/v1.1/epics/E04-epic-navigation/tasks/T002-epic-detail-overlay.md +0 -73
- package/.savepoint/releases/v1.1/epics/E04-epic-navigation/tasks/T003-epic-status-glyphs.md +0 -73
- package/.savepoint/releases/v1.1/epics/E05-tasking-permissions/E05-Audit.md +0 -237
- package/.savepoint/releases/v1.1/epics/E05-tasking-permissions/E05-Detail.md +0 -54
- package/.savepoint/releases/v1.1/epics/E05-tasking-permissions/tasks/T001-update-agents-md.md +0 -45
- package/.savepoint/releases/v1.1/epics/E05-tasking-permissions/tasks/T002-update-router-md.md +0 -40
- package/.savepoint/releases/v1.1/epics/E05-tasking-permissions/tasks/T003-update-design-md.md +0 -47
- package/.savepoint/releases/v1.1/epics/E05-tasking-permissions/tasks/T004-implement-m-hotkey.md +0 -98
- package/.savepoint/releases/v1.1/epics/E05-tasking-permissions/tasks/T005-update-help-overlay.md +0 -33
- package/.savepoint/releases/v1.1/epics/E05-tasking-permissions/tasks/T006-tests-and-quality-gates.md +0 -62
- package/.savepoint/releases/v1.1/epics/E06-audit-command/E06-Audit.md +0 -56
- package/.savepoint/releases/v1.1/epics/E06-audit-command/E06-Detail.md +0 -63
- package/.savepoint/releases/v1.1/epics/E06-audit-command/tasks/T005-proposals.md +0 -44
- package/.savepoint/releases/v1.1/epics/E06-audit-command/tasks/T007-apply-close.md +0 -35
- package/.savepoint/releases/v1.1/epics/E06-audit-command/tasks/T009-integration.md +0 -40
- package/.savepoint/releases/v1.1/epics/E06-audit-command/tasks/T010-audit-file-migration.md +0 -45
- package/.savepoint/releases/v1.1/epics/E06-audit-command/tasks/T011-model-tab-state.md +0 -26
- package/.savepoint/releases/v1.1/epics/E06-audit-command/tasks/T012-epic-audit-render.md +0 -33
- package/.savepoint/releases/v1.1/epics/E06-audit-command/tasks/T013-handle-tab-keys.md +0 -34
- package/.savepoint/releases/v1.1/epics/E06-audit-command/tasks/T014-tab-indicator.md +0 -33
- package/.savepoint/releases/v1.1/epics/E07-init-command/E07-Audit.md +0 -336
- package/.savepoint/releases/v1.1/epics/E07-init-command/E07-Detail.md +0 -61
- package/.savepoint/releases/v1.1/epics/E07-init-command/tasks/T001-cli-entrypoint.md +0 -37
- package/.savepoint/releases/v1.1/epics/E07-init-command/tasks/T002-target-validation.md +0 -28
- package/.savepoint/releases/v1.1/epics/E07-init-command/tasks/T003-scaffold-writer.md +0 -46
- package/.savepoint/releases/v1.1/epics/E07-init-command/tasks/T004-atomic-writes.md +0 -27
- package/.savepoint/releases/v1.1/epics/E07-init-command/tasks/T005-magic-prompt.md +0 -25
- package/.savepoint/releases/v1.1/epics/E07-init-command/tasks/T006-clipboard.md +0 -26
- package/.savepoint/releases/v1.1/epics/E07-init-command/tasks/T007-integration-test.md +0 -26
- package/.savepoint/releases/v1.1/epics/E08-board-command/E08-Audit.md +0 -333
- package/.savepoint/releases/v1.1/epics/E08-board-command/E08-Detail.md +0 -68
- package/.savepoint/releases/v1.1/epics/E08-board-command/tasks/T001-cli-entrypoint.md +0 -26
- package/.savepoint/releases/v1.1/epics/E08-board-command/tasks/T002-non-tty-fallback.md +0 -27
- package/.savepoint/releases/v1.1/epics/E08-board-command/tasks/T003-tui-app-shell.md +0 -28
- package/.savepoint/releases/v1.1/epics/E08-board-command/tasks/T004-board-model.md +0 -29
- package/.savepoint/releases/v1.1/epics/E08-board-command/tasks/T005-detail-pane.md +0 -27
- package/.savepoint/releases/v1.1/epics/E08-board-command/tasks/T006-status-transitions.md +0 -29
- package/.savepoint/releases/v1.1/epics/E08-board-command/tasks/T007-theme-fallbacks.md +0 -29
- package/.savepoint/releases/v1.1/epics/E08-board-command/tasks/T008-integration-test.md +0 -27
- package/.savepoint/releases/v1.1/epics/E09-doctor-command/E09-Audit.md +0 -207
- package/.savepoint/releases/v1.1/epics/E09-doctor-command/E09-Detail.md +0 -65
- package/.savepoint/releases/v1.1/epics/E09-doctor-command/tasks/T001-cli-entrypoint.md +0 -24
- package/.savepoint/releases/v1.1/epics/E09-doctor-command/tasks/T002-config-router-validation.md +0 -28
- package/.savepoint/releases/v1.1/epics/E09-doctor-command/tasks/T003-structure-checks.md +0 -29
- package/.savepoint/releases/v1.1/epics/E09-doctor-command/tasks/T004-dependency-checks.md +0 -27
- package/.savepoint/releases/v1.1/epics/E09-doctor-command/tasks/T005-audit-orphan-checks.md +0 -28
- package/.savepoint/releases/v1.1/epics/E09-doctor-command/tasks/T006-quality-gates-report.md +0 -31
- package/.savepoint/releases/v1.1/epics/E11-board-refresh-fix/E11-Detail.md +0 -36
- package/.savepoint/releases/v1.1/epics/E11-board-refresh-fix/tasks/T001-debug-logging.md +0 -25
- package/.savepoint/releases/v1.1/epics/E11-board-refresh-fix/tasks/T002-increase-debounce.md +0 -21
- package/.savepoint/releases/v1.1/epics/E11-board-refresh-fix/tasks/T003-error-handling.md +0 -22
- package/.savepoint/releases/v1.1/epics/E11-board-refresh-fix/tasks/T004-test-verify.md +0 -29
- package/.savepoint/releases/v1.1/epics/E12-validation-fix/E12-Audit.md +0 -444
- package/.savepoint/releases/v1.1/epics/E12-validation-fix/E12-Detail.md +0 -45
- package/.savepoint/releases/v1.1/epics/E12-validation-fix/tasks/T001-default-phase.md +0 -35
- package/.savepoint/releases/v1.1/epics/E12-validation-fix/tasks/T002-default-status.md +0 -19
- package/.savepoint/releases/v1.1/epics/E12-validation-fix/tasks/T003-better-errors.md +0 -29
- package/.savepoint/releases/v1.1/epics/E12-validation-fix/tasks/T004-validate-on-write.md +0 -25
- package/.savepoint/releases/v1.1/epics/E12-validation-fix/tasks/T005-tests.md +0 -37
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/E13-Audit.md +0 -118
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/E13-Detail.md +0 -73
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/tasks/T001-safe-cleanup.md +0 -66
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/tasks/T002-bug-fixes.md +0 -35
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/tasks/T003-centralize-duplication.md +0 -60
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/tasks/T004-infrastructure.md +0 -33
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/tasks/T005-decompose-update.md +0 -37
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/tasks/T006-async-io.md +0 -40
- package/.savepoint/releases/v1.1/epics/E13-audit-remediation/tasks/T007-test-coverage.md +0 -37
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/E14-Audit.md +0 -267
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/E14-Detail.md +0 -54
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/tasks/T001-group-model.md +0 -39
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/tasks/T002-data-interfaces.md +0 -42
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/tasks/T003-discover-orphans.md +0 -33
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/tasks/T004-epic-panel-headings.md +0 -35
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/tasks/T005-shell-tokenization.md +0 -27
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/tasks/T006-unify-enums.md +0 -29
- package/.savepoint/releases/v1.1/epics/E14-structural-improvements/tasks/T007-testutil-package.md +0 -28
- package/.savepoint/releases/v1.1/epics/E15-hardening/E15-Detail.md +0 -43
- package/.savepoint/releases/v1.1/epics/E15-hardening/tasks/T001-benchmarks.md +0 -31
- package/.savepoint/releases/v1.1/epics/E15-hardening/tasks/T002-fuzz-targets.md +0 -28
- package/.savepoint/releases/v1.1/epics/E15-hardening/tasks/T003-debug-flag.md +0 -30
- package/.savepoint/releases/v1.1/epics/E15-hardening/tasks/T004-dist-checksums.md +0 -27
- package/.savepoint/releases/v1.1/epics/E15-hardening/tasks/T005-windows-targets.md +0 -28
- package/.savepoint/releases/v1.1/epics/E15-hardening/tasks/T006-abbreviation-splitting.md +0 -26
- package/.savepoint/releases/v1.1/epics/E15-hardening/tasks/T007-root-test-allowlist.md +0 -28
- package/.savepoint/releases/v1.1/epics/_archived/T001-cli-entrypoint.md +0 -25
- package/.savepoint/releases/v1.1/epics/_archived/T002-quality-gates.md +0 -27
- package/.savepoint/releases/v1.1/epics/_archived/T003-snapshot.md +0 -27
- package/.savepoint/releases/v1.1/epics/_archived/T004-ai-reconcile.md +0 -29
- package/.savepoint/releases/v1.1/epics/_archived/T006-tui-review.md +0 -31
- package/.savepoint/releases/v1.1/epics/_archived/T008-skip-handling.md +0 -34
- package/.savepoint/releases/v1.1/v1.1-PRD.md +0 -139
- package/.savepoint/router.md +0 -57
- package/.savepoint/visual-identity.md +0 -125
- package/AGENTS.md +0 -99
- package/CLAUDE.md +0 -1
- package/GEMINI.md +0 -1
- package/Makefile +0 -29
- package/agent-skills/ink-tui-design/SKILL.md +0 -309
- package/agent-skills/ink-tui-design/references/component-patterns.md +0 -371
- package/agent-skills/ink-tui-design/references/hooks-guide.md +0 -436
- package/agent-skills/ink-tui-design/references/ink-gotchas.md +0 -330
- package/agent-skills/ink-tui-design/references/testing-patterns.md +0 -384
- package/agent-skills/savepoint-audit/SKILL.md +0 -87
- package/agent-skills/savepoint-build-task/SKILL.md +0 -44
- package/agent-skills/savepoint-create-plan/SKILL.md +0 -33
- package/agent-skills/savepoint-create-task/SKILL.md +0 -44
- package/agent-skills/savepoint-draft-prd/SKILL.md +0 -37
- package/agent-skills/savepoint-system-design/SKILL.md +0 -38
- package/agent-skills/superpowers/brainstorming/SKILL.md +0 -165
- package/agent-skills/superpowers/brainstorming/visual-companion.md +0 -304
- package/agent-skills/superpowers/dispatching-parallel-agents/SKILL.md +0 -193
- package/agent-skills/superpowers/executing-plans/SKILL.md +0 -77
- package/agent-skills/superpowers/finishing-a-development-branch/SKILL.md +0 -213
- package/agent-skills/superpowers/receiving-code-review/SKILL.md +0 -226
- package/agent-skills/superpowers/requesting-code-review/SKILL.md +0 -115
- package/agent-skills/superpowers/requesting-code-review/code-reviewer.md +0 -160
- package/agent-skills/superpowers/subagent-driven-development/SKILL.md +0 -292
- package/agent-skills/superpowers/subagent-driven-development/code-quality-reviewer-prompt.md +0 -27
- package/agent-skills/superpowers/subagent-driven-development/implementer-prompt.md +0 -113
- package/agent-skills/superpowers/subagent-driven-development/spec-reviewer-prompt.md +0 -61
- package/agent-skills/superpowers/systematic-debugging/SKILL.md +0 -305
- package/agent-skills/superpowers/systematic-debugging/condition-based-waiting.md +0 -122
- package/agent-skills/superpowers/systematic-debugging/defense-in-depth.md +0 -130
- package/agent-skills/superpowers/systematic-debugging/root-cause-tracing.md +0 -183
- package/agent-skills/superpowers/test-driven-development/SKILL.md +0 -389
- package/agent-skills/superpowers/test-driven-development/testing-anti-patterns.md +0 -317
- package/agent-skills/superpowers/verification-before-completion/SKILL.md +0 -147
- package/agent-skills/superpowers/writing-plans/SKILL.md +0 -159
- package/agent-skills/superpowers/writing-plans/plan-document-reviewer-prompt.md +0 -49
- package/agent_skills_test.go +0 -91
- package/assets/banner.png +0 -0
- package/assets/logo.png +0 -0
- package/assets/strawman.png +0 -0
- package/cmd/board.go +0 -59
- package/cmd/board_test.go +0 -137
- package/cmd/doctor.go +0 -53
- package/cmd/doctor_test.go +0 -146
- package/cmd/init.go +0 -63
- package/cmd/init_test.go +0 -104
- package/go.mod +0 -36
- package/go.sum +0 -75
- package/internal/board/board.go +0 -177
- package/internal/board/board_test.go +0 -168
- package/internal/board/card.go +0 -129
- package/internal/board/card_test.go +0 -254
- package/internal/board/column.go +0 -127
- package/internal/board/column_test.go +0 -139
- package/internal/board/detail.go +0 -185
- package/internal/board/detail_test.go +0 -340
- package/internal/board/epic_panel.go +0 -262
- package/internal/board/epic_panel_test.go +0 -869
- package/internal/board/help.go +0 -41
- package/internal/board/help_test.go +0 -86
- package/internal/board/integration_test.go +0 -266
- package/internal/board/interfaces.go +0 -65
- package/internal/board/interfaces_test.go +0 -114
- package/internal/board/io.go +0 -93
- package/internal/board/layout.go +0 -68
- package/internal/board/layout_test.go +0 -106
- package/internal/board/model.go +0 -235
- package/internal/board/model_test.go +0 -67
- package/internal/board/plain.go +0 -88
- package/internal/board/plain_test.go +0 -117
- package/internal/board/release.go +0 -34
- package/internal/board/release_test.go +0 -177
- package/internal/board/render_policy_test.go +0 -77
- package/internal/board/status.go +0 -23
- package/internal/board/theme.go +0 -24
- package/internal/board/theme_test.go +0 -31
- package/internal/board/transitions.go +0 -113
- package/internal/board/transitions_test.go +0 -164
- package/internal/board/tui.go +0 -32
- package/internal/board/update.go +0 -556
- package/internal/board/update_test.go +0 -575
- package/internal/board/util.go +0 -76
- package/internal/board/view.go +0 -317
- package/internal/board/view_test.go +0 -315
- package/internal/board/watch.go +0 -130
- package/internal/buildtool/main.go +0 -211
- package/internal/buildtool/main_test.go +0 -46
- package/internal/data/config.go +0 -101
- package/internal/data/config_test.go +0 -122
- package/internal/data/discover.go +0 -178
- package/internal/data/discover_test.go +0 -130
- package/internal/data/errors.go +0 -13
- package/internal/data/lifecycle.go +0 -44
- package/internal/data/lifecycle_test.go +0 -41
- package/internal/data/parser.go +0 -242
- package/internal/data/parser_test.go +0 -281
- package/internal/data/router.go +0 -52
- package/internal/data/router_test.go +0 -35
- package/internal/data/task.go +0 -57
- package/internal/data/task_test.go +0 -51
- package/internal/data/write.go +0 -218
- package/internal/data/write_test.go +0 -623
- package/internal/doctor/checks.go +0 -567
- package/internal/doctor/checks_test.go +0 -716
- package/internal/doctor/gates.go +0 -193
- package/internal/doctor/gates_test.go +0 -166
- package/internal/doctor/interfaces.go +0 -64
- package/internal/doctor/interfaces_test.go +0 -104
- package/internal/doctor/repairs.go +0 -80
- package/internal/doctor/repairs_test.go +0 -81
- package/internal/doctor/report.go +0 -157
- package/internal/doctor/report_test.go +0 -89
- package/internal/init/clipboard.go +0 -146
- package/internal/init/clipboard_test.go +0 -74
- package/internal/init/install.go +0 -16
- package/internal/init/integration_test.go +0 -197
- package/internal/init/prompt.go +0 -14
- package/internal/init/prompt_test.go +0 -77
- package/internal/init/scaffold.go +0 -59
- package/internal/init/scaffold_test.go +0 -179
- package/internal/init/template_freshness_test.go +0 -56
- package/internal/init/validate.go +0 -85
- package/internal/init/validate_test.go +0 -141
- package/internal/init/write.go +0 -73
- package/internal/init/write_test.go +0 -91
- package/internal/styles/palette.go +0 -49
- package/internal/styles/styles.go +0 -139
- package/internal/styles/styles_test.go +0 -133
- package/internal/testutil/fixture.go +0 -113
- package/internal/testutil/fs.go +0 -26
- package/main.go +0 -117
- package/project-audit/audit_report_glm_5.1.md +0 -411
- package/project-audit/audit_report_opus_4.6 +0 -406
- package/project-audit/consolidated-audit-report.md +0 -456
- package/scripts/vitest-preload.cjs +0 -95
- package/templates/project/.savepoint/Design.md +0 -47
- package/templates/project/.savepoint/PRD.md +0 -34
- package/templates/project/.savepoint/config.yml +0 -27
- package/templates/project/.savepoint/router.md +0 -153
- package/templates/project/.savepoint/visual-identity.md +0 -122
- package/templates/project/AGENTS.md +0 -88
- package/templates/project/agent-skills/savepoint-audit/SKILL.md +0 -87
- package/templates/project/agent-skills/savepoint-build-task/SKILL.md +0 -44
- package/templates/project/agent-skills/savepoint-create-plan/SKILL.md +0 -33
- package/templates/project/agent-skills/savepoint-create-task/SKILL.md +0 -44
- package/templates/project/agent-skills/savepoint-draft-prd/SKILL.md +0 -37
- package/templates/project/agent-skills/savepoint-system-design/SKILL.md +0 -38
- package/templates/prompts/audit-reconciliation.prompt.md +0 -72
- package/templates/prompts/design.prompt.md +0 -45
- package/templates/prompts/epic-design.prompt.md +0 -43
- package/templates/prompts/magic-prompt.prompt.md +0 -7
- package/templates/prompts/prd.prompt.md +0 -42
- package/templates/prompts/task-breakdown.prompt.md +0 -54
- package/templates/prompts/task-building.prompt.md +0 -38
- package/templates/prompts/task-planning.prompt.md +0 -53
- package/templates/release/v1/PRD.md +0 -37
|
@@ -1,317 +0,0 @@
|
|
|
1
|
-
# Testing Anti-Patterns
|
|
2
|
-
|
|
3
|
-
**Load this reference when:** writing or changing tests, adding mocks, or tempted to add test-only methods to production code.
|
|
4
|
-
|
|
5
|
-
## Overview
|
|
6
|
-
|
|
7
|
-
Tests must verify real behavior, not mock behavior. Mocks are a means to isolate, not the thing being tested.
|
|
8
|
-
|
|
9
|
-
**Core principle:** Test what the code does, not what the mocks do.
|
|
10
|
-
|
|
11
|
-
**Following strict TDD prevents these anti-patterns.**
|
|
12
|
-
|
|
13
|
-
## The Iron Laws
|
|
14
|
-
|
|
15
|
-
```
|
|
16
|
-
1. NEVER test mock behavior
|
|
17
|
-
2. NEVER add test-only methods to production classes
|
|
18
|
-
3. NEVER mock without understanding dependencies
|
|
19
|
-
```
|
|
20
|
-
|
|
21
|
-
## Anti-Pattern 1: Testing Mock Behavior
|
|
22
|
-
|
|
23
|
-
**The violation:**
|
|
24
|
-
|
|
25
|
-
```typescript
|
|
26
|
-
// ❌ BAD: Testing that the mock exists
|
|
27
|
-
test('renders sidebar', () => {
|
|
28
|
-
render(<Page />);
|
|
29
|
-
expect(screen.getByTestId('sidebar-mock')).toBeInTheDocument();
|
|
30
|
-
});
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
**Why this is wrong:**
|
|
34
|
-
|
|
35
|
-
- You're verifying the mock works, not that the component works
|
|
36
|
-
- Test passes when mock is present, fails when it's not
|
|
37
|
-
- Tells you nothing about real behavior
|
|
38
|
-
|
|
39
|
-
**your human partner's correction:** "Are we testing the behavior of a mock?"
|
|
40
|
-
|
|
41
|
-
**The fix:**
|
|
42
|
-
|
|
43
|
-
```typescript
|
|
44
|
-
// ✅ GOOD: Test real component or don't mock it
|
|
45
|
-
test('renders sidebar', () => {
|
|
46
|
-
render(<Page />); // Don't mock sidebar
|
|
47
|
-
expect(screen.getByRole('navigation')).toBeInTheDocument();
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
// OR if sidebar must be mocked for isolation:
|
|
51
|
-
// Don't assert on the mock - test Page's behavior with sidebar present
|
|
52
|
-
```
|
|
53
|
-
|
|
54
|
-
### Gate Function
|
|
55
|
-
|
|
56
|
-
```
|
|
57
|
-
BEFORE asserting on any mock element:
|
|
58
|
-
Ask: "Am I testing real component behavior or just mock existence?"
|
|
59
|
-
|
|
60
|
-
IF testing mock existence:
|
|
61
|
-
STOP - Delete the assertion or unmock the component
|
|
62
|
-
|
|
63
|
-
Test real behavior instead
|
|
64
|
-
```
|
|
65
|
-
|
|
66
|
-
## Anti-Pattern 2: Test-Only Methods in Production
|
|
67
|
-
|
|
68
|
-
**The violation:**
|
|
69
|
-
|
|
70
|
-
```typescript
|
|
71
|
-
// ❌ BAD: destroy() only used in tests
|
|
72
|
-
class Session {
|
|
73
|
-
async destroy() {
|
|
74
|
-
// Looks like production API!
|
|
75
|
-
await this._workspaceManager?.destroyWorkspace(this.id);
|
|
76
|
-
// ... cleanup
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
// In tests
|
|
81
|
-
afterEach(() => session.destroy());
|
|
82
|
-
```
|
|
83
|
-
|
|
84
|
-
**Why this is wrong:**
|
|
85
|
-
|
|
86
|
-
- Production class polluted with test-only code
|
|
87
|
-
- Dangerous if accidentally called in production
|
|
88
|
-
- Violates YAGNI and separation of concerns
|
|
89
|
-
- Confuses object lifecycle with entity lifecycle
|
|
90
|
-
|
|
91
|
-
**The fix:**
|
|
92
|
-
|
|
93
|
-
```typescript
|
|
94
|
-
// ✅ GOOD: Test utilities handle test cleanup
|
|
95
|
-
// Session has no destroy() - it's stateless in production
|
|
96
|
-
|
|
97
|
-
// In test-utils/
|
|
98
|
-
export async function cleanupSession(session: Session) {
|
|
99
|
-
const workspace = session.getWorkspaceInfo();
|
|
100
|
-
if (workspace) {
|
|
101
|
-
await workspaceManager.destroyWorkspace(workspace.id);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
// In tests
|
|
106
|
-
afterEach(() => cleanupSession(session));
|
|
107
|
-
```
|
|
108
|
-
|
|
109
|
-
### Gate Function
|
|
110
|
-
|
|
111
|
-
```
|
|
112
|
-
BEFORE adding any method to production class:
|
|
113
|
-
Ask: "Is this only used by tests?"
|
|
114
|
-
|
|
115
|
-
IF yes:
|
|
116
|
-
STOP - Don't add it
|
|
117
|
-
Put it in test utilities instead
|
|
118
|
-
|
|
119
|
-
Ask: "Does this class own this resource's lifecycle?"
|
|
120
|
-
|
|
121
|
-
IF no:
|
|
122
|
-
STOP - Wrong class for this method
|
|
123
|
-
```
|
|
124
|
-
|
|
125
|
-
## Anti-Pattern 3: Mocking Without Understanding
|
|
126
|
-
|
|
127
|
-
**The violation:**
|
|
128
|
-
|
|
129
|
-
```typescript
|
|
130
|
-
// ❌ BAD: Mock breaks test logic
|
|
131
|
-
test("detects duplicate server", () => {
|
|
132
|
-
// Mock prevents config write that test depends on!
|
|
133
|
-
vi.mock("ToolCatalog", () => ({
|
|
134
|
-
discoverAndCacheTools: vi.fn().mockResolvedValue(undefined),
|
|
135
|
-
}));
|
|
136
|
-
|
|
137
|
-
await addServer(config);
|
|
138
|
-
await addServer(config); // Should throw - but won't!
|
|
139
|
-
});
|
|
140
|
-
```
|
|
141
|
-
|
|
142
|
-
**Why this is wrong:**
|
|
143
|
-
|
|
144
|
-
- Mocked method had side effect test depended on (writing config)
|
|
145
|
-
- Over-mocking to "be safe" breaks actual behavior
|
|
146
|
-
- Test passes for wrong reason or fails mysteriously
|
|
147
|
-
|
|
148
|
-
**The fix:**
|
|
149
|
-
|
|
150
|
-
```typescript
|
|
151
|
-
// ✅ GOOD: Mock at correct level
|
|
152
|
-
test("detects duplicate server", () => {
|
|
153
|
-
// Mock the slow part, preserve behavior test needs
|
|
154
|
-
vi.mock("MCPServerManager"); // Just mock slow server startup
|
|
155
|
-
|
|
156
|
-
await addServer(config); // Config written
|
|
157
|
-
await addServer(config); // Duplicate detected ✓
|
|
158
|
-
});
|
|
159
|
-
```
|
|
160
|
-
|
|
161
|
-
### Gate Function
|
|
162
|
-
|
|
163
|
-
```
|
|
164
|
-
BEFORE mocking any method:
|
|
165
|
-
STOP - Don't mock yet
|
|
166
|
-
|
|
167
|
-
1. Ask: "What side effects does the real method have?"
|
|
168
|
-
2. Ask: "Does this test depend on any of those side effects?"
|
|
169
|
-
3. Ask: "Do I fully understand what this test needs?"
|
|
170
|
-
|
|
171
|
-
IF depends on side effects:
|
|
172
|
-
Mock at lower level (the actual slow/external operation)
|
|
173
|
-
OR use test doubles that preserve necessary behavior
|
|
174
|
-
NOT the high-level method the test depends on
|
|
175
|
-
|
|
176
|
-
IF unsure what test depends on:
|
|
177
|
-
Run test with real implementation FIRST
|
|
178
|
-
Observe what actually needs to happen
|
|
179
|
-
THEN add minimal mocking at the right level
|
|
180
|
-
|
|
181
|
-
Red flags:
|
|
182
|
-
- "I'll mock this to be safe"
|
|
183
|
-
- "This might be slow, better mock it"
|
|
184
|
-
- Mocking without understanding the dependency chain
|
|
185
|
-
```
|
|
186
|
-
|
|
187
|
-
## Anti-Pattern 4: Incomplete Mocks
|
|
188
|
-
|
|
189
|
-
**The violation:**
|
|
190
|
-
|
|
191
|
-
```typescript
|
|
192
|
-
// ❌ BAD: Partial mock - only fields you think you need
|
|
193
|
-
const mockResponse = {
|
|
194
|
-
status: "success",
|
|
195
|
-
data: { userId: "123", name: "Alice" },
|
|
196
|
-
// Missing: metadata that downstream code uses
|
|
197
|
-
};
|
|
198
|
-
|
|
199
|
-
// Later: breaks when code accesses response.metadata.requestId
|
|
200
|
-
```
|
|
201
|
-
|
|
202
|
-
**Why this is wrong:**
|
|
203
|
-
|
|
204
|
-
- **Partial mocks hide structural assumptions** - You only mocked fields you know about
|
|
205
|
-
- **Downstream code may depend on fields you didn't include** - Silent failures
|
|
206
|
-
- **Tests pass but integration fails** - Mock incomplete, real API complete
|
|
207
|
-
- **False confidence** - Test proves nothing about real behavior
|
|
208
|
-
|
|
209
|
-
**The Iron Rule:** Mock the COMPLETE data structure as it exists in reality, not just fields your immediate test uses.
|
|
210
|
-
|
|
211
|
-
**The fix:**
|
|
212
|
-
|
|
213
|
-
```typescript
|
|
214
|
-
// ✅ GOOD: Mirror real API completeness
|
|
215
|
-
const mockResponse = {
|
|
216
|
-
status: "success",
|
|
217
|
-
data: { userId: "123", name: "Alice" },
|
|
218
|
-
metadata: { requestId: "req-789", timestamp: 1234567890 },
|
|
219
|
-
// All fields real API returns
|
|
220
|
-
};
|
|
221
|
-
```
|
|
222
|
-
|
|
223
|
-
### Gate Function
|
|
224
|
-
|
|
225
|
-
```
|
|
226
|
-
BEFORE creating mock responses:
|
|
227
|
-
Check: "What fields does the real API response contain?"
|
|
228
|
-
|
|
229
|
-
Actions:
|
|
230
|
-
1. Examine actual API response from docs/examples
|
|
231
|
-
2. Include ALL fields system might consume downstream
|
|
232
|
-
3. Verify mock matches real response schema completely
|
|
233
|
-
|
|
234
|
-
Critical:
|
|
235
|
-
If you're creating a mock, you must understand the ENTIRE structure
|
|
236
|
-
Partial mocks fail silently when code depends on omitted fields
|
|
237
|
-
|
|
238
|
-
If uncertain: Include all documented fields
|
|
239
|
-
```
|
|
240
|
-
|
|
241
|
-
## Anti-Pattern 5: Integration Tests as Afterthought
|
|
242
|
-
|
|
243
|
-
**The violation:**
|
|
244
|
-
|
|
245
|
-
```
|
|
246
|
-
✅ Implementation complete
|
|
247
|
-
❌ No tests written
|
|
248
|
-
"Ready for testing"
|
|
249
|
-
```
|
|
250
|
-
|
|
251
|
-
**Why this is wrong:**
|
|
252
|
-
|
|
253
|
-
- Testing is part of implementation, not optional follow-up
|
|
254
|
-
- TDD would have caught this
|
|
255
|
-
- Can't claim complete without tests
|
|
256
|
-
|
|
257
|
-
**The fix:**
|
|
258
|
-
|
|
259
|
-
```
|
|
260
|
-
TDD cycle:
|
|
261
|
-
1. Write failing test
|
|
262
|
-
2. Implement to pass
|
|
263
|
-
3. Refactor
|
|
264
|
-
4. THEN claim complete
|
|
265
|
-
```
|
|
266
|
-
|
|
267
|
-
## When Mocks Become Too Complex
|
|
268
|
-
|
|
269
|
-
**Warning signs:**
|
|
270
|
-
|
|
271
|
-
- Mock setup longer than test logic
|
|
272
|
-
- Mocking everything to make test pass
|
|
273
|
-
- Mocks missing methods real components have
|
|
274
|
-
- Test breaks when mock changes
|
|
275
|
-
|
|
276
|
-
**your human partner's question:** "Do we need to be using a mock here?"
|
|
277
|
-
|
|
278
|
-
**Consider:** Integration tests with real components often simpler than complex mocks
|
|
279
|
-
|
|
280
|
-
## TDD Prevents These Anti-Patterns
|
|
281
|
-
|
|
282
|
-
**Why TDD helps:**
|
|
283
|
-
|
|
284
|
-
1. **Write test first** → Forces you to think about what you're actually testing
|
|
285
|
-
2. **Watch it fail** → Confirms test tests real behavior, not mocks
|
|
286
|
-
3. **Minimal implementation** → No test-only methods creep in
|
|
287
|
-
4. **Real dependencies** → You see what the test actually needs before mocking
|
|
288
|
-
|
|
289
|
-
**If you're testing mock behavior, you violated TDD** - you added mocks without watching test fail against real code first.
|
|
290
|
-
|
|
291
|
-
## Quick Reference
|
|
292
|
-
|
|
293
|
-
| Anti-Pattern | Fix |
|
|
294
|
-
| ------------------------------- | --------------------------------------------- |
|
|
295
|
-
| Assert on mock elements | Test real component or unmock it |
|
|
296
|
-
| Test-only methods in production | Move to test utilities |
|
|
297
|
-
| Mock without understanding | Understand dependencies first, mock minimally |
|
|
298
|
-
| Incomplete mocks | Mirror real API completely |
|
|
299
|
-
| Tests as afterthought | TDD - tests first |
|
|
300
|
-
| Over-complex mocks | Consider integration tests |
|
|
301
|
-
|
|
302
|
-
## Red Flags
|
|
303
|
-
|
|
304
|
-
- Assertion checks for `*-mock` test IDs
|
|
305
|
-
- Methods only called in test files
|
|
306
|
-
- Mock setup is >50% of test
|
|
307
|
-
- Test fails when you remove mock
|
|
308
|
-
- Can't explain why mock is needed
|
|
309
|
-
- Mocking "just to be safe"
|
|
310
|
-
|
|
311
|
-
## The Bottom Line
|
|
312
|
-
|
|
313
|
-
**Mocks are tools to isolate, not things to test.**
|
|
314
|
-
|
|
315
|
-
If TDD reveals you're testing mock behavior, you've gone wrong.
|
|
316
|
-
|
|
317
|
-
Fix: Test real behavior or question why you're mocking at all.
|
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: verification-before-completion
|
|
3
|
-
description: Use when about to claim work is complete, fixed, or passing, before committing or creating PRs - requires running verification commands and confirming output before making any success claims; evidence before assertions always
|
|
4
|
-
---
|
|
5
|
-
|
|
6
|
-
# Verification Before Completion
|
|
7
|
-
|
|
8
|
-
## Overview
|
|
9
|
-
|
|
10
|
-
Claiming work is complete without verification is dishonesty, not efficiency.
|
|
11
|
-
|
|
12
|
-
**Core principle:** Evidence before claims, always.
|
|
13
|
-
|
|
14
|
-
**Violating the letter of this rule is violating the spirit of this rule.**
|
|
15
|
-
|
|
16
|
-
## The Iron Law
|
|
17
|
-
|
|
18
|
-
```
|
|
19
|
-
NO COMPLETION CLAIMS WITHOUT FRESH VERIFICATION EVIDENCE
|
|
20
|
-
```
|
|
21
|
-
|
|
22
|
-
If you haven't run the verification command in this message, you cannot claim it passes.
|
|
23
|
-
|
|
24
|
-
## The Gate Function
|
|
25
|
-
|
|
26
|
-
```
|
|
27
|
-
BEFORE claiming any status or expressing satisfaction:
|
|
28
|
-
|
|
29
|
-
1. IDENTIFY: What command proves this claim?
|
|
30
|
-
2. RUN: Execute the FULL command (fresh, complete)
|
|
31
|
-
3. READ: Full output, check exit code, count failures
|
|
32
|
-
4. VERIFY: Does output confirm the claim?
|
|
33
|
-
- If NO: State actual status with evidence
|
|
34
|
-
- If YES: State claim WITH evidence
|
|
35
|
-
5. ONLY THEN: Make the claim
|
|
36
|
-
|
|
37
|
-
Skip any step = lying, not verifying
|
|
38
|
-
```
|
|
39
|
-
|
|
40
|
-
## Common Failures
|
|
41
|
-
|
|
42
|
-
| Claim | Requires | Not Sufficient |
|
|
43
|
-
| --------------------- | ------------------------------- | ------------------------------ |
|
|
44
|
-
| Tests pass | Test command output: 0 failures | Previous run, "should pass" |
|
|
45
|
-
| Linter clean | Linter output: 0 errors | Partial check, extrapolation |
|
|
46
|
-
| Build succeeds | Build command: exit 0 | Linter passing, logs look good |
|
|
47
|
-
| Bug fixed | Test original symptom: passes | Code changed, assumed fixed |
|
|
48
|
-
| Regression test works | Red-green cycle verified | Test passes once |
|
|
49
|
-
| Agent completed | VCS diff shows changes | Agent reports "success" |
|
|
50
|
-
| Requirements met | Line-by-line checklist | Tests passing |
|
|
51
|
-
|
|
52
|
-
## Red Flags - STOP
|
|
53
|
-
|
|
54
|
-
- Using "should", "probably", "seems to"
|
|
55
|
-
- Expressing satisfaction before verification ("Great!", "Perfect!", "Done!", etc.)
|
|
56
|
-
- About to commit/push/PR without verification
|
|
57
|
-
- Trusting agent success reports
|
|
58
|
-
- Relying on partial verification
|
|
59
|
-
- Thinking "just this once"
|
|
60
|
-
- Tired and wanting work over
|
|
61
|
-
- **ANY wording implying success without having run verification**
|
|
62
|
-
|
|
63
|
-
## Rationalization Prevention
|
|
64
|
-
|
|
65
|
-
| Excuse | Reality |
|
|
66
|
-
| --------------------------------------- | ---------------------- |
|
|
67
|
-
| "Should work now" | RUN the verification |
|
|
68
|
-
| "I'm confident" | Confidence ≠ evidence |
|
|
69
|
-
| "Just this once" | No exceptions |
|
|
70
|
-
| "Linter passed" | Linter ≠ compiler |
|
|
71
|
-
| "Agent said success" | Verify independently |
|
|
72
|
-
| "I'm tired" | Exhaustion ≠ excuse |
|
|
73
|
-
| "Partial check is enough" | Partial proves nothing |
|
|
74
|
-
| "Different words so rule doesn't apply" | Spirit over letter |
|
|
75
|
-
|
|
76
|
-
## Key Patterns
|
|
77
|
-
|
|
78
|
-
**Tests:**
|
|
79
|
-
|
|
80
|
-
```
|
|
81
|
-
✅ [Run test command] [See: 34/34 pass] "All tests pass"
|
|
82
|
-
❌ "Should pass now" / "Looks correct"
|
|
83
|
-
```
|
|
84
|
-
|
|
85
|
-
**Regression tests (TDD Red-Green):**
|
|
86
|
-
|
|
87
|
-
```
|
|
88
|
-
✅ Write → Run (pass) → Revert fix → Run (MUST FAIL) → Restore → Run (pass)
|
|
89
|
-
❌ "I've written a regression test" (without red-green verification)
|
|
90
|
-
```
|
|
91
|
-
|
|
92
|
-
**Build:**
|
|
93
|
-
|
|
94
|
-
```
|
|
95
|
-
✅ [Run build] [See: exit 0] "Build passes"
|
|
96
|
-
❌ "Linter passed" (linter doesn't check compilation)
|
|
97
|
-
```
|
|
98
|
-
|
|
99
|
-
**Requirements:**
|
|
100
|
-
|
|
101
|
-
```
|
|
102
|
-
✅ Re-read plan → Create checklist → Verify each → Report gaps or completion
|
|
103
|
-
❌ "Tests pass, phase complete"
|
|
104
|
-
```
|
|
105
|
-
|
|
106
|
-
**Agent delegation:**
|
|
107
|
-
|
|
108
|
-
```
|
|
109
|
-
✅ Agent reports success → Check VCS diff → Verify changes → Report actual state
|
|
110
|
-
❌ Trust agent report
|
|
111
|
-
```
|
|
112
|
-
|
|
113
|
-
## Why This Matters
|
|
114
|
-
|
|
115
|
-
From 24 failure memories:
|
|
116
|
-
|
|
117
|
-
- your human partner said "I don't believe you" - trust broken
|
|
118
|
-
- Undefined functions shipped - would crash
|
|
119
|
-
- Missing requirements shipped - incomplete features
|
|
120
|
-
- Time wasted on false completion → redirect → rework
|
|
121
|
-
- Violates: "Honesty is a core value. If you lie, you'll be replaced."
|
|
122
|
-
|
|
123
|
-
## When To Apply
|
|
124
|
-
|
|
125
|
-
**ALWAYS before:**
|
|
126
|
-
|
|
127
|
-
- ANY variation of success/completion claims
|
|
128
|
-
- ANY expression of satisfaction
|
|
129
|
-
- ANY positive statement about work state
|
|
130
|
-
- Committing, PR creation, task completion
|
|
131
|
-
- Moving to next task
|
|
132
|
-
- Delegating to agents
|
|
133
|
-
|
|
134
|
-
**Rule applies to:**
|
|
135
|
-
|
|
136
|
-
- Exact phrases
|
|
137
|
-
- Paraphrases and synonyms
|
|
138
|
-
- Implications of success
|
|
139
|
-
- ANY communication suggesting completion/correctness
|
|
140
|
-
|
|
141
|
-
## The Bottom Line
|
|
142
|
-
|
|
143
|
-
**No shortcuts for verification.**
|
|
144
|
-
|
|
145
|
-
Run the command. Read the output. THEN claim the result.
|
|
146
|
-
|
|
147
|
-
This is non-negotiable.
|
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: writing-plans
|
|
3
|
-
description: Use when you have a spec or requirements for a multi-step task, before touching code
|
|
4
|
-
---
|
|
5
|
-
|
|
6
|
-
# Writing Plans
|
|
7
|
-
|
|
8
|
-
## Overview
|
|
9
|
-
|
|
10
|
-
Write comprehensive implementation plans assuming the engineer has zero context for our codebase and questionable taste. Document everything they need to know: which files to touch for each task, code, testing, docs they might need to check, how to test it. Give them the whole plan as bite-sized tasks. DRY. YAGNI. TDD. Frequent commits.
|
|
11
|
-
|
|
12
|
-
Assume they are a skilled developer, but know almost nothing about our toolset or problem domain. Assume they don't know good test design very well.
|
|
13
|
-
|
|
14
|
-
**Announce at start:** "I'm using the writing-plans skill to create the implementation plan."
|
|
15
|
-
|
|
16
|
-
**Context:** This should be run in a dedicated worktree (created by brainstorming skill).
|
|
17
|
-
|
|
18
|
-
**Save plans to:** `docs/superpowers/plans/YYYY-MM-DD-<feature-name>.md`
|
|
19
|
-
|
|
20
|
-
- (User preferences for plan location override this default)
|
|
21
|
-
|
|
22
|
-
## Scope Check
|
|
23
|
-
|
|
24
|
-
If the spec covers multiple independent subsystems, it should have been broken into sub-project specs during brainstorming. If it wasn't, suggest breaking this into separate plans — one per subsystem. Each plan should produce working, testable software on its own.
|
|
25
|
-
|
|
26
|
-
## File Structure
|
|
27
|
-
|
|
28
|
-
Before defining tasks, map out which files will be created or modified and what each one is responsible for. This is where decomposition decisions get locked in.
|
|
29
|
-
|
|
30
|
-
- Design units with clear boundaries and well-defined interfaces. Each file should have one clear responsibility.
|
|
31
|
-
- You reason best about code you can hold in context at once, and your edits are more reliable when files are focused. Prefer smaller, focused files over large ones that do too much.
|
|
32
|
-
- Files that change together should live together. Split by responsibility, not by technical layer.
|
|
33
|
-
- In existing codebases, follow established patterns. If the codebase uses large files, don't unilaterally restructure - but if a file you're modifying has grown unwieldy, including a split in the plan is reasonable.
|
|
34
|
-
|
|
35
|
-
This structure informs the task decomposition. Each task should produce self-contained changes that make sense independently.
|
|
36
|
-
|
|
37
|
-
## Bite-Sized Task Granularity
|
|
38
|
-
|
|
39
|
-
**Each step is one action (2-5 minutes):**
|
|
40
|
-
|
|
41
|
-
- "Write the failing test" - step
|
|
42
|
-
- "Run it to make sure it fails" - step
|
|
43
|
-
- "Implement the minimal code to make the test pass" - step
|
|
44
|
-
- "Run the tests and make sure they pass" - step
|
|
45
|
-
- "Commit" - step
|
|
46
|
-
|
|
47
|
-
## Plan Document Header
|
|
48
|
-
|
|
49
|
-
**Every plan MUST start with this header:**
|
|
50
|
-
|
|
51
|
-
```markdown
|
|
52
|
-
# [Feature Name] Implementation Plan
|
|
53
|
-
|
|
54
|
-
> **For agentic workers:** REQUIRED SUB-SKILL: Use subagent-driven-development (recommended) or executing-plans to implement this plan task-by-task. Steps use checkbox (`- [ ]`) syntax for tracking.
|
|
55
|
-
|
|
56
|
-
**Goal:** [One sentence describing what this builds]
|
|
57
|
-
|
|
58
|
-
**Architecture:** [2-3 sentences about approach]
|
|
59
|
-
|
|
60
|
-
**Tech Stack:** [Key technologies/libraries]
|
|
61
|
-
|
|
62
|
-
---
|
|
63
|
-
```
|
|
64
|
-
|
|
65
|
-
## Task Structure
|
|
66
|
-
|
|
67
|
-
````markdown
|
|
68
|
-
### Task N: [Component Name]
|
|
69
|
-
|
|
70
|
-
**Files:**
|
|
71
|
-
|
|
72
|
-
- Create: `exact/path/to/file.py`
|
|
73
|
-
- Modify: `exact/path/to/existing.py:123-145`
|
|
74
|
-
- Test: `tests/exact/path/to/test.py`
|
|
75
|
-
|
|
76
|
-
- [ ] **Step 1: Write the failing test**
|
|
77
|
-
|
|
78
|
-
```python
|
|
79
|
-
def test_specific_behavior():
|
|
80
|
-
result = function(input)
|
|
81
|
-
assert result == expected
|
|
82
|
-
```
|
|
83
|
-
|
|
84
|
-
- [ ] **Step 2: Run test to verify it fails**
|
|
85
|
-
|
|
86
|
-
Run: `pytest tests/path/test.py::test_name -v`
|
|
87
|
-
Expected: FAIL with "function not defined"
|
|
88
|
-
|
|
89
|
-
- [ ] **Step 3: Write minimal implementation**
|
|
90
|
-
|
|
91
|
-
```python
|
|
92
|
-
def function(input):
|
|
93
|
-
return expected
|
|
94
|
-
```
|
|
95
|
-
|
|
96
|
-
- [ ] **Step 4: Run test to verify it passes**
|
|
97
|
-
|
|
98
|
-
Run: `pytest tests/path/test.py::test_name -v`
|
|
99
|
-
Expected: PASS
|
|
100
|
-
|
|
101
|
-
- [ ] **Step 5: Commit**
|
|
102
|
-
|
|
103
|
-
```bash
|
|
104
|
-
git add tests/path/test.py src/path/file.py
|
|
105
|
-
git commit -m "feat: add specific feature"
|
|
106
|
-
```
|
|
107
|
-
````
|
|
108
|
-
|
|
109
|
-
## No Placeholders
|
|
110
|
-
|
|
111
|
-
Every step must contain the actual content an engineer needs. These are **plan failures** — never write them:
|
|
112
|
-
|
|
113
|
-
- "TBD", "TODO", "implement later", "fill in details"
|
|
114
|
-
- "Add appropriate error handling" / "add validation" / "handle edge cases"
|
|
115
|
-
- "Write tests for the above" (without actual test code)
|
|
116
|
-
- "Similar to Task N" (repeat the code — the engineer may be reading tasks out of order)
|
|
117
|
-
- Steps that describe what to do without showing how (code blocks required for code steps)
|
|
118
|
-
- References to types, functions, or methods not defined in any task
|
|
119
|
-
|
|
120
|
-
## Remember
|
|
121
|
-
|
|
122
|
-
- Exact file paths always
|
|
123
|
-
- Complete code in every step — if a step changes code, show the code
|
|
124
|
-
- Exact commands with expected output
|
|
125
|
-
- DRY, YAGNI, TDD, frequent commits
|
|
126
|
-
|
|
127
|
-
## Self-Review
|
|
128
|
-
|
|
129
|
-
After writing the complete plan, look at the spec with fresh eyes and check the plan against it. This is a checklist you run yourself — not a subagent dispatch.
|
|
130
|
-
|
|
131
|
-
**1. Spec coverage:** Skim each section/requirement in the spec. Can you point to a task that implements it? List any gaps.
|
|
132
|
-
|
|
133
|
-
**2. Placeholder scan:** Search your plan for red flags — any of the patterns from the "No Placeholders" section above. Fix them.
|
|
134
|
-
|
|
135
|
-
**3. Type consistency:** Do the types, method signatures, and property names you used in later tasks match what you defined in earlier tasks? A function called `clearLayers()` in Task 3 but `clearFullLayers()` in Task 7 is a bug.
|
|
136
|
-
|
|
137
|
-
If you find issues, fix them inline. No need to re-review — just fix and move on. If you find a spec requirement with no task, add the task.
|
|
138
|
-
|
|
139
|
-
## Execution Handoff
|
|
140
|
-
|
|
141
|
-
After saving the plan, offer execution choice:
|
|
142
|
-
|
|
143
|
-
**"Plan complete and saved to `docs/superpowers/plans/<filename>.md`. Two execution options:**
|
|
144
|
-
|
|
145
|
-
**1. Subagent-Driven (recommended)** - I dispatch a fresh subagent per task, review between tasks, fast iteration
|
|
146
|
-
|
|
147
|
-
**2. Inline Execution** - Execute tasks in this session using executing-plans, batch execution with checkpoints
|
|
148
|
-
|
|
149
|
-
**Which approach?"**
|
|
150
|
-
|
|
151
|
-
**If Subagent-Driven chosen:**
|
|
152
|
-
|
|
153
|
-
- **REQUIRED SUB-SKILL:** Use subagent-driven-development
|
|
154
|
-
- Fresh subagent per task + two-stage review
|
|
155
|
-
|
|
156
|
-
**If Inline Execution chosen:**
|
|
157
|
-
|
|
158
|
-
- **REQUIRED SUB-SKILL:** Use executing-plans
|
|
159
|
-
- Batch execution with checkpoints for review
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
# Plan Document Reviewer Prompt Template
|
|
2
|
-
|
|
3
|
-
Use this template when dispatching a plan document reviewer subagent.
|
|
4
|
-
|
|
5
|
-
**Purpose:** Verify the plan is complete, matches the spec, and has proper task decomposition.
|
|
6
|
-
|
|
7
|
-
**Dispatch after:** The complete plan is written.
|
|
8
|
-
|
|
9
|
-
```
|
|
10
|
-
Task tool (general-purpose):
|
|
11
|
-
description: "Review plan document"
|
|
12
|
-
prompt: |
|
|
13
|
-
You are a plan document reviewer. Verify this plan is complete and ready for implementation.
|
|
14
|
-
|
|
15
|
-
**Plan to review:** [PLAN_FILE_PATH]
|
|
16
|
-
**Spec for reference:** [SPEC_FILE_PATH]
|
|
17
|
-
|
|
18
|
-
## What to Check
|
|
19
|
-
|
|
20
|
-
| Category | What to Look For |
|
|
21
|
-
|----------|------------------|
|
|
22
|
-
| Completeness | TODOs, placeholders, incomplete tasks, missing steps |
|
|
23
|
-
| Spec Alignment | Plan covers spec requirements, no major scope creep |
|
|
24
|
-
| Task Decomposition | Tasks have clear boundaries, steps are actionable |
|
|
25
|
-
| Buildability | Could an engineer follow this plan without getting stuck? |
|
|
26
|
-
|
|
27
|
-
## Calibration
|
|
28
|
-
|
|
29
|
-
**Only flag issues that would cause real problems during implementation.**
|
|
30
|
-
An implementer building the wrong thing or getting stuck is an issue.
|
|
31
|
-
Minor wording, stylistic preferences, and "nice to have" suggestions are not.
|
|
32
|
-
|
|
33
|
-
Approve unless there are serious gaps — missing requirements from the spec,
|
|
34
|
-
contradictory steps, placeholder content, or tasks so vague they can't be acted on.
|
|
35
|
-
|
|
36
|
-
## Output Format
|
|
37
|
-
|
|
38
|
-
## Plan Review
|
|
39
|
-
|
|
40
|
-
**Status:** Approved | Issues Found
|
|
41
|
-
|
|
42
|
-
**Issues (if any):**
|
|
43
|
-
- [Task X, Step Y]: [specific issue] - [why it matters for implementation]
|
|
44
|
-
|
|
45
|
-
**Recommendations (advisory, do not block approval):**
|
|
46
|
-
- [suggestions for improvement]
|
|
47
|
-
```
|
|
48
|
-
|
|
49
|
-
**Reviewer returns:** Status, Issues (if any), Recommendations
|