tlc-claude-code 1.6.2 → 1.7.0
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/.claude/commands/tlc/audit.md +0 -0
- package/.claude/commands/tlc/autofix.md +0 -0
- package/.claude/commands/tlc/bug.md +0 -0
- package/.claude/commands/tlc/build.md +6 -0
- package/.claude/commands/tlc/checklist.md +0 -0
- package/.claude/commands/tlc/ci.md +0 -0
- package/.claude/commands/tlc/claim.md +0 -0
- package/.claude/commands/tlc/cleanup.md +0 -0
- package/.claude/commands/tlc/complete.md +0 -0
- package/.claude/commands/tlc/config.md +0 -0
- package/.claude/commands/tlc/coverage.md +0 -0
- package/.claude/commands/tlc/deploy.md +0 -0
- package/.claude/commands/tlc/discuss.md +0 -0
- package/.claude/commands/tlc/docs.md +0 -0
- package/.claude/commands/tlc/edge-cases.md +0 -0
- package/.claude/commands/tlc/export.md +0 -0
- package/.claude/commands/tlc/help.md +0 -0
- package/.claude/commands/tlc/import-project.md +0 -0
- package/.claude/commands/tlc/init.md +35 -37
- package/.claude/commands/tlc/issues.md +0 -0
- package/.claude/commands/tlc/llm.md +0 -0
- package/.claude/commands/tlc/new-milestone.md +0 -0
- package/.claude/commands/tlc/new-project.md +0 -0
- package/.claude/commands/tlc/next.md +0 -0
- package/.claude/commands/tlc/outdated.md +0 -0
- package/.claude/commands/tlc/plan.md +0 -0
- package/.claude/commands/tlc/progress.md +0 -0
- package/.claude/commands/tlc/quality.md +0 -0
- package/.claude/commands/tlc/quick.md +0 -0
- package/.claude/commands/tlc/refactor.md +0 -0
- package/.claude/commands/tlc/release.md +0 -0
- package/.claude/commands/tlc/review-pr.md +0 -0
- package/.claude/commands/tlc/review.md +0 -0
- package/.claude/commands/tlc/security.md +0 -0
- package/.claude/commands/tlc/server.md +0 -0
- package/.claude/commands/tlc/start.md +0 -0
- package/.claude/commands/tlc/status.md +0 -0
- package/.claude/commands/tlc/sync.md +0 -0
- package/.claude/commands/tlc/tlc.md +38 -31
- package/.claude/commands/tlc/verify.md +0 -0
- package/.claude/commands/tlc/who.md +0 -0
- package/.gitattributes +0 -0
- package/CLAUDE.md +113 -61
- package/CODING-STANDARDS.md +0 -0
- package/LICENSE +0 -0
- package/PROJECT.md +0 -0
- package/README.md +0 -0
- package/autofix.md +0 -0
- package/bin/init.js +0 -0
- package/bin/install.js +0 -0
- package/bin/postinstall.js +0 -0
- package/bin/rebuild.js +0 -0
- package/bin/server.js +0 -0
- package/bin/setup.js +0 -0
- package/bin/tlc.js +0 -0
- package/bug.md +0 -0
- package/build.md +0 -0
- package/checklist.md +0 -0
- package/ci.md +0 -0
- package/claim.md +0 -0
- package/complete.md +0 -0
- package/config.md +0 -0
- package/coverage.md +0 -0
- package/dashboard/dist/App.d.ts +0 -0
- package/dashboard/dist/App.js +0 -0
- package/dashboard/dist/App.test.d.ts +0 -0
- package/dashboard/dist/App.test.js +0 -0
- package/dashboard/dist/api/health-diagnostics.d.ts +0 -0
- package/dashboard/dist/api/health-diagnostics.js +0 -0
- package/dashboard/dist/api/health-diagnostics.test.d.ts +0 -0
- package/dashboard/dist/api/health-diagnostics.test.js +0 -0
- package/dashboard/dist/api/index.d.ts +0 -0
- package/dashboard/dist/api/index.js +0 -0
- package/dashboard/dist/api/notes-api.d.ts +0 -0
- package/dashboard/dist/api/notes-api.js +0 -0
- package/dashboard/dist/api/notes-api.test.d.ts +0 -0
- package/dashboard/dist/api/notes-api.test.js +0 -0
- package/dashboard/dist/api/safeFetch.d.ts +0 -0
- package/dashboard/dist/api/safeFetch.js +0 -0
- package/dashboard/dist/api/safeFetch.test.d.ts +0 -0
- package/dashboard/dist/api/safeFetch.test.js +0 -0
- package/dashboard/dist/api/tasks-api.d.ts +0 -0
- package/dashboard/dist/api/tasks-api.js +0 -0
- package/dashboard/dist/api/tasks-api.test.d.ts +0 -0
- package/dashboard/dist/api/tasks-api.test.js +0 -0
- package/dashboard/dist/components/ActivityFeed.d.ts +0 -0
- package/dashboard/dist/components/ActivityFeed.js +0 -0
- package/dashboard/dist/components/ActivityFeed.test.d.ts +0 -0
- package/dashboard/dist/components/ActivityFeed.test.js +0 -0
- package/dashboard/dist/components/AgentRegistryPane.d.ts +0 -0
- package/dashboard/dist/components/AgentRegistryPane.js +0 -0
- package/dashboard/dist/components/AgentRegistryPane.test.d.ts +0 -0
- package/dashboard/dist/components/AgentRegistryPane.test.js +0 -0
- package/dashboard/dist/components/AgentsPane.d.ts +0 -0
- package/dashboard/dist/components/AgentsPane.js +0 -0
- package/dashboard/dist/components/AgentsPane.test.d.ts +0 -0
- package/dashboard/dist/components/AgentsPane.test.js +0 -0
- package/dashboard/dist/components/AppPreview.d.ts +0 -0
- package/dashboard/dist/components/AppPreview.js +0 -0
- package/dashboard/dist/components/AppPreview.test.d.ts +0 -0
- package/dashboard/dist/components/AppPreview.test.js +0 -0
- package/dashboard/dist/components/AuditPane.d.ts +0 -0
- package/dashboard/dist/components/AuditPane.js +0 -0
- package/dashboard/dist/components/AuditPane.test.d.ts +0 -0
- package/dashboard/dist/components/AuditPane.test.js +0 -0
- package/dashboard/dist/components/BranchSelector.d.ts +0 -0
- package/dashboard/dist/components/BranchSelector.js +0 -0
- package/dashboard/dist/components/BranchSelector.test.d.ts +0 -0
- package/dashboard/dist/components/BranchSelector.test.js +0 -0
- package/dashboard/dist/components/BugsPane.d.ts +0 -0
- package/dashboard/dist/components/BugsPane.js +0 -0
- package/dashboard/dist/components/BugsPane.test.d.ts +0 -0
- package/dashboard/dist/components/BugsPane.test.js +0 -0
- package/dashboard/dist/components/ChatPane.d.ts +0 -0
- package/dashboard/dist/components/ChatPane.js +0 -0
- package/dashboard/dist/components/ChatPane.test.d.ts +0 -0
- package/dashboard/dist/components/ChatPane.test.js +0 -0
- package/dashboard/dist/components/CommandPalette.d.ts +0 -0
- package/dashboard/dist/components/CommandPalette.js +0 -0
- package/dashboard/dist/components/CommandPalette.test.d.ts +0 -0
- package/dashboard/dist/components/CommandPalette.test.js +0 -0
- package/dashboard/dist/components/CompliancePane.d.ts +0 -0
- package/dashboard/dist/components/CompliancePane.js +0 -0
- package/dashboard/dist/components/CompliancePane.test.d.ts +0 -0
- package/dashboard/dist/components/CompliancePane.test.js +0 -0
- package/dashboard/dist/components/ConnectionStatus.d.ts +0 -0
- package/dashboard/dist/components/ConnectionStatus.js +0 -0
- package/dashboard/dist/components/ConnectionStatus.test.d.ts +0 -0
- package/dashboard/dist/components/ConnectionStatus.test.js +0 -0
- package/dashboard/dist/components/ContainerSecurityPane.d.ts +45 -0
- package/dashboard/dist/components/ContainerSecurityPane.js +44 -0
- package/dashboard/dist/components/ContainerSecurityPane.test.d.ts +1 -0
- package/dashboard/dist/components/ContainerSecurityPane.test.js +153 -0
- package/dashboard/dist/components/DeviceFrame.d.ts +0 -0
- package/dashboard/dist/components/DeviceFrame.js +0 -0
- package/dashboard/dist/components/DeviceFrame.test.d.ts +0 -0
- package/dashboard/dist/components/DeviceFrame.test.js +0 -0
- package/dashboard/dist/components/DocsPane.d.ts +0 -0
- package/dashboard/dist/components/DocsPane.js +0 -0
- package/dashboard/dist/components/DocsPane.test.d.ts +0 -0
- package/dashboard/dist/components/DocsPane.test.js +0 -0
- package/dashboard/dist/components/EnvironmentBadge.d.ts +0 -0
- package/dashboard/dist/components/EnvironmentBadge.js +0 -0
- package/dashboard/dist/components/EnvironmentBadge.test.d.ts +0 -0
- package/dashboard/dist/components/EnvironmentBadge.test.js +0 -0
- package/dashboard/dist/components/FocusIndicator.d.ts +0 -0
- package/dashboard/dist/components/FocusIndicator.js +0 -0
- package/dashboard/dist/components/FocusIndicator.test.d.ts +0 -0
- package/dashboard/dist/components/FocusIndicator.test.js +0 -0
- package/dashboard/dist/components/GitHubPane.d.ts +0 -0
- package/dashboard/dist/components/GitHubPane.js +0 -0
- package/dashboard/dist/components/GitHubPane.test.d.ts +0 -0
- package/dashboard/dist/components/GitHubPane.test.js +0 -0
- package/dashboard/dist/components/HealthPane.d.ts +0 -0
- package/dashboard/dist/components/HealthPane.js +0 -0
- package/dashboard/dist/components/HealthPane.test.d.ts +0 -0
- package/dashboard/dist/components/HealthPane.test.js +0 -0
- package/dashboard/dist/components/KeyboardHelp.d.ts +0 -0
- package/dashboard/dist/components/KeyboardHelp.js +0 -0
- package/dashboard/dist/components/KeyboardHelp.test.d.ts +0 -0
- package/dashboard/dist/components/KeyboardHelp.test.js +0 -0
- package/dashboard/dist/components/LogSearch.d.ts +0 -0
- package/dashboard/dist/components/LogSearch.js +0 -0
- package/dashboard/dist/components/LogSearch.test.d.ts +0 -0
- package/dashboard/dist/components/LogSearch.test.js +0 -0
- package/dashboard/dist/components/LogStream.d.ts +0 -0
- package/dashboard/dist/components/LogStream.js +0 -0
- package/dashboard/dist/components/LogStream.test.d.ts +0 -0
- package/dashboard/dist/components/LogStream.test.js +0 -0
- package/dashboard/dist/components/LogsPane.d.ts +0 -0
- package/dashboard/dist/components/LogsPane.js +0 -0
- package/dashboard/dist/components/LogsPane.test.d.ts +0 -0
- package/dashboard/dist/components/LogsPane.test.js +0 -0
- package/dashboard/dist/components/PhasesPane.d.ts +0 -0
- package/dashboard/dist/components/PhasesPane.js +0 -0
- package/dashboard/dist/components/PhasesPane.test.d.ts +0 -0
- package/dashboard/dist/components/PhasesPane.test.js +0 -0
- package/dashboard/dist/components/PlanSync.d.ts +0 -0
- package/dashboard/dist/components/PlanSync.js +0 -0
- package/dashboard/dist/components/PlanSync.test.d.ts +0 -0
- package/dashboard/dist/components/PlanSync.test.js +0 -0
- package/dashboard/dist/components/PlanView.d.ts +0 -0
- package/dashboard/dist/components/PlanView.js +0 -0
- package/dashboard/dist/components/PlanView.test.d.ts +0 -0
- package/dashboard/dist/components/PlanView.test.js +0 -0
- package/dashboard/dist/components/PreviewPane.d.ts +0 -0
- package/dashboard/dist/components/PreviewPane.js +0 -0
- package/dashboard/dist/components/PreviewPane.test.d.ts +0 -0
- package/dashboard/dist/components/PreviewPane.test.js +0 -0
- package/dashboard/dist/components/PreviewPanel.d.ts +0 -0
- package/dashboard/dist/components/PreviewPanel.js +0 -0
- package/dashboard/dist/components/PreviewPanel.test.d.ts +0 -0
- package/dashboard/dist/components/PreviewPanel.test.js +0 -0
- package/dashboard/dist/components/ProjectCard.d.ts +0 -0
- package/dashboard/dist/components/ProjectCard.js +0 -0
- package/dashboard/dist/components/ProjectCard.test.d.ts +0 -0
- package/dashboard/dist/components/ProjectCard.test.js +0 -0
- package/dashboard/dist/components/ProjectDetail.d.ts +0 -0
- package/dashboard/dist/components/ProjectDetail.js +0 -0
- package/dashboard/dist/components/ProjectDetail.test.d.ts +0 -0
- package/dashboard/dist/components/ProjectDetail.test.js +0 -0
- package/dashboard/dist/components/ProjectList.d.ts +0 -0
- package/dashboard/dist/components/ProjectList.js +0 -0
- package/dashboard/dist/components/ProjectList.test.d.ts +0 -0
- package/dashboard/dist/components/ProjectList.test.js +0 -0
- package/dashboard/dist/components/QualityGatePane.d.ts +0 -0
- package/dashboard/dist/components/QualityGatePane.js +0 -0
- package/dashboard/dist/components/QualityGatePane.test.d.ts +0 -0
- package/dashboard/dist/components/QualityGatePane.test.js +0 -0
- package/dashboard/dist/components/QualityPane.d.ts +0 -0
- package/dashboard/dist/components/QualityPane.js +0 -0
- package/dashboard/dist/components/QualityPane.test.d.ts +0 -0
- package/dashboard/dist/components/QualityPane.test.js +0 -0
- package/dashboard/dist/components/RouterPane.d.ts +0 -0
- package/dashboard/dist/components/RouterPane.js +0 -0
- package/dashboard/dist/components/RouterPane.test.d.ts +0 -0
- package/dashboard/dist/components/RouterPane.test.js +0 -0
- package/dashboard/dist/components/SSOPane.d.ts +0 -0
- package/dashboard/dist/components/SSOPane.js +0 -0
- package/dashboard/dist/components/SSOPane.test.d.ts +0 -0
- package/dashboard/dist/components/SSOPane.test.js +0 -0
- package/dashboard/dist/components/ServicesPane.d.ts +0 -0
- package/dashboard/dist/components/ServicesPane.js +0 -0
- package/dashboard/dist/components/ServicesPane.test.d.ts +0 -0
- package/dashboard/dist/components/ServicesPane.test.js +0 -0
- package/dashboard/dist/components/SettingsPanel.d.ts +0 -0
- package/dashboard/dist/components/SettingsPanel.js +0 -0
- package/dashboard/dist/components/SettingsPanel.test.d.ts +0 -0
- package/dashboard/dist/components/SettingsPanel.test.js +0 -0
- package/dashboard/dist/components/StatusBar.d.ts +0 -0
- package/dashboard/dist/components/StatusBar.js +0 -0
- package/dashboard/dist/components/StatusBar.test.d.ts +0 -0
- package/dashboard/dist/components/StatusBar.test.js +0 -0
- package/dashboard/dist/components/StatusPane.d.ts +0 -0
- package/dashboard/dist/components/StatusPane.js +0 -0
- package/dashboard/dist/components/StatusPane.test.d.ts +0 -0
- package/dashboard/dist/components/StatusPane.test.js +0 -0
- package/dashboard/dist/components/TaskBoard.d.ts +0 -0
- package/dashboard/dist/components/TaskBoard.js +0 -0
- package/dashboard/dist/components/TaskBoard.test.d.ts +0 -0
- package/dashboard/dist/components/TaskBoard.test.js +0 -0
- package/dashboard/dist/components/TaskCard.d.ts +0 -0
- package/dashboard/dist/components/TaskCard.js +0 -0
- package/dashboard/dist/components/TaskCard.test.d.ts +0 -0
- package/dashboard/dist/components/TaskCard.test.js +0 -0
- package/dashboard/dist/components/TaskDetail.d.ts +0 -0
- package/dashboard/dist/components/TaskDetail.js +0 -0
- package/dashboard/dist/components/TaskDetail.test.d.ts +0 -0
- package/dashboard/dist/components/TaskDetail.test.js +0 -0
- package/dashboard/dist/components/TaskFilter.d.ts +0 -0
- package/dashboard/dist/components/TaskFilter.js +0 -0
- package/dashboard/dist/components/TaskFilter.test.d.ts +0 -0
- package/dashboard/dist/components/TaskFilter.test.js +0 -0
- package/dashboard/dist/components/TeamPanel.d.ts +0 -0
- package/dashboard/dist/components/TeamPanel.js +0 -0
- package/dashboard/dist/components/TeamPanel.test.d.ts +0 -0
- package/dashboard/dist/components/TeamPanel.test.js +0 -0
- package/dashboard/dist/components/TeamPresence.d.ts +0 -0
- package/dashboard/dist/components/TeamPresence.js +0 -0
- package/dashboard/dist/components/TeamPresence.test.d.ts +0 -0
- package/dashboard/dist/components/TeamPresence.test.js +0 -0
- package/dashboard/dist/components/UpdateBanner.d.ts +0 -0
- package/dashboard/dist/components/UpdateBanner.js +0 -0
- package/dashboard/dist/components/UpdateBanner.test.d.ts +0 -0
- package/dashboard/dist/components/UpdateBanner.test.js +0 -0
- package/dashboard/dist/components/UsagePane.d.ts +0 -0
- package/dashboard/dist/components/UsagePane.js +0 -0
- package/dashboard/dist/components/UsagePane.test.d.ts +0 -0
- package/dashboard/dist/components/UsagePane.test.js +0 -0
- package/dashboard/dist/components/WorkspaceDocsPane.d.ts +0 -0
- package/dashboard/dist/components/WorkspaceDocsPane.js +0 -0
- package/dashboard/dist/components/WorkspaceDocsPane.test.d.ts +0 -0
- package/dashboard/dist/components/WorkspaceDocsPane.test.js +0 -0
- package/dashboard/dist/components/WorkspacePane.d.ts +0 -0
- package/dashboard/dist/components/WorkspacePane.js +0 -0
- package/dashboard/dist/components/WorkspacePane.test.d.ts +0 -0
- package/dashboard/dist/components/WorkspacePane.test.js +0 -0
- package/dashboard/dist/components/ZeroRetentionPane.d.ts +0 -0
- package/dashboard/dist/components/ZeroRetentionPane.js +0 -0
- package/dashboard/dist/components/ZeroRetentionPane.test.d.ts +0 -0
- package/dashboard/dist/components/ZeroRetentionPane.test.js +0 -0
- package/dashboard/dist/components/accessibility.test.d.ts +0 -0
- package/dashboard/dist/components/accessibility.test.js +0 -0
- package/dashboard/dist/components/layout/Header.d.ts +0 -0
- package/dashboard/dist/components/layout/Header.js +0 -0
- package/dashboard/dist/components/layout/Header.test.d.ts +0 -0
- package/dashboard/dist/components/layout/Header.test.js +0 -0
- package/dashboard/dist/components/layout/MobileNav.d.ts +0 -0
- package/dashboard/dist/components/layout/MobileNav.js +0 -0
- package/dashboard/dist/components/layout/MobileNav.test.d.ts +0 -0
- package/dashboard/dist/components/layout/MobileNav.test.js +0 -0
- package/dashboard/dist/components/layout/Shell.d.ts +0 -0
- package/dashboard/dist/components/layout/Shell.js +0 -0
- package/dashboard/dist/components/layout/Shell.test.d.ts +0 -0
- package/dashboard/dist/components/layout/Shell.test.js +0 -0
- package/dashboard/dist/components/layout/Sidebar.d.ts +0 -0
- package/dashboard/dist/components/layout/Sidebar.js +0 -0
- package/dashboard/dist/components/layout/Sidebar.test.d.ts +0 -0
- package/dashboard/dist/components/layout/Sidebar.test.js +0 -0
- package/dashboard/dist/components/orchestration/AgentCard.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentCard.js +0 -0
- package/dashboard/dist/components/orchestration/AgentCard.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentCard.test.js +0 -0
- package/dashboard/dist/components/orchestration/AgentControls.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentControls.js +0 -0
- package/dashboard/dist/components/orchestration/AgentControls.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentControls.test.js +0 -0
- package/dashboard/dist/components/orchestration/AgentDetail.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentDetail.js +0 -0
- package/dashboard/dist/components/orchestration/AgentDetail.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentDetail.test.js +0 -0
- package/dashboard/dist/components/orchestration/AgentList.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentList.js +0 -0
- package/dashboard/dist/components/orchestration/AgentList.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/AgentList.test.js +0 -0
- package/dashboard/dist/components/orchestration/CostMeter.d.ts +0 -0
- package/dashboard/dist/components/orchestration/CostMeter.js +0 -0
- package/dashboard/dist/components/orchestration/CostMeter.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/CostMeter.test.js +0 -0
- package/dashboard/dist/components/orchestration/ModelSelector.d.ts +0 -0
- package/dashboard/dist/components/orchestration/ModelSelector.js +0 -0
- package/dashboard/dist/components/orchestration/ModelSelector.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/ModelSelector.test.js +0 -0
- package/dashboard/dist/components/orchestration/OrchestrationDashboard.d.ts +0 -0
- package/dashboard/dist/components/orchestration/OrchestrationDashboard.js +0 -0
- package/dashboard/dist/components/orchestration/OrchestrationDashboard.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/OrchestrationDashboard.test.js +0 -0
- package/dashboard/dist/components/orchestration/QualityIndicator.d.ts +0 -0
- package/dashboard/dist/components/orchestration/QualityIndicator.js +0 -0
- package/dashboard/dist/components/orchestration/QualityIndicator.test.d.ts +0 -0
- package/dashboard/dist/components/orchestration/QualityIndicator.test.js +0 -0
- package/dashboard/dist/components/orchestration/index.d.ts +0 -0
- package/dashboard/dist/components/orchestration/index.js +0 -0
- package/dashboard/dist/components/performance.test.d.ts +0 -0
- package/dashboard/dist/components/performance.test.js +0 -0
- package/dashboard/dist/components/responsive.test.d.ts +0 -0
- package/dashboard/dist/components/responsive.test.js +0 -0
- package/dashboard/dist/components/ui/Badge.d.ts +0 -0
- package/dashboard/dist/components/ui/Badge.js +0 -0
- package/dashboard/dist/components/ui/Badge.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Badge.test.js +0 -0
- package/dashboard/dist/components/ui/Button.d.ts +0 -0
- package/dashboard/dist/components/ui/Button.js +0 -0
- package/dashboard/dist/components/ui/Button.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Button.test.js +0 -0
- package/dashboard/dist/components/ui/Card.d.ts +0 -0
- package/dashboard/dist/components/ui/Card.js +0 -0
- package/dashboard/dist/components/ui/Card.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Card.test.js +0 -0
- package/dashboard/dist/components/ui/Dropdown.d.ts +0 -0
- package/dashboard/dist/components/ui/Dropdown.js +0 -0
- package/dashboard/dist/components/ui/Dropdown.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Dropdown.test.js +0 -0
- package/dashboard/dist/components/ui/EmptyState.d.ts +0 -0
- package/dashboard/dist/components/ui/EmptyState.js +0 -0
- package/dashboard/dist/components/ui/EmptyState.test.d.ts +0 -0
- package/dashboard/dist/components/ui/EmptyState.test.js +0 -0
- package/dashboard/dist/components/ui/ErrorState.d.ts +0 -0
- package/dashboard/dist/components/ui/ErrorState.js +0 -0
- package/dashboard/dist/components/ui/ErrorState.test.d.ts +0 -0
- package/dashboard/dist/components/ui/ErrorState.test.js +0 -0
- package/dashboard/dist/components/ui/Input.d.ts +0 -0
- package/dashboard/dist/components/ui/Input.js +0 -0
- package/dashboard/dist/components/ui/Input.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Input.test.js +0 -0
- package/dashboard/dist/components/ui/Modal.d.ts +0 -0
- package/dashboard/dist/components/ui/Modal.js +0 -0
- package/dashboard/dist/components/ui/Modal.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Modal.test.js +0 -0
- package/dashboard/dist/components/ui/Skeleton.d.ts +0 -0
- package/dashboard/dist/components/ui/Skeleton.js +0 -0
- package/dashboard/dist/components/ui/Skeleton.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Skeleton.test.js +0 -0
- package/dashboard/dist/components/ui/Toast.d.ts +0 -0
- package/dashboard/dist/components/ui/Toast.js +0 -0
- package/dashboard/dist/components/ui/Toast.test.d.ts +0 -0
- package/dashboard/dist/components/ui/Toast.test.js +0 -0
- package/dashboard/dist/hooks/useTheme.d.ts +0 -0
- package/dashboard/dist/hooks/useTheme.js +0 -0
- package/dashboard/dist/hooks/useTheme.test.d.ts +0 -0
- package/dashboard/dist/hooks/useTheme.test.js +0 -0
- package/dashboard/dist/hooks/useWebSocket.d.ts +0 -0
- package/dashboard/dist/hooks/useWebSocket.js +0 -0
- package/dashboard/dist/hooks/useWebSocket.test.d.ts +0 -0
- package/dashboard/dist/hooks/useWebSocket.test.js +0 -0
- package/dashboard/dist/index.d.ts +0 -0
- package/dashboard/dist/index.js +0 -0
- package/dashboard/dist/stores/projectStore.d.ts +0 -0
- package/dashboard/dist/stores/projectStore.js +0 -0
- package/dashboard/dist/stores/projectStore.test.d.ts +0 -0
- package/dashboard/dist/stores/projectStore.test.js +0 -0
- package/dashboard/dist/stores/uiStore.d.ts +0 -0
- package/dashboard/dist/stores/uiStore.js +0 -0
- package/dashboard/dist/stores/uiStore.test.d.ts +0 -0
- package/dashboard/dist/stores/uiStore.test.js +0 -0
- package/dashboard/dist/styles/tokens.d.ts +0 -0
- package/dashboard/dist/styles/tokens.js +0 -0
- package/dashboard/dist/styles/tokens.test.d.ts +0 -0
- package/dashboard/dist/styles/tokens.test.js +0 -0
- package/dashboard/dist/test/setup.d.ts +0 -0
- package/dashboard/dist/test/setup.js +0 -0
- package/dashboard/package.json +0 -0
- package/deploy.md +0 -0
- package/discuss.md +0 -0
- package/docker-compose.dev.yml +0 -0
- package/docs.md +0 -0
- package/edge-cases.md +0 -0
- package/export.md +0 -0
- package/help.md +0 -0
- package/import-project.md +0 -0
- package/init.md +0 -0
- package/install.sh +0 -0
- package/issues.md +0 -0
- package/new-milestone.md +0 -0
- package/new-project.md +0 -0
- package/package.json +1 -1
- package/plan.md +0 -0
- package/progress.md +0 -0
- package/quality.md +0 -0
- package/quick.md +0 -0
- package/release.md +0 -0
- package/scripts/capture-screenshots.js +0 -0
- package/scripts/docs-update.js +0 -0
- package/scripts/generate-screenshots.js +0 -0
- package/scripts/project-docs.js +0 -0
- package/scripts/vps-setup.sh +0 -0
- package/server/dashboard/index.html +0 -0
- package/server/dashboard/login.html +0 -0
- package/server/index.js +0 -0
- package/server/lib/access-control-doc.js +0 -0
- package/server/lib/access-control-doc.test.js +0 -0
- package/server/lib/access-control.js +0 -0
- package/server/lib/access-control.test.js +1 -1
- package/server/lib/adapters/base-adapter.js +0 -0
- package/server/lib/adapters/base-adapter.test.js +0 -0
- package/server/lib/adapters/claude-adapter.js +0 -0
- package/server/lib/adapters/claude-adapter.test.js +0 -0
- package/server/lib/adapters/deepseek-adapter.js +0 -0
- package/server/lib/adapters/deepseek-adapter.test.js +0 -0
- package/server/lib/adapters/openai-adapter.js +0 -0
- package/server/lib/adapters/openai-adapter.test.js +0 -0
- package/server/lib/adr-generator.js +0 -0
- package/server/lib/adr-generator.test.js +0 -0
- package/server/lib/agent-cleanup.js +0 -0
- package/server/lib/agent-cleanup.test.js +0 -0
- package/server/lib/agent-hooks.js +0 -0
- package/server/lib/agent-hooks.test.js +0 -0
- package/server/lib/agent-metadata.js +0 -0
- package/server/lib/agent-metadata.test.js +0 -0
- package/server/lib/agent-persistence.js +0 -0
- package/server/lib/agent-persistence.test.js +0 -0
- package/server/lib/agent-progress-monitor.js +0 -0
- package/server/lib/agent-progress-monitor.test.js +0 -0
- package/server/lib/agent-registry-command.js +0 -0
- package/server/lib/agent-registry-command.test.js +0 -0
- package/server/lib/agent-registry.js +0 -0
- package/server/lib/agent-registry.test.js +0 -0
- package/server/lib/agent-state.js +0 -0
- package/server/lib/agent-state.test.js +0 -0
- package/server/lib/agents-cancel-command.js +0 -0
- package/server/lib/agents-cancel-command.test.js +1 -1
- package/server/lib/agents-get-command.js +0 -0
- package/server/lib/agents-get-command.test.js +1 -1
- package/server/lib/agents-list-command.js +0 -0
- package/server/lib/agents-list-command.test.js +1 -1
- package/server/lib/agents-logs-command.js +0 -0
- package/server/lib/agents-logs-command.test.js +1 -1
- package/server/lib/agents-retry-command.js +0 -0
- package/server/lib/agents-retry-command.test.js +1 -1
- package/server/lib/api-provider.js +0 -0
- package/server/lib/api-provider.test.js +0 -0
- package/server/lib/architecture-command.js +0 -0
- package/server/lib/architecture-command.test.js +0 -0
- package/server/lib/ast-analyzer.js +0 -0
- package/server/lib/ast-analyzer.test.js +0 -0
- package/server/lib/audit-attribution.js +0 -0
- package/server/lib/audit-attribution.test.js +0 -0
- package/server/lib/audit-classifier.js +0 -0
- package/server/lib/audit-classifier.test.js +0 -0
- package/server/lib/audit-command.js +0 -0
- package/server/lib/audit-command.test.js +0 -0
- package/server/lib/audit-exporter.js +0 -0
- package/server/lib/audit-exporter.test.js +0 -0
- package/server/lib/audit-logger.js +0 -0
- package/server/lib/audit-logger.test.js +0 -0
- package/server/lib/audit-query.js +0 -0
- package/server/lib/audit-query.test.js +0 -0
- package/server/lib/audit-storage.js +0 -0
- package/server/lib/audit-storage.test.js +0 -0
- package/server/lib/auth-flow-docs.js +0 -0
- package/server/lib/auth-flow-docs.test.js +0 -0
- package/server/lib/auth-system.js +0 -0
- package/server/lib/auth-system.test.js +0 -0
- package/server/lib/auto-database.js +0 -0
- package/server/lib/autofix-command.js +0 -0
- package/server/lib/autofix-command.test.js +0 -0
- package/server/lib/autofix-engine.js +0 -0
- package/server/lib/autofix-engine.test.js +0 -0
- package/server/lib/boundary-detector.js +0 -0
- package/server/lib/boundary-detector.test.js +0 -0
- package/server/lib/branch-deployer.js +0 -0
- package/server/lib/branch-deployer.test.js +0 -0
- package/server/lib/budget-alerts.js +0 -0
- package/server/lib/budget-alerts.test.js +0 -0
- package/server/lib/budget-limits.js +0 -0
- package/server/lib/budget-limits.test.js +2 -2
- package/server/lib/budget-tracker.js +0 -0
- package/server/lib/budget-tracker.test.js +0 -0
- package/server/lib/bug-sync.js +0 -0
- package/server/lib/bug-sync.test.js +0 -0
- package/server/lib/bulk-repo-init.js +0 -0
- package/server/lib/bulk-repo-init.test.js +0 -0
- package/server/lib/candidates-tracker.js +0 -0
- package/server/lib/candidates-tracker.test.js +0 -0
- package/server/lib/checkpoint-manager.js +0 -0
- package/server/lib/checkpoint-manager.test.js +0 -0
- package/server/lib/ci-command.js +0 -0
- package/server/lib/ci-command.test.js +0 -0
- package/server/lib/circular-detector.js +0 -0
- package/server/lib/circular-detector.test.js +0 -0
- package/server/lib/claude-injector.js +0 -0
- package/server/lib/claude-injector.test.js +0 -0
- package/server/lib/cli-detector.js +0 -0
- package/server/lib/cli-detector.test.js +0 -0
- package/server/lib/cli-provider.js +0 -0
- package/server/lib/cli-provider.test.js +0 -0
- package/server/lib/code-gate/bypass-logger.js +129 -0
- package/server/lib/code-gate/bypass-logger.test.js +142 -0
- package/server/lib/code-gate/gate-command.js +114 -0
- package/server/lib/code-gate/gate-command.test.js +111 -0
- package/server/lib/code-gate/gate-config.js +163 -0
- package/server/lib/code-gate/gate-config.test.js +181 -0
- package/server/lib/code-gate/gate-engine.js +193 -0
- package/server/lib/code-gate/gate-engine.test.js +258 -0
- package/server/lib/code-gate/gate-reporter.js +123 -0
- package/server/lib/code-gate/gate-reporter.test.js +159 -0
- package/server/lib/code-gate/hooks-generator.js +149 -0
- package/server/lib/code-gate/hooks-generator.test.js +142 -0
- package/server/lib/code-gate/llm-reviewer.js +176 -0
- package/server/lib/code-gate/llm-reviewer.test.js +161 -0
- package/server/lib/code-gate/push-gate.js +133 -0
- package/server/lib/code-gate/push-gate.test.js +190 -0
- package/server/lib/code-gate/rules/architecture-rules.js +228 -0
- package/server/lib/code-gate/rules/architecture-rules.test.js +155 -0
- package/server/lib/code-gate/rules/client-rules.js +120 -0
- package/server/lib/code-gate/rules/client-rules.test.js +121 -0
- package/server/lib/code-gate/rules/config-rules.js +140 -0
- package/server/lib/code-gate/rules/config-rules.test.js +103 -0
- package/server/lib/code-gate/rules/database-rules.js +158 -0
- package/server/lib/code-gate/rules/database-rules.test.js +119 -0
- package/server/lib/code-gate/rules/docker-rules.js +201 -0
- package/server/lib/code-gate/rules/docker-rules.test.js +104 -0
- package/server/lib/code-gate/rules/quality-rules.js +304 -0
- package/server/lib/code-gate/rules/quality-rules.test.js +199 -0
- package/server/lib/code-gate/rules/security-rules.js +228 -0
- package/server/lib/code-gate/rules/security-rules.test.js +131 -0
- package/server/lib/code-gate/rules/structure-rules.js +155 -0
- package/server/lib/code-gate/rules/structure-rules.test.js +107 -0
- package/server/lib/code-gate/rules/test-rules.js +93 -0
- package/server/lib/code-gate/rules/test-rules.test.js +97 -0
- package/server/lib/code-gate/typescript-gate.js +128 -0
- package/server/lib/code-gate/typescript-gate.test.js +131 -0
- package/server/lib/code-generator.js +0 -0
- package/server/lib/code-generator.test.js +1 -1
- package/server/lib/cohesion-analyzer.js +0 -0
- package/server/lib/cohesion-analyzer.test.js +0 -0
- package/server/lib/compliance/control-mapper.js +0 -0
- package/server/lib/compliance/control-mapper.test.js +0 -0
- package/server/lib/compliance/evidence-linker.js +0 -0
- package/server/lib/compliance/evidence-linker.test.js +0 -0
- package/server/lib/compliance/gdpr-checklist.js +0 -0
- package/server/lib/compliance/gdpr-checklist.test.js +0 -0
- package/server/lib/compliance/hipaa-checklist.js +0 -0
- package/server/lib/compliance/hipaa-checklist.test.js +0 -0
- package/server/lib/compliance/iso27001-checklist.js +0 -0
- package/server/lib/compliance/iso27001-checklist.test.js +0 -0
- package/server/lib/compliance/multi-framework-reporter.js +0 -0
- package/server/lib/compliance/multi-framework-reporter.test.js +0 -0
- package/server/lib/compliance/pci-dss-checklist.js +0 -0
- package/server/lib/compliance/pci-dss-checklist.test.js +0 -0
- package/server/lib/compliance/trust-centre.js +0 -0
- package/server/lib/compliance/trust-centre.test.js +0 -0
- package/server/lib/compliance-checklist.js +0 -0
- package/server/lib/compliance-checklist.test.js +0 -0
- package/server/lib/compliance-command.js +0 -0
- package/server/lib/compliance-command.test.js +0 -0
- package/server/lib/compliance-reporter.js +0 -0
- package/server/lib/compliance-reporter.test.js +0 -0
- package/server/lib/config.js +0 -0
- package/server/lib/config.test.js +0 -0
- package/server/lib/consensus-engine.js +0 -0
- package/server/lib/consensus-engine.test.js +0 -0
- package/server/lib/container-orchestrator.js +0 -0
- package/server/lib/container-orchestrator.test.js +0 -0
- package/server/lib/context-builder.js +0 -0
- package/server/lib/context-builder.test.js +0 -0
- package/server/lib/contract-testing.js +0 -0
- package/server/lib/contract-testing.test.js +0 -0
- package/server/lib/conversion-planner.js +0 -0
- package/server/lib/conversion-planner.test.js +0 -0
- package/server/lib/convert-command.js +0 -0
- package/server/lib/convert-command.test.js +0 -0
- package/server/lib/cost-command.js +0 -0
- package/server/lib/cost-command.test.js +1 -1
- package/server/lib/cost-optimizer.js +0 -0
- package/server/lib/cost-optimizer.test.js +1 -1
- package/server/lib/cost-projections.js +0 -0
- package/server/lib/cost-projections.test.js +1 -1
- package/server/lib/cost-reports.js +0 -0
- package/server/lib/cost-reports.test.js +1 -1
- package/server/lib/cost-tracker.js +0 -0
- package/server/lib/cost-tracker.test.js +1 -1
- package/server/lib/coupling-calculator.js +0 -0
- package/server/lib/coupling-calculator.test.js +0 -0
- package/server/lib/coverage-threshold.js +0 -0
- package/server/lib/coverage-threshold.test.js +0 -0
- package/server/lib/crypto-patterns.js +0 -0
- package/server/lib/crypto-patterns.test.js +1 -1
- package/server/lib/dashboard/api-server.js +0 -0
- package/server/lib/dashboard/api-server.test.js +0 -0
- package/server/lib/dashboard/health-api.js +0 -0
- package/server/lib/dashboard/health-api.test.js +0 -0
- package/server/lib/dashboard/notes-api.js +0 -0
- package/server/lib/dashboard/notes-api.test.js +0 -0
- package/server/lib/dashboard/router-api.js +0 -0
- package/server/lib/dashboard/router-api.test.js +0 -0
- package/server/lib/dashboard/tasks-api.js +0 -0
- package/server/lib/dashboard/tasks-api.test.js +0 -0
- package/server/lib/dashboard/tlc-introspection.js +0 -0
- package/server/lib/dashboard/tlc-introspection.test.js +0 -0
- package/server/lib/dashboard/version-api.js +0 -0
- package/server/lib/dashboard/version-api.test.js +0 -0
- package/server/lib/dashboard/websocket-server.js +0 -0
- package/server/lib/dashboard/websocket-server.test.js +0 -0
- package/server/lib/data-flow-doc.js +0 -0
- package/server/lib/data-flow-doc.test.js +0 -0
- package/server/lib/debug.test.js +0 -0
- package/server/lib/dependency-graph.js +0 -0
- package/server/lib/dependency-graph.test.js +0 -0
- package/server/lib/dependency-update.js +0 -0
- package/server/lib/dependency-update.test.js +0 -0
- package/server/lib/deploy/branch-classifier.js +0 -0
- package/server/lib/deploy/branch-classifier.test.js +0 -0
- package/server/lib/deploy/deployment-approval.js +0 -0
- package/server/lib/deploy/deployment-approval.test.js +0 -0
- package/server/lib/deploy/deployment-audit.js +0 -0
- package/server/lib/deploy/deployment-audit.test.js +0 -0
- package/server/lib/deploy/deployment-executor.js +0 -0
- package/server/lib/deploy/deployment-executor.test.js +0 -0
- package/server/lib/deploy/deployment-rules.js +0 -0
- package/server/lib/deploy/deployment-rules.test.js +0 -0
- package/server/lib/deploy/rollback-manager.js +0 -0
- package/server/lib/deploy/rollback-manager.test.js +0 -0
- package/server/lib/deploy/security-gates.js +0 -0
- package/server/lib/deploy/security-gates.test.js +0 -0
- package/server/lib/deploy-command.js +0 -0
- package/server/lib/deploy-command.test.js +0 -0
- package/server/lib/design-command.js +0 -0
- package/server/lib/design-command.test.js +1 -1
- package/server/lib/design-parser.js +0 -0
- package/server/lib/design-parser.test.js +1 -1
- package/server/lib/dev-server-command.js +0 -0
- package/server/lib/dev-server-command.test.js +0 -0
- package/server/lib/dev-server-runtime.js +0 -0
- package/server/lib/dev-server-runtime.test.js +0 -0
- package/server/lib/devserver-router-api.js +0 -0
- package/server/lib/devserver-router-api.test.js +0 -0
- package/server/lib/docker-manager.js +0 -0
- package/server/lib/docker-manager.test.js +0 -0
- package/server/lib/docs-command.js +0 -0
- package/server/lib/docs-command.test.js +0 -0
- package/server/lib/docs-generator.js +0 -0
- package/server/lib/docs-generator.test.js +0 -0
- package/server/lib/duplication-detector.js +0 -0
- package/server/lib/duplication-detector.test.js +0 -0
- package/server/lib/edge-case-generator.js +0 -0
- package/server/lib/edge-case-generator.test.js +0 -0
- package/server/lib/edge-cases-command.js +0 -0
- package/server/lib/edge-cases-command.test.js +0 -0
- package/server/lib/ephemeral-storage.js +0 -0
- package/server/lib/ephemeral-storage.test.js +0 -0
- package/server/lib/evidence-collector.js +0 -0
- package/server/lib/evidence-collector.test.js +0 -0
- package/server/lib/example-generator.js +0 -0
- package/server/lib/example-generator.test.js +0 -0
- package/server/lib/example-service.js +0 -0
- package/server/lib/example-service.test.js +0 -0
- package/server/lib/export-command.js +0 -0
- package/server/lib/export-command.test.js +0 -0
- package/server/lib/file-collector.js +0 -0
- package/server/lib/file-collector.test.js +0 -0
- package/server/lib/file-watcher.js +0 -0
- package/server/lib/file-watcher.test.js +0 -0
- package/server/lib/flow-diagram-generator.js +0 -0
- package/server/lib/flow-diagram-generator.test.js +0 -0
- package/server/lib/gemini-vision.js +0 -0
- package/server/lib/gemini-vision.test.js +1 -1
- package/server/lib/github-actions.js +0 -0
- package/server/lib/github-actions.test.js +0 -0
- package/server/lib/idp-manager.js +0 -0
- package/server/lib/idp-manager.test.js +0 -0
- package/server/lib/impact-scorer.js +0 -0
- package/server/lib/impact-scorer.test.js +0 -0
- package/server/lib/input-validator.js +0 -0
- package/server/lib/input-validator.test.js +1 -1
- package/server/lib/introspect.js +0 -0
- package/server/lib/introspect.test.js +0 -0
- package/server/lib/issue-command.js +0 -0
- package/server/lib/issue-command.test.js +0 -0
- package/server/lib/issue-tracker.js +0 -0
- package/server/lib/issue-tracker.test.js +0 -0
- package/server/lib/k8s/gitops-config.js +0 -0
- package/server/lib/k8s/gitops-config.test.js +0 -0
- package/server/lib/k8s/helm-generator.js +0 -0
- package/server/lib/k8s/helm-generator.test.js +0 -0
- package/server/lib/k8s/kustomize-generator.js +0 -0
- package/server/lib/k8s/kustomize-generator.test.js +0 -0
- package/server/lib/k8s/network-policy.js +0 -0
- package/server/lib/k8s/network-policy.test.js +0 -0
- package/server/lib/k8s/pod-security.js +0 -0
- package/server/lib/k8s/pod-security.test.js +0 -0
- package/server/lib/k8s/rbac-generator.js +0 -0
- package/server/lib/k8s/rbac-generator.test.js +0 -0
- package/server/lib/k8s/resource-manager.js +0 -0
- package/server/lib/k8s/resource-manager.test.js +0 -0
- package/server/lib/k8s/secrets-encryption.js +0 -0
- package/server/lib/k8s/secrets-encryption.test.js +0 -0
- package/server/lib/litellm-client.js +0 -0
- package/server/lib/litellm-client.test.js +1 -1
- package/server/lib/litellm-command.js +0 -0
- package/server/lib/litellm-command.test.js +1 -1
- package/server/lib/litellm-config.js +0 -0
- package/server/lib/litellm-config.test.js +1 -1
- package/server/lib/log-streamer.js +0 -0
- package/server/lib/log-streamer.test.js +0 -0
- package/server/lib/mcp-format.js +0 -0
- package/server/lib/mcp-format.test.js +0 -0
- package/server/lib/memory-classifier.js +0 -0
- package/server/lib/memory-classifier.test.js +0 -0
- package/server/lib/memory-committer.js +0 -0
- package/server/lib/memory-committer.test.js +0 -0
- package/server/lib/memory-exclusion.js +0 -0
- package/server/lib/memory-exclusion.test.js +0 -0
- package/server/lib/memory-hooks.js +0 -0
- package/server/lib/memory-hooks.test.js +0 -0
- package/server/lib/memory-init.js +0 -0
- package/server/lib/memory-init.test.js +0 -0
- package/server/lib/memory-observer.js +0 -0
- package/server/lib/memory-observer.test.js +0 -0
- package/server/lib/memory-reader.js +0 -0
- package/server/lib/memory-reader.test.js +0 -0
- package/server/lib/memory-storage.js +0 -0
- package/server/lib/memory-storage.test.js +0 -0
- package/server/lib/memory-writer.js +0 -0
- package/server/lib/memory-writer.test.js +0 -0
- package/server/lib/merge-command.js +0 -0
- package/server/lib/merge-command.test.js +0 -0
- package/server/lib/mermaid-generator.js +0 -0
- package/server/lib/mermaid-generator.test.js +0 -0
- package/server/lib/messaging-patterns.js +0 -0
- package/server/lib/messaging-patterns.test.js +0 -0
- package/server/lib/mfa-handler.js +0 -0
- package/server/lib/mfa-handler.test.js +0 -0
- package/server/lib/microservice-template.js +0 -0
- package/server/lib/microservice-template.test.js +0 -0
- package/server/lib/model-pricing.js +0 -0
- package/server/lib/model-pricing.test.js +1 -1
- package/server/lib/model-router.js +0 -0
- package/server/lib/model-router.test.js +0 -0
- package/server/lib/models-command.js +0 -0
- package/server/lib/models-command.test.js +1 -1
- package/server/lib/monitoring/alert-manager.js +0 -0
- package/server/lib/monitoring/alert-manager.test.js +0 -0
- package/server/lib/monitoring/health-check.js +0 -0
- package/server/lib/monitoring/health-check.test.js +0 -0
- package/server/lib/monitoring/incident-manager.js +0 -0
- package/server/lib/monitoring/incident-manager.test.js +0 -0
- package/server/lib/monitoring/log-aggregator.js +0 -0
- package/server/lib/monitoring/log-aggregator.test.js +0 -0
- package/server/lib/monitoring/metrics-collector.js +0 -0
- package/server/lib/monitoring/metrics-collector.test.js +0 -0
- package/server/lib/monitoring/status-page.js +0 -0
- package/server/lib/monitoring/status-page.test.js +0 -0
- package/server/lib/monitoring/uptime-monitor.js +0 -0
- package/server/lib/monitoring/uptime-monitor.test.js +0 -0
- package/server/lib/network/fail2ban-config.js +0 -0
- package/server/lib/network/fail2ban-config.test.js +0 -0
- package/server/lib/network/firewall-manager.js +0 -0
- package/server/lib/network/firewall-manager.test.js +0 -0
- package/server/lib/network/geoip-filter.js +0 -0
- package/server/lib/network/geoip-filter.test.js +0 -0
- package/server/lib/network/rate-limiter.js +0 -0
- package/server/lib/network/rate-limiter.test.js +0 -0
- package/server/lib/network/request-validator.js +0 -0
- package/server/lib/network/request-validator.test.js +0 -0
- package/server/lib/network/security-headers.js +0 -0
- package/server/lib/network/security-headers.test.js +0 -0
- package/server/lib/network/tls-config.js +0 -0
- package/server/lib/network/tls-config.test.js +0 -0
- package/server/lib/new-project-microservice.js +0 -0
- package/server/lib/new-project-microservice.test.js +0 -0
- package/server/lib/oauth-flow.js +0 -0
- package/server/lib/oauth-flow.test.js +0 -0
- package/server/lib/oauth-registry.js +0 -0
- package/server/lib/oauth-registry.test.js +0 -0
- package/server/lib/openapi-generator.js +0 -0
- package/server/lib/openapi-generator.test.js +0 -0
- package/server/lib/optimize-command.js +0 -0
- package/server/lib/optimize-command.test.js +1 -1
- package/server/lib/orchestration-integration.js +0 -0
- package/server/lib/orchestration-integration.test.js +1 -1
- package/server/lib/orm-schema-parser.js +0 -0
- package/server/lib/orm-schema-parser.test.js +0 -0
- package/server/lib/output-encoder.js +0 -0
- package/server/lib/output-encoder.test.js +1 -1
- package/server/lib/output-schemas.js +0 -0
- package/server/lib/output-schemas.test.js +0 -0
- package/server/lib/overdrive-command.js +0 -0
- package/server/lib/overdrive-command.test.js +0 -0
- package/server/lib/pattern-detector.js +0 -0
- package/server/lib/pattern-detector.test.js +0 -0
- package/server/lib/plan-parser.js +0 -0
- package/server/lib/pr-report.js +0 -0
- package/server/lib/pr-report.test.js +0 -0
- package/server/lib/pr-reviewer.js +0 -0
- package/server/lib/pr-reviewer.test.js +0 -0
- package/server/lib/project-detector.js +0 -0
- package/server/lib/provider-interface.js +0 -0
- package/server/lib/provider-interface.test.js +0 -0
- package/server/lib/provider-queue.js +0 -0
- package/server/lib/provider-queue.test.js +0 -0
- package/server/lib/qa-release-task.js +184 -0
- package/server/lib/qa-release-task.test.js +326 -0
- package/server/lib/quality-command.js +0 -0
- package/server/lib/quality-command.test.js +0 -0
- package/server/lib/quality-evaluator.js +0 -0
- package/server/lib/quality-evaluator.test.js +1 -1
- package/server/lib/quality-gate-command.js +0 -0
- package/server/lib/quality-gate-command.test.js +1 -1
- package/server/lib/quality-gate-scorer.js +0 -0
- package/server/lib/quality-gate-scorer.test.js +1 -1
- package/server/lib/quality-history.js +0 -0
- package/server/lib/quality-history.test.js +1 -1
- package/server/lib/quality-presets.js +0 -0
- package/server/lib/quality-presets.test.js +1 -1
- package/server/lib/quality-retry.js +0 -0
- package/server/lib/quality-retry.test.js +1 -1
- package/server/lib/quality-scorer.js +0 -0
- package/server/lib/quality-scorer.test.js +0 -0
- package/server/lib/quality-thresholds.js +0 -0
- package/server/lib/quality-thresholds.test.js +1 -1
- package/server/lib/readme-generator.js +0 -0
- package/server/lib/readme-generator.test.js +0 -0
- package/server/lib/refactor-command.js +0 -0
- package/server/lib/refactor-command.test.js +0 -0
- package/server/lib/refactor-executor.js +0 -0
- package/server/lib/refactor-executor.test.js +0 -0
- package/server/lib/refactor-observer.js +0 -0
- package/server/lib/refactor-observer.test.js +0 -0
- package/server/lib/refactor-progress.js +0 -0
- package/server/lib/refactor-progress.test.js +0 -0
- package/server/lib/refactor-reporter.js +0 -0
- package/server/lib/refactor-reporter.test.js +0 -0
- package/server/lib/release-audit.js +298 -0
- package/server/lib/release-audit.test.js +460 -0
- package/server/lib/release-config.js +174 -0
- package/server/lib/release-config.test.js +226 -0
- package/server/lib/release-gate.js +267 -0
- package/server/lib/release-gate.test.js +366 -0
- package/server/lib/release-notifier.js +276 -0
- package/server/lib/release-notifier.test.js +298 -0
- package/server/lib/relevance-scorer.js +0 -0
- package/server/lib/relevance-scorer.test.js +0 -0
- package/server/lib/repo-dependency-tracker.js +0 -0
- package/server/lib/repo-dependency-tracker.test.js +0 -0
- package/server/lib/retention-policy.js +0 -0
- package/server/lib/retention-policy.test.js +0 -0
- package/server/lib/review-command.js +0 -0
- package/server/lib/review-command.test.js +0 -0
- package/server/lib/review-orchestrator.js +0 -0
- package/server/lib/review-orchestrator.test.js +0 -0
- package/server/lib/review-reporter.js +0 -0
- package/server/lib/review-reporter.test.js +0 -0
- package/server/lib/role-mapper.js +0 -0
- package/server/lib/role-mapper.test.js +0 -0
- package/server/lib/route-detector.js +0 -0
- package/server/lib/route-detector.test.js +0 -0
- package/server/lib/router-config.js +0 -0
- package/server/lib/router-config.test.js +0 -0
- package/server/lib/router-setup-command.js +0 -0
- package/server/lib/router-setup-command.test.js +0 -0
- package/server/lib/router-status-api.js +0 -0
- package/server/lib/router-status-api.test.js +0 -0
- package/server/lib/saml-provider.js +0 -0
- package/server/lib/saml-provider.test.js +0 -0
- package/server/lib/screenshot-capture.js +0 -0
- package/server/lib/screenshot-capture.test.js +0 -0
- package/server/lib/secure-auth.js +0 -0
- package/server/lib/secure-auth.test.js +1 -1
- package/server/lib/secure-code-command.js +0 -0
- package/server/lib/secure-code-command.test.js +1 -1
- package/server/lib/secure-errors.js +0 -0
- package/server/lib/secure-errors.test.js +1 -1
- package/server/lib/security/auth-security.js +0 -0
- package/server/lib/security/auth-security.test.js +4 -3
- package/server/lib/security/cis-benchmark.js +0 -0
- package/server/lib/security/cis-benchmark.test.js +0 -0
- package/server/lib/security/compose-templates.js +0 -0
- package/server/lib/security/compose-templates.test.js +0 -0
- package/server/lib/security/container-runtime.js +0 -0
- package/server/lib/security/container-runtime.test.js +0 -0
- package/server/lib/security/cors-validator.js +0 -0
- package/server/lib/security/cors-validator.test.js +0 -0
- package/server/lib/security/crypto-utils.js +0 -0
- package/server/lib/security/crypto-utils.test.js +0 -0
- package/server/lib/security/dockerfile-linter.js +0 -0
- package/server/lib/security/dockerfile-linter.test.js +0 -0
- package/server/lib/security/dockerfile-templates.js +0 -0
- package/server/lib/security/dockerfile-templates.test.js +0 -0
- package/server/lib/security/error-sanitizer.js +0 -0
- package/server/lib/security/error-sanitizer.test.js +0 -0
- package/server/lib/security/headers-generator.js +0 -0
- package/server/lib/security/headers-generator.test.js +0 -0
- package/server/lib/security/image-scanner.js +0 -0
- package/server/lib/security/image-scanner.test.js +0 -0
- package/server/lib/security/input-validator.js +0 -0
- package/server/lib/security/input-validator.test.js +0 -0
- package/server/lib/security/network-policy.js +0 -0
- package/server/lib/security/network-policy.test.js +0 -0
- package/server/lib/security/output-encoder.js +0 -0
- package/server/lib/security/output-encoder.test.js +0 -0
- package/server/lib/security/path-validator.js +0 -0
- package/server/lib/security/path-validator.test.js +0 -0
- package/server/lib/security/query-builder.js +0 -0
- package/server/lib/security/query-builder.test.js +0 -0
- package/server/lib/security/secret-detector.js +0 -0
- package/server/lib/security/secret-detector.test.js +0 -0
- package/server/lib/security/secrets-validator.js +0 -0
- package/server/lib/security/secrets-validator.test.js +0 -0
- package/server/lib/security-audit.js +0 -0
- package/server/lib/security-audit.test.js +0 -0
- package/server/lib/security-policy-generator.js +0 -0
- package/server/lib/security-policy-generator.test.js +0 -0
- package/server/lib/security-testing/dast-runner.js +0 -0
- package/server/lib/security-testing/dast-runner.test.js +0 -0
- package/server/lib/security-testing/dependency-scanner.js +0 -0
- package/server/lib/security-testing/dependency-scanner.test.js +0 -0
- package/server/lib/security-testing/pentest-runner.js +0 -0
- package/server/lib/security-testing/pentest-runner.test.js +0 -0
- package/server/lib/security-testing/sast-runner.js +0 -0
- package/server/lib/security-testing/sast-runner.test.js +0 -0
- package/server/lib/security-testing/secret-scanner.js +0 -0
- package/server/lib/security-testing/secret-scanner.test.js +0 -0
- package/server/lib/security-testing/security-gate.js +0 -0
- package/server/lib/security-testing/security-gate.test.js +0 -0
- package/server/lib/security-testing/security-reporter.js +0 -0
- package/server/lib/security-testing/security-reporter.test.js +0 -0
- package/server/lib/semantic-analyzer.js +0 -0
- package/server/lib/semantic-analyzer.test.js +0 -0
- package/server/lib/sensitive-detector.js +0 -0
- package/server/lib/sensitive-detector.test.js +0 -0
- package/server/lib/service-interaction-diagram.js +0 -0
- package/server/lib/service-interaction-diagram.test.js +0 -0
- package/server/lib/service-proxy.js +0 -0
- package/server/lib/service-proxy.test.js +0 -0
- package/server/lib/service-scaffold.js +0 -0
- package/server/lib/service-scaffold.test.js +0 -0
- package/server/lib/service-summary.js +0 -0
- package/server/lib/service-summary.test.js +0 -0
- package/server/lib/session-purge.js +0 -0
- package/server/lib/session-purge.test.js +0 -0
- package/server/lib/session-summary.js +0 -0
- package/server/lib/session-summary.test.js +0 -0
- package/server/lib/shared-kernel.js +0 -0
- package/server/lib/shared-kernel.test.js +0 -0
- package/server/lib/slack-notifier.js +0 -0
- package/server/lib/slack-notifier.test.js +0 -0
- package/server/lib/spec-merger.js +0 -0
- package/server/lib/spec-merger.test.js +0 -0
- package/server/lib/sso-command.js +0 -0
- package/server/lib/sso-command.test.js +0 -0
- package/server/lib/sso-session.js +0 -0
- package/server/lib/sso-session.test.js +0 -0
- package/server/lib/standards/audit-checker.js +0 -0
- package/server/lib/standards/audit-checker.test.js +0 -0
- package/server/lib/standards/cleanup-executor.js +0 -0
- package/server/lib/standards/cleanup-executor.test.js +0 -0
- package/server/lib/standards/refactor-stepper.js +0 -0
- package/server/lib/standards/refactor-stepper.test.js +0 -0
- package/server/lib/standards/standards-injector.js +0 -0
- package/server/lib/standards/standards-injector.test.js +0 -0
- package/server/lib/tag-classifier.js +154 -0
- package/server/lib/tag-classifier.test.js +240 -0
- package/server/lib/tag-release-command.js +456 -0
- package/server/lib/tag-release-command.test.js +542 -0
- package/server/lib/tag-release.js +398 -0
- package/server/lib/tag-release.test.js +478 -0
- package/server/lib/team-docs-command.js +0 -0
- package/server/lib/team-docs-command.test.js +0 -0
- package/server/lib/team-docs.js +0 -0
- package/server/lib/team-docs.test.js +0 -0
- package/server/lib/tool-detector.js +0 -0
- package/server/lib/tool-detector.test.js +0 -0
- package/server/lib/tool-rules.js +0 -0
- package/server/lib/tool-rules.test.js +0 -0
- package/server/lib/traefik-config.js +0 -0
- package/server/lib/traefik-config.test.js +0 -0
- package/server/lib/usage-command.js +0 -0
- package/server/lib/usage-command.test.js +0 -0
- package/server/lib/usage-formatter.js +0 -0
- package/server/lib/usage-formatter.test.js +0 -0
- package/server/lib/usage-history.js +0 -0
- package/server/lib/usage-history.test.js +0 -0
- package/server/lib/user-management.test.js +0 -0
- package/server/lib/vision-command.js +0 -0
- package/server/lib/vision-command.test.js +1 -1
- package/server/lib/visual-command.js +0 -0
- package/server/lib/visual-command.test.js +1 -1
- package/server/lib/visual-testing.js +0 -0
- package/server/lib/visual-testing.test.js +1 -1
- package/server/lib/vps/backup-manager.js +0 -0
- package/server/lib/vps/backup-manager.test.js +0 -0
- package/server/lib/vps/caddy-config.js +0 -0
- package/server/lib/vps/caddy-config.test.js +0 -0
- package/server/lib/vps/compose-orchestrator.js +0 -0
- package/server/lib/vps/compose-orchestrator.test.js +0 -0
- package/server/lib/vps/database-config.js +0 -0
- package/server/lib/vps/database-config.test.js +0 -0
- package/server/lib/vps/deploy-script.js +0 -0
- package/server/lib/vps/deploy-script.test.js +0 -0
- package/server/lib/vps/secrets-manager.js +0 -0
- package/server/lib/vps/secrets-manager.test.js +0 -0
- package/server/lib/vps/server-hardening.js +0 -0
- package/server/lib/vps/server-hardening.test.js +0 -0
- package/server/lib/webhook-listener.js +0 -0
- package/server/lib/webhook-listener.test.js +0 -0
- package/server/lib/webhook-tag-handler.js +154 -0
- package/server/lib/webhook-tag-handler.test.js +228 -0
- package/server/lib/websocket-server.js +0 -0
- package/server/lib/websocket-server.test.js +0 -0
- package/server/lib/workspace-command.js +0 -0
- package/server/lib/workspace-command.test.js +0 -0
- package/server/lib/workspace-config.js +0 -0
- package/server/lib/workspace-config.test.js +0 -0
- package/server/lib/workspace-docs-command.js +0 -0
- package/server/lib/workspace-docs-command.test.js +0 -0
- package/server/lib/workspace-memory.js +0 -0
- package/server/lib/workspace-memory.test.js +0 -0
- package/server/lib/workspace-scanner.js +0 -0
- package/server/lib/workspace-scanner.test.js +0 -0
- package/server/lib/workspace-test-runner.js +0 -0
- package/server/lib/workspace-test-runner.test.js +0 -0
- package/server/lib/zero-retention-command.js +0 -0
- package/server/lib/zero-retention-command.test.js +0 -0
- package/server/lib/zero-retention.js +0 -0
- package/server/lib/zero-retention.test.js +0 -0
- package/server/package-lock.json +0 -0
- package/server/package.json +0 -0
- package/server/setup.sh +0 -0
- package/server/templates/CLAUDE.md +0 -0
- package/server/templates/CODING-STANDARDS.md +0 -0
- package/server.md +0 -0
- package/start-dev.bat +0 -0
- package/start-dev.ps1 +0 -0
- package/start-dev.sh +0 -0
- package/start.md +0 -0
- package/status.md +0 -0
- package/sync.md +0 -0
- package/templates/docs-sync.yml +0 -0
- package/tlc.md +0 -0
- package/update.md +0 -0
- package/verify.md +0 -0
- package/who.md +0 -0
|
@@ -0,0 +1,542 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tag Release Command Tests
|
|
3
|
+
*
|
|
4
|
+
* Tests for /tlc:tag CLI command covering all subcommands:
|
|
5
|
+
* create, status, accept, reject, promote, retry, list, history
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { describe, it, expect, beforeEach, vi } from 'vitest';
|
|
9
|
+
import { executeTagCommand } from './tag-release-command.js';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Build a mock release manager with sensible defaults.
|
|
13
|
+
* Each method is a vi.fn() that can be overridden per test.
|
|
14
|
+
*/
|
|
15
|
+
function makeMockManager(overrides = {}) {
|
|
16
|
+
return {
|
|
17
|
+
startRelease: vi.fn().mockResolvedValue({
|
|
18
|
+
tag: 'v1.0.0-rc.1',
|
|
19
|
+
commitSha: 'abc123',
|
|
20
|
+
tier: 'rc',
|
|
21
|
+
state: 'pending',
|
|
22
|
+
}),
|
|
23
|
+
runGates: vi.fn().mockResolvedValue({ passed: true, results: [] }),
|
|
24
|
+
deployPreview: vi.fn().mockResolvedValue('https://qa-v1.0.0-rc.1.example.com'),
|
|
25
|
+
acceptRelease: vi.fn().mockResolvedValue({
|
|
26
|
+
tag: 'v1.0.0-rc.1',
|
|
27
|
+
state: 'accepted',
|
|
28
|
+
reviewer: 'qa-lead',
|
|
29
|
+
}),
|
|
30
|
+
rejectRelease: vi.fn().mockResolvedValue({
|
|
31
|
+
tag: 'v1.0.0-rc.1',
|
|
32
|
+
state: 'rejected',
|
|
33
|
+
reviewer: 'qa-lead',
|
|
34
|
+
reason: 'UI broken',
|
|
35
|
+
}),
|
|
36
|
+
retryGates: vi.fn().mockResolvedValue({ passed: true, results: [] }),
|
|
37
|
+
getRelease: vi.fn().mockResolvedValue(null),
|
|
38
|
+
listReleases: vi.fn().mockResolvedValue([]),
|
|
39
|
+
...overrides,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Build a mock audit instance.
|
|
45
|
+
*/
|
|
46
|
+
function makeMockAudit(overrides = {}) {
|
|
47
|
+
return {
|
|
48
|
+
recordEvent: vi.fn().mockReturnValue({ id: 'evt-1', tag: 'v1.0.0-rc.1', action: 'created' }),
|
|
49
|
+
getEvents: vi.fn().mockReturnValue([]),
|
|
50
|
+
getAuditTrail: vi.fn().mockReturnValue([]),
|
|
51
|
+
getSummary: vi.fn().mockReturnValue([]),
|
|
52
|
+
...overrides,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Build a standard test context with DI.
|
|
58
|
+
*/
|
|
59
|
+
function makeContext(overrides = {}) {
|
|
60
|
+
return {
|
|
61
|
+
config: { release: {} },
|
|
62
|
+
projectDir: '/tmp/test-project',
|
|
63
|
+
user: { name: 'developer', role: 'developer' },
|
|
64
|
+
manager: makeMockManager(overrides.managerOverrides),
|
|
65
|
+
audit: makeMockAudit(overrides.auditOverrides),
|
|
66
|
+
...overrides,
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
describe('tag-release-command', () => {
|
|
71
|
+
// ─── create subcommand ────────────────────────────────────────────
|
|
72
|
+
|
|
73
|
+
describe('create subcommand', () => {
|
|
74
|
+
it('creates git tag and triggers pipeline', async () => {
|
|
75
|
+
const ctx = makeContext();
|
|
76
|
+
const result = await executeTagCommand('create', { tag: 'v1.0.0-rc.1', commit: 'abc123' }, ctx);
|
|
77
|
+
|
|
78
|
+
expect(result.success).toBe(true);
|
|
79
|
+
expect(result.message).toContain('v1.0.0-rc.1');
|
|
80
|
+
expect(ctx.manager.startRelease).toHaveBeenCalledWith('v1.0.0-rc.1', 'abc123');
|
|
81
|
+
expect(ctx.audit.recordEvent).toHaveBeenCalled();
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
it('validates tag format before proceeding', async () => {
|
|
85
|
+
const ctx = makeContext();
|
|
86
|
+
const result = await executeTagCommand('create', { tag: 'v1.0.0-rc.1', commit: 'abc123' }, ctx);
|
|
87
|
+
|
|
88
|
+
expect(result.success).toBe(true);
|
|
89
|
+
expect(result.data).toBeDefined();
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
it('rejects invalid tag names', async () => {
|
|
93
|
+
const ctx = makeContext();
|
|
94
|
+
const result = await executeTagCommand('create', { tag: 'not-a-valid-tag', commit: 'abc123' }, ctx);
|
|
95
|
+
|
|
96
|
+
expect(result.success).toBe(false);
|
|
97
|
+
expect(result.message).toMatch(/invalid/i);
|
|
98
|
+
expect(ctx.manager.startRelease).not.toHaveBeenCalled();
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
// ─── status subcommand ────────────────────────────────────────────
|
|
103
|
+
|
|
104
|
+
describe('status subcommand', () => {
|
|
105
|
+
it('shows current gate progress for a tag', async () => {
|
|
106
|
+
const release = {
|
|
107
|
+
tag: 'v1.0.0-rc.1',
|
|
108
|
+
state: 'gates-running',
|
|
109
|
+
gateResults: { passed: false, results: [{ gate: 'tests', status: 'pass' }] },
|
|
110
|
+
};
|
|
111
|
+
const ctx = makeContext({
|
|
112
|
+
managerOverrides: { getRelease: vi.fn().mockResolvedValue(release) },
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
const result = await executeTagCommand('status', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
116
|
+
|
|
117
|
+
expect(result.success).toBe(true);
|
|
118
|
+
expect(result.data.state).toBe('gates-running');
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
it('shows "not found" for unknown tag', async () => {
|
|
122
|
+
const ctx = makeContext({
|
|
123
|
+
managerOverrides: { getRelease: vi.fn().mockResolvedValue(null) },
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
const result = await executeTagCommand('status', { tag: 'v9.9.9' }, ctx);
|
|
127
|
+
|
|
128
|
+
expect(result.success).toBe(false);
|
|
129
|
+
expect(result.message).toMatch(/not found/i);
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
it('shows all active releases with no args', async () => {
|
|
133
|
+
const releases = [
|
|
134
|
+
{ tag: 'v1.0.0-rc.1', state: 'deployed' },
|
|
135
|
+
{ tag: 'v1.0.0-rc.2', state: 'pending' },
|
|
136
|
+
];
|
|
137
|
+
const ctx = makeContext({
|
|
138
|
+
managerOverrides: { listReleases: vi.fn().mockResolvedValue(releases) },
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
const result = await executeTagCommand('status', {}, ctx);
|
|
142
|
+
|
|
143
|
+
expect(result.success).toBe(true);
|
|
144
|
+
expect(result.data).toHaveLength(2);
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
// ─── accept subcommand ────────────────────────────────────────────
|
|
149
|
+
|
|
150
|
+
describe('accept subcommand', () => {
|
|
151
|
+
it('requires qa or admin role', async () => {
|
|
152
|
+
const ctx = makeContext({
|
|
153
|
+
user: { name: 'qa-lead', role: 'qa' },
|
|
154
|
+
});
|
|
155
|
+
|
|
156
|
+
const result = await executeTagCommand('accept', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
157
|
+
|
|
158
|
+
expect(result.success).toBe(true);
|
|
159
|
+
expect(ctx.manager.acceptRelease).toHaveBeenCalledWith('v1.0.0-rc.1', 'qa-lead');
|
|
160
|
+
});
|
|
161
|
+
|
|
162
|
+
it('rejects unauthorized users (developer role)', async () => {
|
|
163
|
+
const ctx = makeContext({
|
|
164
|
+
user: { name: 'dev1', role: 'developer' },
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
const result = await executeTagCommand('accept', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
168
|
+
|
|
169
|
+
expect(result.success).toBe(false);
|
|
170
|
+
expect(result.message).toMatch(/unauthorized|permission|role/i);
|
|
171
|
+
expect(ctx.manager.acceptRelease).not.toHaveBeenCalled();
|
|
172
|
+
});
|
|
173
|
+
|
|
174
|
+
it('updates release state to accepted', async () => {
|
|
175
|
+
const ctx = makeContext({
|
|
176
|
+
user: { name: 'admin1', role: 'admin' },
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
const result = await executeTagCommand('accept', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
180
|
+
|
|
181
|
+
expect(result.success).toBe(true);
|
|
182
|
+
expect(result.data.state).toBe('accepted');
|
|
183
|
+
expect(ctx.audit.recordEvent).toHaveBeenCalled();
|
|
184
|
+
});
|
|
185
|
+
});
|
|
186
|
+
|
|
187
|
+
// ─── reject subcommand ────────────────────────────────────────────
|
|
188
|
+
|
|
189
|
+
describe('reject subcommand', () => {
|
|
190
|
+
it('stores reason and marks as rejected', async () => {
|
|
191
|
+
const ctx = makeContext({
|
|
192
|
+
user: { name: 'qa-lead', role: 'qa' },
|
|
193
|
+
});
|
|
194
|
+
|
|
195
|
+
const result = await executeTagCommand(
|
|
196
|
+
'reject',
|
|
197
|
+
{ tag: 'v1.0.0-rc.1', reason: 'UI broken on mobile' },
|
|
198
|
+
ctx
|
|
199
|
+
);
|
|
200
|
+
|
|
201
|
+
expect(result.success).toBe(true);
|
|
202
|
+
expect(ctx.manager.rejectRelease).toHaveBeenCalledWith(
|
|
203
|
+
'v1.0.0-rc.1',
|
|
204
|
+
'qa-lead',
|
|
205
|
+
'UI broken on mobile'
|
|
206
|
+
);
|
|
207
|
+
expect(result.data.state).toBe('rejected');
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
it('requires reason text (fails without it)', async () => {
|
|
211
|
+
const ctx = makeContext({
|
|
212
|
+
user: { name: 'qa-lead', role: 'qa' },
|
|
213
|
+
});
|
|
214
|
+
|
|
215
|
+
const result = await executeTagCommand('reject', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
216
|
+
|
|
217
|
+
expect(result.success).toBe(false);
|
|
218
|
+
expect(result.message).toMatch(/reason/i);
|
|
219
|
+
expect(ctx.manager.rejectRelease).not.toHaveBeenCalled();
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
it('requires qa or admin role', async () => {
|
|
223
|
+
const ctx = makeContext({
|
|
224
|
+
user: { name: 'dev1', role: 'developer' },
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
const result = await executeTagCommand(
|
|
228
|
+
'reject',
|
|
229
|
+
{ tag: 'v1.0.0-rc.1', reason: 'Bad build' },
|
|
230
|
+
ctx
|
|
231
|
+
);
|
|
232
|
+
|
|
233
|
+
expect(result.success).toBe(false);
|
|
234
|
+
expect(result.message).toMatch(/unauthorized|permission|role/i);
|
|
235
|
+
});
|
|
236
|
+
});
|
|
237
|
+
|
|
238
|
+
// ─── promote subcommand ───────────────────────────────────────────
|
|
239
|
+
|
|
240
|
+
describe('promote subcommand', () => {
|
|
241
|
+
it('creates clean version tag from RC (v1.0.0-rc.1 -> v1.0.0)', async () => {
|
|
242
|
+
const ctx = makeContext({
|
|
243
|
+
managerOverrides: {
|
|
244
|
+
getRelease: vi.fn().mockResolvedValue({
|
|
245
|
+
tag: 'v1.0.0-rc.1',
|
|
246
|
+
state: 'accepted',
|
|
247
|
+
tier: 'rc',
|
|
248
|
+
}),
|
|
249
|
+
},
|
|
250
|
+
});
|
|
251
|
+
|
|
252
|
+
const result = await executeTagCommand('promote', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
253
|
+
|
|
254
|
+
expect(result.success).toBe(true);
|
|
255
|
+
expect(result.data.promotedTag).toBe('v1.0.0');
|
|
256
|
+
expect(result.message).toContain('v1.0.0');
|
|
257
|
+
});
|
|
258
|
+
|
|
259
|
+
it('rejects if release not accepted', async () => {
|
|
260
|
+
const ctx = makeContext({
|
|
261
|
+
managerOverrides: {
|
|
262
|
+
getRelease: vi.fn().mockResolvedValue({
|
|
263
|
+
tag: 'v1.0.0-rc.1',
|
|
264
|
+
state: 'deployed',
|
|
265
|
+
tier: 'rc',
|
|
266
|
+
}),
|
|
267
|
+
},
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
const result = await executeTagCommand('promote', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
271
|
+
|
|
272
|
+
expect(result.success).toBe(false);
|
|
273
|
+
expect(result.message).toMatch(/accepted|not accepted/i);
|
|
274
|
+
});
|
|
275
|
+
|
|
276
|
+
it('rejects non-RC tags', async () => {
|
|
277
|
+
const ctx = makeContext({
|
|
278
|
+
managerOverrides: {
|
|
279
|
+
getRelease: vi.fn().mockResolvedValue({
|
|
280
|
+
tag: 'v1.0.0-beta.1',
|
|
281
|
+
state: 'accepted',
|
|
282
|
+
tier: 'beta',
|
|
283
|
+
}),
|
|
284
|
+
},
|
|
285
|
+
});
|
|
286
|
+
|
|
287
|
+
const result = await executeTagCommand('promote', { tag: 'v1.0.0-beta.1' }, ctx);
|
|
288
|
+
|
|
289
|
+
expect(result.success).toBe(false);
|
|
290
|
+
expect(result.message).toMatch(/rc|release candidate/i);
|
|
291
|
+
});
|
|
292
|
+
});
|
|
293
|
+
|
|
294
|
+
// ─── retry subcommand ─────────────────────────────────────────────
|
|
295
|
+
|
|
296
|
+
describe('retry subcommand', () => {
|
|
297
|
+
it('only re-runs failed gates', async () => {
|
|
298
|
+
const ctx = makeContext({
|
|
299
|
+
managerOverrides: {
|
|
300
|
+
getRelease: vi.fn().mockResolvedValue({
|
|
301
|
+
tag: 'v1.0.0-rc.1',
|
|
302
|
+
state: 'gates-failed',
|
|
303
|
+
gateResults: {
|
|
304
|
+
passed: false,
|
|
305
|
+
results: [
|
|
306
|
+
{ gate: 'tests', status: 'pass' },
|
|
307
|
+
{ gate: 'security', status: 'fail' },
|
|
308
|
+
],
|
|
309
|
+
},
|
|
310
|
+
}),
|
|
311
|
+
retryGates: vi.fn().mockResolvedValue({
|
|
312
|
+
passed: true,
|
|
313
|
+
results: [
|
|
314
|
+
{ gate: 'tests', status: 'pass' },
|
|
315
|
+
{ gate: 'security', status: 'pass' },
|
|
316
|
+
],
|
|
317
|
+
}),
|
|
318
|
+
},
|
|
319
|
+
});
|
|
320
|
+
|
|
321
|
+
const result = await executeTagCommand('retry', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
322
|
+
|
|
323
|
+
expect(result.success).toBe(true);
|
|
324
|
+
expect(ctx.manager.retryGates).toHaveBeenCalledWith('v1.0.0-rc.1');
|
|
325
|
+
});
|
|
326
|
+
|
|
327
|
+
it('rejects if no failed gates', async () => {
|
|
328
|
+
const ctx = makeContext({
|
|
329
|
+
managerOverrides: {
|
|
330
|
+
getRelease: vi.fn().mockResolvedValue({
|
|
331
|
+
tag: 'v1.0.0-rc.1',
|
|
332
|
+
state: 'gates-passed',
|
|
333
|
+
gateResults: {
|
|
334
|
+
passed: true,
|
|
335
|
+
results: [{ gate: 'tests', status: 'pass' }],
|
|
336
|
+
},
|
|
337
|
+
}),
|
|
338
|
+
},
|
|
339
|
+
});
|
|
340
|
+
|
|
341
|
+
const result = await executeTagCommand('retry', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
342
|
+
|
|
343
|
+
expect(result.success).toBe(false);
|
|
344
|
+
expect(result.message).toMatch(/no failed|already passed|not failed/i);
|
|
345
|
+
});
|
|
346
|
+
});
|
|
347
|
+
|
|
348
|
+
// ─── list subcommand ──────────────────────────────────────────────
|
|
349
|
+
|
|
350
|
+
describe('list subcommand', () => {
|
|
351
|
+
it('shows tags with status indicators', async () => {
|
|
352
|
+
const releases = [
|
|
353
|
+
{ tag: 'v1.0.0-rc.1', state: 'accepted', tier: 'rc' },
|
|
354
|
+
{ tag: 'v1.1.0-rc.1', state: 'pending', tier: 'rc' },
|
|
355
|
+
];
|
|
356
|
+
const ctx = makeContext({
|
|
357
|
+
managerOverrides: { listReleases: vi.fn().mockResolvedValue(releases) },
|
|
358
|
+
});
|
|
359
|
+
|
|
360
|
+
const result = await executeTagCommand('list', {}, ctx);
|
|
361
|
+
|
|
362
|
+
expect(result.success).toBe(true);
|
|
363
|
+
expect(result.data).toHaveLength(2);
|
|
364
|
+
expect(result.message).toContain('v1.0.0-rc.1');
|
|
365
|
+
expect(result.message).toContain('v1.1.0-rc.1');
|
|
366
|
+
});
|
|
367
|
+
|
|
368
|
+
it('sorts by version descending', async () => {
|
|
369
|
+
const releases = [
|
|
370
|
+
{ tag: 'v1.0.0-rc.1', state: 'accepted', tier: 'rc' },
|
|
371
|
+
{ tag: 'v2.0.0-rc.1', state: 'pending', tier: 'rc' },
|
|
372
|
+
{ tag: 'v1.1.0-rc.1', state: 'deployed', tier: 'rc' },
|
|
373
|
+
];
|
|
374
|
+
const ctx = makeContext({
|
|
375
|
+
managerOverrides: { listReleases: vi.fn().mockResolvedValue(releases) },
|
|
376
|
+
});
|
|
377
|
+
|
|
378
|
+
const result = await executeTagCommand('list', {}, ctx);
|
|
379
|
+
|
|
380
|
+
expect(result.success).toBe(true);
|
|
381
|
+
// Should be sorted v2.0.0-rc.1, v1.1.0-rc.1, v1.0.0-rc.1
|
|
382
|
+
expect(result.data[0].tag).toBe('v2.0.0-rc.1');
|
|
383
|
+
expect(result.data[1].tag).toBe('v1.1.0-rc.1');
|
|
384
|
+
expect(result.data[2].tag).toBe('v1.0.0-rc.1');
|
|
385
|
+
});
|
|
386
|
+
|
|
387
|
+
it('shows empty message when no releases', async () => {
|
|
388
|
+
const ctx = makeContext({
|
|
389
|
+
managerOverrides: { listReleases: vi.fn().mockResolvedValue([]) },
|
|
390
|
+
});
|
|
391
|
+
|
|
392
|
+
const result = await executeTagCommand('list', {}, ctx);
|
|
393
|
+
|
|
394
|
+
expect(result.success).toBe(true);
|
|
395
|
+
expect(result.message).toMatch(/no releases|empty|none/i);
|
|
396
|
+
expect(result.data).toHaveLength(0);
|
|
397
|
+
});
|
|
398
|
+
});
|
|
399
|
+
|
|
400
|
+
// ─── history subcommand ───────────────────────────────────────────
|
|
401
|
+
|
|
402
|
+
describe('history subcommand', () => {
|
|
403
|
+
it('shows chronological release decisions', async () => {
|
|
404
|
+
const events = [
|
|
405
|
+
{ id: 'evt-1', tag: 'v1.0.0-rc.1', action: 'created', user: 'dev1', timestamp: '2024-01-01T00:00:00Z' },
|
|
406
|
+
{ id: 'evt-2', tag: 'v1.0.0-rc.1', action: 'accepted', user: 'qa-lead', timestamp: '2024-01-02T00:00:00Z' },
|
|
407
|
+
];
|
|
408
|
+
const ctx = makeContext({
|
|
409
|
+
auditOverrides: {
|
|
410
|
+
getAuditTrail: vi.fn().mockReturnValue(events),
|
|
411
|
+
getSummary: vi.fn().mockReturnValue([
|
|
412
|
+
{ tag: 'v1.0.0-rc.1', status: 'accepted', lastEvent: 'accepted', lastUpdated: '2024-01-02T00:00:00Z' },
|
|
413
|
+
]),
|
|
414
|
+
},
|
|
415
|
+
});
|
|
416
|
+
|
|
417
|
+
const result = await executeTagCommand('history', {}, ctx);
|
|
418
|
+
|
|
419
|
+
expect(result.success).toBe(true);
|
|
420
|
+
expect(result.data).toHaveLength(2);
|
|
421
|
+
});
|
|
422
|
+
|
|
423
|
+
it('filters by tag when specified', async () => {
|
|
424
|
+
const events = [
|
|
425
|
+
{ id: 'evt-1', tag: 'v1.0.0-rc.1', action: 'created', user: 'dev1', timestamp: '2024-01-01T00:00:00Z' },
|
|
426
|
+
];
|
|
427
|
+
const ctx = makeContext({
|
|
428
|
+
auditOverrides: { getAuditTrail: vi.fn().mockReturnValue(events) },
|
|
429
|
+
});
|
|
430
|
+
|
|
431
|
+
const result = await executeTagCommand('history', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
432
|
+
|
|
433
|
+
expect(result.success).toBe(true);
|
|
434
|
+
expect(ctx.audit.getAuditTrail).toHaveBeenCalledWith('v1.0.0-rc.1');
|
|
435
|
+
});
|
|
436
|
+
});
|
|
437
|
+
|
|
438
|
+
// ─── validation and error handling ────────────────────────────────
|
|
439
|
+
|
|
440
|
+
describe('validation and error handling', () => {
|
|
441
|
+
it('validates user role from config before accept/reject', async () => {
|
|
442
|
+
const ctx = makeContext({
|
|
443
|
+
user: { name: 'intern', role: 'viewer' },
|
|
444
|
+
});
|
|
445
|
+
|
|
446
|
+
const acceptResult = await executeTagCommand('accept', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
447
|
+
expect(acceptResult.success).toBe(false);
|
|
448
|
+
|
|
449
|
+
const rejectResult = await executeTagCommand(
|
|
450
|
+
'reject',
|
|
451
|
+
{ tag: 'v1.0.0-rc.1', reason: 'Bad' },
|
|
452
|
+
ctx
|
|
453
|
+
);
|
|
454
|
+
expect(rejectResult.success).toBe(false);
|
|
455
|
+
});
|
|
456
|
+
|
|
457
|
+
it('returns structured output { success, message, data }', async () => {
|
|
458
|
+
const ctx = makeContext();
|
|
459
|
+
const result = await executeTagCommand('create', { tag: 'v1.0.0-rc.1', commit: 'abc123' }, ctx);
|
|
460
|
+
|
|
461
|
+
expect(result).toHaveProperty('success');
|
|
462
|
+
expect(result).toHaveProperty('message');
|
|
463
|
+
expect(result).toHaveProperty('data');
|
|
464
|
+
});
|
|
465
|
+
|
|
466
|
+
it('unknown subcommand returns error', async () => {
|
|
467
|
+
const ctx = makeContext();
|
|
468
|
+
const result = await executeTagCommand('deploy', {}, ctx);
|
|
469
|
+
|
|
470
|
+
expect(result.success).toBe(false);
|
|
471
|
+
expect(result.message).toMatch(/unknown|unsupported|invalid/i);
|
|
472
|
+
});
|
|
473
|
+
|
|
474
|
+
it('help text lists available subcommands', async () => {
|
|
475
|
+
const ctx = makeContext();
|
|
476
|
+
const result = await executeTagCommand('help', {}, ctx);
|
|
477
|
+
|
|
478
|
+
expect(result.success).toBe(true);
|
|
479
|
+
expect(result.message).toContain('create');
|
|
480
|
+
expect(result.message).toContain('status');
|
|
481
|
+
expect(result.message).toContain('accept');
|
|
482
|
+
expect(result.message).toContain('reject');
|
|
483
|
+
expect(result.message).toContain('promote');
|
|
484
|
+
expect(result.message).toContain('retry');
|
|
485
|
+
expect(result.message).toContain('list');
|
|
486
|
+
expect(result.message).toContain('history');
|
|
487
|
+
});
|
|
488
|
+
|
|
489
|
+
it('each subcommand has proper error handling', async () => {
|
|
490
|
+
const ctx = makeContext({
|
|
491
|
+
managerOverrides: {
|
|
492
|
+
startRelease: vi.fn().mockRejectedValue(new Error('Disk full')),
|
|
493
|
+
},
|
|
494
|
+
});
|
|
495
|
+
|
|
496
|
+
const result = await executeTagCommand('create', { tag: 'v1.0.0-rc.1', commit: 'abc123' }, ctx);
|
|
497
|
+
|
|
498
|
+
expect(result.success).toBe(false);
|
|
499
|
+
expect(result.message).toContain('Disk full');
|
|
500
|
+
});
|
|
501
|
+
|
|
502
|
+
it('accept error handling catches manager exceptions', async () => {
|
|
503
|
+
const ctx = makeContext({
|
|
504
|
+
user: { name: 'qa-lead', role: 'qa' },
|
|
505
|
+
managerOverrides: {
|
|
506
|
+
acceptRelease: vi.fn().mockRejectedValue(new Error('Invalid state transition')),
|
|
507
|
+
},
|
|
508
|
+
});
|
|
509
|
+
|
|
510
|
+
const result = await executeTagCommand('accept', { tag: 'v1.0.0-rc.1' }, ctx);
|
|
511
|
+
|
|
512
|
+
expect(result.success).toBe(false);
|
|
513
|
+
expect(result.message).toContain('Invalid state transition');
|
|
514
|
+
});
|
|
515
|
+
|
|
516
|
+
it('promote returns not found for missing release', async () => {
|
|
517
|
+
const ctx = makeContext({
|
|
518
|
+
managerOverrides: {
|
|
519
|
+
getRelease: vi.fn().mockResolvedValue(null),
|
|
520
|
+
},
|
|
521
|
+
});
|
|
522
|
+
|
|
523
|
+
const result = await executeTagCommand('promote', { tag: 'v9.9.9-rc.1' }, ctx);
|
|
524
|
+
|
|
525
|
+
expect(result.success).toBe(false);
|
|
526
|
+
expect(result.message).toMatch(/not found/i);
|
|
527
|
+
});
|
|
528
|
+
|
|
529
|
+
it('retry returns not found for missing release', async () => {
|
|
530
|
+
const ctx = makeContext({
|
|
531
|
+
managerOverrides: {
|
|
532
|
+
getRelease: vi.fn().mockResolvedValue(null),
|
|
533
|
+
},
|
|
534
|
+
});
|
|
535
|
+
|
|
536
|
+
const result = await executeTagCommand('retry', { tag: 'v9.9.9-rc.1' }, ctx);
|
|
537
|
+
|
|
538
|
+
expect(result.success).toBe(false);
|
|
539
|
+
expect(result.message).toMatch(/not found/i);
|
|
540
|
+
});
|
|
541
|
+
});
|
|
542
|
+
});
|