aios-core 4.2.14 → 4.3.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.
Files changed (288) hide show
  1. package/.aios-core/cli/commands/validate/index.js +1 -1
  2. package/.aios-core/core/code-intel/helpers/creation-helper.js +183 -0
  3. package/.aios-core/core/code-intel/helpers/devops-helper.js +166 -0
  4. package/.aios-core/core/code-intel/helpers/planning-helper.js +248 -0
  5. package/.aios-core/core/code-intel/helpers/qa-helper.js +187 -0
  6. package/.aios-core/core/code-intel/helpers/story-helper.js +146 -0
  7. package/.aios-core/core/config/schemas/framework-config.schema.json +155 -7
  8. package/.aios-core/core/config/schemas/project-config.schema.json +329 -15
  9. package/.aios-core/core/config/template-overrides.js +84 -0
  10. package/.aios-core/core/docs/troubleshooting-guide.md +1 -1
  11. package/.aios-core/core/doctor/checks/agent-memory.js +63 -0
  12. package/.aios-core/core/doctor/checks/claude-md.js +56 -0
  13. package/.aios-core/core/doctor/checks/code-intel.js +57 -0
  14. package/.aios-core/core/doctor/checks/commands-count.js +81 -0
  15. package/.aios-core/core/doctor/checks/core-config.js +53 -0
  16. package/.aios-core/core/doctor/checks/entity-registry.js +53 -0
  17. package/.aios-core/core/doctor/checks/git-hooks.js +50 -0
  18. package/.aios-core/core/doctor/checks/graph-dashboard.js +48 -0
  19. package/.aios-core/core/doctor/checks/hooks-claude-count.js +107 -0
  20. package/.aios-core/core/doctor/checks/ide-sync.js +68 -0
  21. package/.aios-core/core/doctor/checks/index.js +46 -0
  22. package/.aios-core/core/doctor/checks/node-version.js +33 -0
  23. package/.aios-core/core/doctor/checks/npm-packages.js +35 -0
  24. package/.aios-core/core/doctor/checks/rules-files.js +61 -0
  25. package/.aios-core/core/doctor/checks/settings-json.js +121 -0
  26. package/.aios-core/core/doctor/checks/skills-count.js +72 -0
  27. package/.aios-core/core/doctor/fix-handler.js +165 -0
  28. package/.aios-core/core/doctor/formatters/json.js +14 -0
  29. package/.aios-core/core/doctor/formatters/text.js +59 -0
  30. package/.aios-core/core/doctor/index.js +94 -0
  31. package/.aios-core/core/graph-dashboard/cli.js +361 -0
  32. package/.aios-core/core/graph-dashboard/data-sources/code-intel-source.js +234 -0
  33. package/.aios-core/core/graph-dashboard/data-sources/metrics-source.js +95 -0
  34. package/.aios-core/core/graph-dashboard/data-sources/registry-source.js +106 -0
  35. package/.aios-core/core/graph-dashboard/formatters/dot-formatter.js +45 -0
  36. package/.aios-core/core/graph-dashboard/formatters/html-formatter.js +1437 -0
  37. package/.aios-core/core/graph-dashboard/formatters/json-formatter.js +13 -0
  38. package/.aios-core/core/graph-dashboard/formatters/mermaid-formatter.js +59 -0
  39. package/.aios-core/core/graph-dashboard/index.js +21 -0
  40. package/.aios-core/core/graph-dashboard/renderers/stats-renderer.js +217 -0
  41. package/.aios-core/core/graph-dashboard/renderers/status-renderer.js +125 -0
  42. package/.aios-core/core/graph-dashboard/renderers/tree-renderer.js +119 -0
  43. package/.aios-core/core/health-check/base-check.js +1 -1
  44. package/.aios-core/core/health-check/check-registry.js +1 -1
  45. package/.aios-core/core/health-check/checks/deployment/build-config.js +1 -1
  46. package/.aios-core/core/health-check/checks/deployment/ci-config.js +1 -1
  47. package/.aios-core/core/health-check/checks/deployment/deployment-readiness.js +1 -1
  48. package/.aios-core/core/health-check/checks/deployment/docker-config.js +1 -1
  49. package/.aios-core/core/health-check/checks/deployment/env-file.js +1 -1
  50. package/.aios-core/core/health-check/checks/deployment/index.js +1 -1
  51. package/.aios-core/core/health-check/checks/index.js +1 -1
  52. package/.aios-core/core/health-check/checks/local/disk-space.js +1 -1
  53. package/.aios-core/core/health-check/checks/local/environment-vars.js +1 -1
  54. package/.aios-core/core/health-check/checks/local/git-install.js +1 -1
  55. package/.aios-core/core/health-check/checks/local/ide-detection.js +1 -1
  56. package/.aios-core/core/health-check/checks/local/index.js +1 -1
  57. package/.aios-core/core/health-check/checks/local/memory.js +1 -1
  58. package/.aios-core/core/health-check/checks/local/network.js +1 -1
  59. package/.aios-core/core/health-check/checks/local/npm-install.js +1 -1
  60. package/.aios-core/core/health-check/checks/local/shell-environment.js +1 -1
  61. package/.aios-core/core/health-check/checks/project/agent-config.js +1 -1
  62. package/.aios-core/core/health-check/checks/project/aios-directory.js +1 -1
  63. package/.aios-core/core/health-check/checks/project/dependencies.js +1 -1
  64. package/.aios-core/core/health-check/checks/project/framework-config.js +1 -1
  65. package/.aios-core/core/health-check/checks/project/index.js +1 -1
  66. package/.aios-core/core/health-check/checks/project/node-version.js +1 -1
  67. package/.aios-core/core/health-check/checks/project/package-json.js +1 -1
  68. package/.aios-core/core/health-check/checks/project/task-definitions.js +1 -1
  69. package/.aios-core/core/health-check/checks/project/workflow-dependencies.js +1 -1
  70. package/.aios-core/core/health-check/checks/repository/branch-protection.js +1 -1
  71. package/.aios-core/core/health-check/checks/repository/commit-history.js +1 -1
  72. package/.aios-core/core/health-check/checks/repository/conflicts.js +1 -1
  73. package/.aios-core/core/health-check/checks/repository/git-repo.js +1 -1
  74. package/.aios-core/core/health-check/checks/repository/git-status.js +1 -1
  75. package/.aios-core/core/health-check/checks/repository/gitignore.js +1 -1
  76. package/.aios-core/core/health-check/checks/repository/index.js +1 -1
  77. package/.aios-core/core/health-check/checks/repository/large-files.js +1 -1
  78. package/.aios-core/core/health-check/checks/repository/lockfile-integrity.js +1 -1
  79. package/.aios-core/core/health-check/checks/services/api-endpoints.js +1 -1
  80. package/.aios-core/core/health-check/checks/services/claude-code.js +1 -1
  81. package/.aios-core/core/health-check/checks/services/gemini-cli.js +1 -1
  82. package/.aios-core/core/health-check/checks/services/github-cli.js +1 -1
  83. package/.aios-core/core/health-check/checks/services/index.js +1 -1
  84. package/.aios-core/core/health-check/checks/services/mcp-integration.js +1 -1
  85. package/.aios-core/core/health-check/engine.js +1 -1
  86. package/.aios-core/core/health-check/healers/backup-manager.js +1 -1
  87. package/.aios-core/core/health-check/healers/index.js +1 -1
  88. package/.aios-core/core/health-check/index.js +9 -2
  89. package/.aios-core/core/health-check/reporters/console.js +1 -1
  90. package/.aios-core/core/health-check/reporters/index.js +1 -1
  91. package/.aios-core/core/health-check/reporters/json.js +1 -1
  92. package/.aios-core/core/health-check/reporters/markdown.js +1 -1
  93. package/.aios-core/core/ids/layer-classifier.js +65 -0
  94. package/.aios-core/core/ids/registry-updater.js +49 -0
  95. package/.aios-core/core/index.esm.js +1 -1
  96. package/.aios-core/core/index.js +1 -1
  97. package/.aios-core/core/session/context-detector.js +2 -7
  98. package/.aios-core/core/synapse/context/context-tracker.js +9 -1
  99. package/.aios-core/core/synapse/engine.js +33 -13
  100. package/.aios-core/core/synapse/runtime/hook-runtime.js +40 -2
  101. package/.aios-core/core/synapse/session/session-manager.js +3 -2
  102. package/.aios-core/core/synapse/utils/atomic-write.js +79 -0
  103. package/.aios-core/core-config.yaml +34 -1
  104. package/.aios-core/data/aios-kb.md +2 -2
  105. package/.aios-core/data/capability-detection.js +290 -0
  106. package/.aios-core/data/entity-registry.yaml +10424 -2127
  107. package/.aios-core/data/mcp-discipline.js +166 -0
  108. package/.aios-core/data/mcp-tool-examples.yaml +215 -0
  109. package/.aios-core/data/tok2-validation.js +168 -0
  110. package/.aios-core/data/tok3-token-comparison.js +123 -0
  111. package/.aios-core/data/tool-registry.yaml +648 -0
  112. package/.aios-core/data/tool-search-validation.js +174 -0
  113. package/.aios-core/development/agents/analyst/MEMORY.md +33 -0
  114. package/.aios-core/development/agents/architect/MEMORY.md +39 -0
  115. package/.aios-core/development/agents/data-engineer/MEMORY.md +32 -0
  116. package/.aios-core/development/agents/dev/MEMORY.md +46 -0
  117. package/.aios-core/development/agents/dev.md +1 -1
  118. package/.aios-core/development/agents/devops/MEMORY.md +39 -0
  119. package/.aios-core/development/agents/devops.md +22 -0
  120. package/.aios-core/development/agents/pm/MEMORY.md +38 -0
  121. package/.aios-core/development/agents/po/MEMORY.md +45 -0
  122. package/.aios-core/development/agents/qa/MEMORY.md +42 -0
  123. package/.aios-core/development/agents/qa.md +1 -1
  124. package/.aios-core/development/agents/sm/MEMORY.md +31 -0
  125. package/.aios-core/development/agents/ux/MEMORY.md +31 -0
  126. package/.aios-core/development/checklists/issue-triage-checklist.md +35 -0
  127. package/.aios-core/development/checklists/memory-audit-checklist.md +53 -0
  128. package/.aios-core/development/scripts/issue-triage.js +171 -0
  129. package/.aios-core/development/scripts/populate-entity-registry.js +412 -19
  130. package/.aios-core/development/scripts/unified-activation-pipeline.js +31 -10
  131. package/.aios-core/development/tasks/analyze-project-structure.md +48 -0
  132. package/.aios-core/development/tasks/brownfield-create-epic.md +41 -0
  133. package/.aios-core/development/tasks/create-doc.md +44 -0
  134. package/.aios-core/development/tasks/create-next-story.md +10 -0
  135. package/.aios-core/development/tasks/dev-develop-story.md +1 -1
  136. package/.aios-core/development/tasks/github-devops-github-pr-automation.md +49 -0
  137. package/.aios-core/development/tasks/github-devops-pre-push-quality-gate.md +63 -0
  138. package/.aios-core/development/tasks/github-issue-triage.md +118 -0
  139. package/.aios-core/development/tasks/health-check.yaml +206 -171
  140. package/.aios-core/development/tasks/kb-mode-interaction.md +3 -3
  141. package/.aios-core/development/tasks/plan-create-context.md +47 -1
  142. package/.aios-core/development/tasks/plan-create-implementation.md +55 -0
  143. package/.aios-core/development/tasks/pr-automation.md +5 -5
  144. package/.aios-core/development/tasks/qa-gate.md +48 -0
  145. package/.aios-core/development/tasks/qa-review-story.md +24 -1
  146. package/.aios-core/development/tasks/resolve-github-issue.md +608 -0
  147. package/.aios-core/development/tasks/review-contributor-pr.md +152 -0
  148. package/.aios-core/development/tasks/setup-llm-routing.md +1 -1
  149. package/.aios-core/development/tasks/spec-research-dependencies.md +4 -0
  150. package/.aios-core/development/tasks/triage-github-issues.md +356 -0
  151. package/.aios-core/development/tasks/validate-agents.md +4 -0
  152. package/.aios-core/development/tasks/validate-next-story.md +10 -0
  153. package/.aios-core/development/templates/agent-handoff-tmpl.yaml +48 -0
  154. package/.aios-core/development/templates/code-intel-integration-pattern.md +199 -0
  155. package/.aios-core/development/templates/ptc-entity-validation.md +113 -0
  156. package/.aios-core/development/templates/ptc-qa-gate.md +100 -0
  157. package/.aios-core/development/templates/ptc-research-aggregation.md +94 -0
  158. package/.aios-core/development/templates/service-template/README.md.hbs +158 -158
  159. package/.aios-core/development/templates/service-template/__tests__/index.test.ts.hbs +237 -237
  160. package/.aios-core/development/templates/service-template/client.ts.hbs +403 -403
  161. package/.aios-core/development/templates/service-template/errors.ts.hbs +182 -182
  162. package/.aios-core/development/templates/service-template/index.ts.hbs +120 -120
  163. package/.aios-core/development/templates/service-template/package.json.hbs +87 -87
  164. package/.aios-core/development/templates/service-template/types.ts.hbs +145 -145
  165. package/.aios-core/development/templates/squad/agent-template.md +11 -0
  166. package/.aios-core/development/templates/squad/task-template.md +21 -0
  167. package/.aios-core/development/templates/squad-template/LICENSE +21 -21
  168. package/.aios-core/docs/standards/AIOS-LIVRO-DE-OURO-V2.1-COMPLETE.md +1 -1
  169. package/.aios-core/docs/standards/AIOS-LIVRO-DE-OURO-V2.2-SUMMARY.md +1 -1
  170. package/.aios-core/framework-config.yaml +8 -0
  171. package/.aios-core/index.esm.js +1 -1
  172. package/.aios-core/index.js +1 -1
  173. package/.aios-core/infrastructure/integrations/ai-providers/index.js +1 -1
  174. package/.aios-core/infrastructure/schemas/task-v3-schema.json +6 -0
  175. package/.aios-core/infrastructure/scripts/collect-tool-usage.js +311 -0
  176. package/.aios-core/infrastructure/scripts/generate-optimization-report.js +497 -0
  177. package/.aios-core/infrastructure/scripts/generate-settings-json.js +300 -0
  178. package/.aios-core/infrastructure/scripts/git-config-detector.js +65 -9
  179. package/.aios-core/infrastructure/scripts/ide-sync/index.js +3 -1
  180. package/.aios-core/infrastructure/scripts/ide-sync/transformers/github-copilot.js +184 -0
  181. package/.aios-core/infrastructure/scripts/repository-detector.js +3 -3
  182. package/.aios-core/infrastructure/templates/aios-sync.yaml.template +182 -182
  183. package/.aios-core/infrastructure/templates/coderabbit.yaml.template +279 -279
  184. package/.aios-core/infrastructure/templates/github-workflows/ci.yml.template +169 -169
  185. package/.aios-core/infrastructure/templates/github-workflows/pr-automation.yml.template +330 -330
  186. package/.aios-core/infrastructure/templates/github-workflows/release.yml.template +196 -196
  187. package/.aios-core/infrastructure/templates/gitignore/gitignore-aios-base.tmpl +63 -63
  188. package/.aios-core/infrastructure/templates/gitignore/gitignore-brownfield-merge.tmpl +18 -18
  189. package/.aios-core/infrastructure/templates/gitignore/gitignore-node.tmpl +85 -85
  190. package/.aios-core/infrastructure/templates/gitignore/gitignore-python.tmpl +145 -145
  191. package/.aios-core/install-manifest.yaml +541 -249
  192. package/.aios-core/lib/build.json +1 -0
  193. package/.aios-core/local-config.yaml.template +71 -71
  194. package/.aios-core/monitor/hooks/lib/__init__.py +1 -1
  195. package/.aios-core/monitor/hooks/lib/enrich.py +58 -58
  196. package/.aios-core/monitor/hooks/lib/send_event.py +47 -47
  197. package/.aios-core/monitor/hooks/notification.py +29 -29
  198. package/.aios-core/monitor/hooks/post_tool_use.py +45 -45
  199. package/.aios-core/monitor/hooks/pre_compact.py +29 -29
  200. package/.aios-core/monitor/hooks/pre_tool_use.py +40 -40
  201. package/.aios-core/monitor/hooks/stop.py +29 -29
  202. package/.aios-core/monitor/hooks/subagent_stop.py +29 -29
  203. package/.aios-core/monitor/hooks/user_prompt_submit.py +38 -38
  204. package/.aios-core/product/templates/adr.hbs +125 -125
  205. package/.aios-core/product/templates/dbdr.hbs +241 -241
  206. package/.aios-core/product/templates/epic.hbs +212 -212
  207. package/.aios-core/product/templates/ide-rules/claude-rules.md +77 -0
  208. package/.aios-core/product/templates/pmdr.hbs +186 -186
  209. package/.aios-core/product/templates/prd-v2.0.hbs +216 -216
  210. package/.aios-core/product/templates/prd.hbs +201 -201
  211. package/.aios-core/product/templates/story.hbs +263 -263
  212. package/.aios-core/product/templates/task.hbs +170 -170
  213. package/.aios-core/product/templates/tmpl-comment-on-examples.sql +158 -158
  214. package/.aios-core/product/templates/tmpl-migration-script.sql +91 -91
  215. package/.aios-core/product/templates/tmpl-rls-granular-policies.sql +104 -104
  216. package/.aios-core/product/templates/tmpl-rls-kiss-policy.sql +10 -10
  217. package/.aios-core/product/templates/tmpl-rls-roles.sql +135 -135
  218. package/.aios-core/product/templates/tmpl-rls-simple.sql +77 -77
  219. package/.aios-core/product/templates/tmpl-rls-tenant.sql +152 -152
  220. package/.aios-core/product/templates/tmpl-rollback-script.sql +77 -77
  221. package/.aios-core/product/templates/tmpl-seed-data.sql +140 -140
  222. package/.aios-core/product/templates/tmpl-smoke-test.sql +16 -16
  223. package/.aios-core/product/templates/tmpl-staging-copy-merge.sql +139 -139
  224. package/.aios-core/product/templates/tmpl-stored-proc.sql +140 -140
  225. package/.aios-core/product/templates/tmpl-trigger.sql +152 -152
  226. package/.aios-core/product/templates/tmpl-view-materialized.sql +133 -133
  227. package/.aios-core/product/templates/tmpl-view.sql +177 -177
  228. package/.aios-core/scripts/pm.sh +0 -0
  229. package/.aios-core/user-guide.md +15 -15
  230. package/.aios-core/utils/filters/constants.js +10 -0
  231. package/.aios-core/utils/filters/content-filter.js +223 -0
  232. package/.aios-core/utils/filters/field-filter.js +126 -0
  233. package/.aios-core/utils/filters/index.js +180 -0
  234. package/.aios-core/utils/filters/schema-filter.js +157 -0
  235. package/.claude/CLAUDE.md +62 -0
  236. package/.claude/hooks/enforce-architecture-first.py +196 -196
  237. package/.claude/hooks/enforce-git-push-authority.sh +33 -0
  238. package/.claude/hooks/mind-clone-governance.py +192 -192
  239. package/.claude/hooks/read-protection.py +151 -151
  240. package/.claude/hooks/slug-validation.py +176 -176
  241. package/.claude/hooks/sql-governance.py +182 -182
  242. package/.claude/hooks/synapse-engine.cjs +28 -5
  243. package/.claude/hooks/write-path-validation.py +194 -194
  244. package/.claude/rules/agent-authority.md +105 -0
  245. package/.claude/rules/agent-handoff.md +97 -0
  246. package/.claude/rules/agent-memory-imports.md +15 -0
  247. package/.claude/rules/coderabbit-integration.md +101 -0
  248. package/.claude/rules/ids-principles.md +119 -0
  249. package/.claude/rules/story-lifecycle.md +145 -0
  250. package/.claude/rules/tool-examples.md +64 -0
  251. package/.claude/rules/tool-response-filtering.md +57 -0
  252. package/.claude/rules/workflow-execution.md +150 -0
  253. package/LICENSE +33 -33
  254. package/bin/aios-graph.js +9 -0
  255. package/bin/aios-init.js +2 -2
  256. package/bin/aios-minimal.js +0 -0
  257. package/bin/aios.js +17 -221
  258. package/bin/utils/detect-fsmonitor.js +70 -0
  259. package/bin/utils/framework-guard.js +238 -0
  260. package/bin/utils/validate-publish.js +108 -0
  261. package/package.json +6 -3
  262. package/packages/aios-install/bin/aios-install.js +0 -0
  263. package/packages/aios-install/bin/edmcp.js +0 -0
  264. package/packages/aios-pro-cli/bin/aios-pro.js +2 -0
  265. package/packages/installer/src/installer/brownfield-upgrader.js +68 -5
  266. package/packages/installer/src/merger/index.js +3 -0
  267. package/packages/installer/src/merger/strategies/index.js +6 -0
  268. package/packages/installer/src/merger/strategies/yaml-merger.js +181 -0
  269. package/packages/installer/src/updater/index.js +4 -4
  270. package/packages/installer/src/wizard/i18n.js +321 -3
  271. package/packages/installer/src/wizard/ide-config-generator.js +152 -25
  272. package/packages/installer/src/wizard/index.js +119 -1
  273. package/packages/installer/src/wizard/pro-setup.js +137 -121
  274. package/packages/installer/tests/unit/artifact-copy-pipeline/artifact-copy-pipeline.test.js +261 -0
  275. package/packages/installer/tests/unit/claude-md-template-v5/claude-md-template-v5.test.js +192 -0
  276. package/packages/installer/tests/unit/doctor/doctor-checks.test.js +551 -0
  277. package/packages/installer/tests/unit/doctor/doctor-orchestrator.test.js +134 -0
  278. package/packages/installer/tests/unit/entity-registry-bootstrap.test.js +186 -0
  279. package/packages/installer/tests/unit/generate-settings-json/generate-settings-json.test.js +309 -0
  280. package/packages/installer/tests/unit/ide-sync-integration/ide-sync-integration.test.js +230 -0
  281. package/packages/installer/tests/unit/merger/strategies.test.js +2 -2
  282. package/packages/installer/tests/unit/merger/yaml-merger.test.js +327 -0
  283. package/scripts/check-markdown-links.py +352 -352
  284. package/scripts/dashboard-parallel-dev.sh +0 -0
  285. package/scripts/dashboard-parallel-phase3.sh +0 -0
  286. package/scripts/dashboard-parallel-phase4.sh +0 -0
  287. package/scripts/install-monitor-hooks.sh +0 -0
  288. package/scripts/package-synapse.js +2 -1
@@ -1,330 +1,330 @@
1
- # =============================================================================
2
- # AIOS PR Automation Template
3
- # =============================================================================
4
- # Template for user projects created with AIOS-FULLSTACK
5
- # Generated by: *setup-github task (Story 5.10)
6
- #
7
- # Features:
8
- # - Required status checks (blocking)
9
- # - Coverage report posted as PR comment
10
- # - Quality gate summary comment
11
- # - CodeRabbit integration status
12
- # =============================================================================
13
-
14
- name: PR Automation
15
-
16
- on:
17
- pull_request:
18
- branches:
19
- - main
20
- - develop
21
- types: [opened, synchronize, reopened]
22
-
23
- permissions:
24
- contents: read
25
- pull-requests: write
26
- checks: write
27
-
28
- env:
29
- NODE_VERSION: '{{NODE_VERSION}}'
30
-
31
- jobs:
32
- # ===========================================================================
33
- # REQUIRED STATUS CHECKS (Blocking)
34
- # ===========================================================================
35
-
36
- lint:
37
- name: Lint
38
- runs-on: ubuntu-latest
39
- timeout-minutes: 5
40
- steps:
41
- - name: Checkout code
42
- uses: actions/checkout@v4
43
-
44
- - name: Setup Node.js
45
- uses: actions/setup-node@v4
46
- with:
47
- node-version: ${{ env.NODE_VERSION }}
48
- cache: 'npm'
49
-
50
- - name: Install dependencies
51
- run: npm ci
52
-
53
- - name: Run ESLint
54
- run: {{LINT_COMMAND}}
55
-
56
- typecheck:
57
- name: TypeCheck
58
- runs-on: ubuntu-latest
59
- timeout-minutes: 5
60
- steps:
61
- - name: Checkout code
62
- uses: actions/checkout@v4
63
-
64
- - name: Setup Node.js
65
- uses: actions/setup-node@v4
66
- with:
67
- node-version: ${{ env.NODE_VERSION }}
68
- cache: 'npm'
69
-
70
- - name: Install dependencies
71
- run: npm ci
72
-
73
- - name: Run TypeScript type checking
74
- run: {{TYPECHECK_COMMAND}}
75
-
76
- test:
77
- name: Test
78
- runs-on: ubuntu-latest
79
- timeout-minutes: 10
80
- outputs:
81
- coverage-summary: ${{ steps.coverage.outputs.summary }}
82
- steps:
83
- - name: Checkout code
84
- uses: actions/checkout@v4
85
-
86
- - name: Setup Node.js
87
- uses: actions/setup-node@v4
88
- with:
89
- node-version: ${{ env.NODE_VERSION }}
90
- cache: 'npm'
91
-
92
- - name: Install dependencies
93
- run: npm ci
94
-
95
- - name: Run tests with coverage
96
- id: test-run
97
- run: {{TEST_COMMAND}}
98
-
99
- - name: Upload coverage to Codecov
100
- uses: codecov/codecov-action@v4
101
- with:
102
- files: ./coverage/lcov.info
103
- flags: unittests
104
- fail_ci_if_error: false
105
-
106
- - name: Extract coverage summary
107
- id: coverage
108
- run: |
109
- if [ -f coverage/coverage-summary.json ]; then
110
- LINES=$(jq '.total.lines.pct' coverage/coverage-summary.json)
111
- STATEMENTS=$(jq '.total.statements.pct' coverage/coverage-summary.json)
112
- BRANCHES=$(jq '.total.branches.pct' coverage/coverage-summary.json)
113
- FUNCTIONS=$(jq '.total.functions.pct' coverage/coverage-summary.json)
114
- echo "summary=Lines: ${LINES}% | Statements: ${STATEMENTS}% | Branches: ${BRANCHES}% | Functions: ${FUNCTIONS}%" >> $GITHUB_OUTPUT
115
- else
116
- echo "summary=Coverage report not available" >> $GITHUB_OUTPUT
117
- fi
118
-
119
- - name: Upload coverage artifact
120
- uses: actions/upload-artifact@v4
121
- with:
122
- name: coverage-report
123
- path: coverage/
124
- retention-days: 7
125
-
126
- # ===========================================================================
127
- # COVERAGE COMMENT
128
- # ===========================================================================
129
-
130
- coverage-comment:
131
- name: Coverage Comment
132
- runs-on: ubuntu-latest
133
- needs: [test]
134
- if: always() && needs.test.result != 'cancelled'
135
- steps:
136
- - name: Post coverage comment
137
- uses: actions/github-script@v7
138
- with:
139
- script: |
140
- const coverageSummary = '${{ needs.test.outputs.coverage-summary }}' || 'Coverage data not available';
141
-
142
- const body = `## 📊 Coverage Report
143
-
144
- ${coverageSummary}
145
-
146
- <details>
147
- <summary>Coverage Details</summary>
148
-
149
- | Metric | Coverage |
150
- |--------|----------|
151
- | Lines | See Codecov |
152
- | Branches | See Codecov |
153
- | Functions | See Codecov |
154
- | Statements | See Codecov |
155
-
156
- </details>
157
-
158
- > 📈 Full coverage report available in [Codecov](https://codecov.io/gh/${{ github.repository }}/pull/${{ github.event.pull_request.number }})
159
- `;
160
-
161
- // Find existing comment
162
- const { data: comments } = await github.rest.issues.listComments({
163
- owner: context.repo.owner,
164
- repo: context.repo.repo,
165
- issue_number: context.issue.number,
166
- });
167
-
168
- const botComment = comments.find(comment =>
169
- comment.user.type === 'Bot' &&
170
- comment.body.includes('📊 Coverage Report')
171
- );
172
-
173
- if (botComment) {
174
- await github.rest.issues.updateComment({
175
- owner: context.repo.owner,
176
- repo: context.repo.repo,
177
- comment_id: botComment.id,
178
- body: body
179
- });
180
- } else {
181
- await github.rest.issues.createComment({
182
- owner: context.repo.owner,
183
- repo: context.repo.repo,
184
- issue_number: context.issue.number,
185
- body: body
186
- });
187
- }
188
-
189
- # ===========================================================================
190
- # QUALITY SUMMARY
191
- # ===========================================================================
192
-
193
- quality-summary:
194
- name: Quality Summary
195
- runs-on: ubuntu-latest
196
- needs: [lint, typecheck, test]
197
- if: always()
198
- steps:
199
- - name: Generate quality summary
200
- uses: actions/github-script@v7
201
- with:
202
- script: |
203
- const lintResult = '${{ needs.lint.result }}';
204
- const typecheckResult = '${{ needs.typecheck.result }}';
205
- const testResult = '${{ needs.test.result }}';
206
-
207
- const getEmoji = (result) => {
208
- switch(result) {
209
- case 'success': return '✅';
210
- case 'failure': return '❌';
211
- case 'cancelled': return 'âšī¸';
212
- case 'skipped': return 'â­ī¸';
213
- default: return 'âŗ';
214
- }
215
- };
216
-
217
- const allPassed = lintResult === 'success' &&
218
- typecheckResult === 'success' &&
219
- testResult === 'success';
220
-
221
- const overallStatus = allPassed ? '✅ All checks passed' : '❌ Some checks failed';
222
-
223
- const body = `## 📋 Quality Gate Summary
224
-
225
- **Overall Status:** ${overallStatus}
226
-
227
- | Check | Status | Result |
228
- |-------|--------|--------|
229
- | Lint | ${getEmoji(lintResult)} | ${lintResult} |
230
- | TypeCheck | ${getEmoji(typecheckResult)} | ${typecheckResult} |
231
- | Tests | ${getEmoji(testResult)} | ${testResult} |
232
-
233
- ### Required for Merge
234
- - ${getEmoji(lintResult)} ESLint validation
235
- - ${getEmoji(typecheckResult)} TypeScript type checking
236
- - ${getEmoji(testResult)} Test suite passing
237
-
238
- ### CodeRabbit Review
239
- 🐰 CodeRabbit will provide automated code review comments separately.
240
- - **CRITICAL** issues must be resolved before merge
241
- - **HIGH** issues should be addressed or documented
242
-
243
- ---
244
- *Generated by AIOS PR Automation*
245
- `;
246
-
247
- // Find existing comment
248
- const { data: comments } = await github.rest.issues.listComments({
249
- owner: context.repo.owner,
250
- repo: context.repo.repo,
251
- issue_number: context.issue.number,
252
- });
253
-
254
- const botComment = comments.find(comment =>
255
- comment.user.type === 'Bot' &&
256
- comment.body.includes('📋 Quality Gate Summary')
257
- );
258
-
259
- if (botComment) {
260
- await github.rest.issues.updateComment({
261
- owner: context.repo.owner,
262
- repo: context.repo.repo,
263
- comment_id: botComment.id,
264
- body: body
265
- });
266
- } else {
267
- await github.rest.issues.createComment({
268
- owner: context.repo.owner,
269
- repo: context.repo.repo,
270
- issue_number: context.issue.number,
271
- body: body
272
- });
273
- }
274
-
275
- - name: Set final status
276
- if: always()
277
- run: |
278
- LINT="${{ needs.lint.result }}"
279
- TYPE="${{ needs.typecheck.result }}"
280
- TEST="${{ needs.test.result }}"
281
-
282
- echo "=== PR Quality Gate Summary ==="
283
- echo "Lint: $LINT"
284
- echo "TypeCheck: $TYPE"
285
- echo "Tests: $TEST"
286
-
287
- if [ "$LINT" != "success" ] || [ "$TYPE" != "success" ] || [ "$TEST" != "success" ]; then
288
- echo "❌ Quality gate failed - merge will be blocked"
289
- exit 1
290
- fi
291
-
292
- echo "✅ All quality gates passed - ready for review"
293
-
294
- # ===========================================================================
295
- # CODERABBIT STATUS CHECK
296
- # ===========================================================================
297
-
298
- coderabbit-check:
299
- name: CodeRabbit Status
300
- runs-on: ubuntu-latest
301
- needs: [lint, typecheck, test]
302
- if: always()
303
- steps:
304
- - name: Check CodeRabbit configuration
305
- run: |
306
- echo "🐰 CodeRabbit Integration Status"
307
- echo "================================"
308
- echo ""
309
- echo "CodeRabbit is configured via .coderabbit.yaml"
310
- echo "Review will be posted as PR comments automatically"
311
- echo ""
312
- echo "Severity Handling:"
313
- echo " - CRITICAL: Must fix before merge"
314
- echo " - HIGH: Should address or document"
315
- echo " - MEDIUM/LOW: Optional"
316
-
317
- - name: Checkout for config check
318
- uses: actions/checkout@v4
319
- with:
320
- sparse-checkout: .coderabbit.yaml
321
- sparse-checkout-cone-mode: false
322
-
323
- - name: Validate config
324
- run: |
325
- if [ -f ".coderabbit.yaml" ]; then
326
- echo "✅ CodeRabbit configuration found"
327
- else
328
- echo "âš ī¸ CodeRabbit configuration not found"
329
- echo "Create .coderabbit.yaml to customize review behavior"
330
- fi
1
+ # =============================================================================
2
+ # AIOS PR Automation Template
3
+ # =============================================================================
4
+ # Template for user projects created with AIOS-FULLSTACK
5
+ # Generated by: *setup-github task (Story 5.10)
6
+ #
7
+ # Features:
8
+ # - Required status checks (blocking)
9
+ # - Coverage report posted as PR comment
10
+ # - Quality gate summary comment
11
+ # - CodeRabbit integration status
12
+ # =============================================================================
13
+
14
+ name: PR Automation
15
+
16
+ on:
17
+ pull_request:
18
+ branches:
19
+ - main
20
+ - develop
21
+ types: [opened, synchronize, reopened]
22
+
23
+ permissions:
24
+ contents: read
25
+ pull-requests: write
26
+ checks: write
27
+
28
+ env:
29
+ NODE_VERSION: '{{NODE_VERSION}}'
30
+
31
+ jobs:
32
+ # ===========================================================================
33
+ # REQUIRED STATUS CHECKS (Blocking)
34
+ # ===========================================================================
35
+
36
+ lint:
37
+ name: Lint
38
+ runs-on: ubuntu-latest
39
+ timeout-minutes: 5
40
+ steps:
41
+ - name: Checkout code
42
+ uses: actions/checkout@v4
43
+
44
+ - name: Setup Node.js
45
+ uses: actions/setup-node@v4
46
+ with:
47
+ node-version: ${{ env.NODE_VERSION }}
48
+ cache: 'npm'
49
+
50
+ - name: Install dependencies
51
+ run: npm ci
52
+
53
+ - name: Run ESLint
54
+ run: {{LINT_COMMAND}}
55
+
56
+ typecheck:
57
+ name: TypeCheck
58
+ runs-on: ubuntu-latest
59
+ timeout-minutes: 5
60
+ steps:
61
+ - name: Checkout code
62
+ uses: actions/checkout@v4
63
+
64
+ - name: Setup Node.js
65
+ uses: actions/setup-node@v4
66
+ with:
67
+ node-version: ${{ env.NODE_VERSION }}
68
+ cache: 'npm'
69
+
70
+ - name: Install dependencies
71
+ run: npm ci
72
+
73
+ - name: Run TypeScript type checking
74
+ run: {{TYPECHECK_COMMAND}}
75
+
76
+ test:
77
+ name: Test
78
+ runs-on: ubuntu-latest
79
+ timeout-minutes: 10
80
+ outputs:
81
+ coverage-summary: ${{ steps.coverage.outputs.summary }}
82
+ steps:
83
+ - name: Checkout code
84
+ uses: actions/checkout@v4
85
+
86
+ - name: Setup Node.js
87
+ uses: actions/setup-node@v4
88
+ with:
89
+ node-version: ${{ env.NODE_VERSION }}
90
+ cache: 'npm'
91
+
92
+ - name: Install dependencies
93
+ run: npm ci
94
+
95
+ - name: Run tests with coverage
96
+ id: test-run
97
+ run: {{TEST_COMMAND}}
98
+
99
+ - name: Upload coverage to Codecov
100
+ uses: codecov/codecov-action@v4
101
+ with:
102
+ files: ./coverage/lcov.info
103
+ flags: unittests
104
+ fail_ci_if_error: false
105
+
106
+ - name: Extract coverage summary
107
+ id: coverage
108
+ run: |
109
+ if [ -f coverage/coverage-summary.json ]; then
110
+ LINES=$(jq '.total.lines.pct' coverage/coverage-summary.json)
111
+ STATEMENTS=$(jq '.total.statements.pct' coverage/coverage-summary.json)
112
+ BRANCHES=$(jq '.total.branches.pct' coverage/coverage-summary.json)
113
+ FUNCTIONS=$(jq '.total.functions.pct' coverage/coverage-summary.json)
114
+ echo "summary=Lines: ${LINES}% | Statements: ${STATEMENTS}% | Branches: ${BRANCHES}% | Functions: ${FUNCTIONS}%" >> $GITHUB_OUTPUT
115
+ else
116
+ echo "summary=Coverage report not available" >> $GITHUB_OUTPUT
117
+ fi
118
+
119
+ - name: Upload coverage artifact
120
+ uses: actions/upload-artifact@v4
121
+ with:
122
+ name: coverage-report
123
+ path: coverage/
124
+ retention-days: 7
125
+
126
+ # ===========================================================================
127
+ # COVERAGE COMMENT
128
+ # ===========================================================================
129
+
130
+ coverage-comment:
131
+ name: Coverage Comment
132
+ runs-on: ubuntu-latest
133
+ needs: [test]
134
+ if: always() && needs.test.result != 'cancelled'
135
+ steps:
136
+ - name: Post coverage comment
137
+ uses: actions/github-script@v7
138
+ with:
139
+ script: |
140
+ const coverageSummary = '${{ needs.test.outputs.coverage-summary }}' || 'Coverage data not available';
141
+
142
+ const body = `## 📊 Coverage Report
143
+
144
+ ${coverageSummary}
145
+
146
+ <details>
147
+ <summary>Coverage Details</summary>
148
+
149
+ | Metric | Coverage |
150
+ |--------|----------|
151
+ | Lines | See Codecov |
152
+ | Branches | See Codecov |
153
+ | Functions | See Codecov |
154
+ | Statements | See Codecov |
155
+
156
+ </details>
157
+
158
+ > 📈 Full coverage report available in [Codecov](https://codecov.io/gh/${{ github.repository }}/pull/${{ github.event.pull_request.number }})
159
+ `;
160
+
161
+ // Find existing comment
162
+ const { data: comments } = await github.rest.issues.listComments({
163
+ owner: context.repo.owner,
164
+ repo: context.repo.repo,
165
+ issue_number: context.issue.number,
166
+ });
167
+
168
+ const botComment = comments.find(comment =>
169
+ comment.user.type === 'Bot' &&
170
+ comment.body.includes('📊 Coverage Report')
171
+ );
172
+
173
+ if (botComment) {
174
+ await github.rest.issues.updateComment({
175
+ owner: context.repo.owner,
176
+ repo: context.repo.repo,
177
+ comment_id: botComment.id,
178
+ body: body
179
+ });
180
+ } else {
181
+ await github.rest.issues.createComment({
182
+ owner: context.repo.owner,
183
+ repo: context.repo.repo,
184
+ issue_number: context.issue.number,
185
+ body: body
186
+ });
187
+ }
188
+
189
+ # ===========================================================================
190
+ # QUALITY SUMMARY
191
+ # ===========================================================================
192
+
193
+ quality-summary:
194
+ name: Quality Summary
195
+ runs-on: ubuntu-latest
196
+ needs: [lint, typecheck, test]
197
+ if: always()
198
+ steps:
199
+ - name: Generate quality summary
200
+ uses: actions/github-script@v7
201
+ with:
202
+ script: |
203
+ const lintResult = '${{ needs.lint.result }}';
204
+ const typecheckResult = '${{ needs.typecheck.result }}';
205
+ const testResult = '${{ needs.test.result }}';
206
+
207
+ const getEmoji = (result) => {
208
+ switch(result) {
209
+ case 'success': return '✅';
210
+ case 'failure': return '❌';
211
+ case 'cancelled': return 'âšī¸';
212
+ case 'skipped': return 'â­ī¸';
213
+ default: return 'âŗ';
214
+ }
215
+ };
216
+
217
+ const allPassed = lintResult === 'success' &&
218
+ typecheckResult === 'success' &&
219
+ testResult === 'success';
220
+
221
+ const overallStatus = allPassed ? '✅ All checks passed' : '❌ Some checks failed';
222
+
223
+ const body = `## 📋 Quality Gate Summary
224
+
225
+ **Overall Status:** ${overallStatus}
226
+
227
+ | Check | Status | Result |
228
+ |-------|--------|--------|
229
+ | Lint | ${getEmoji(lintResult)} | ${lintResult} |
230
+ | TypeCheck | ${getEmoji(typecheckResult)} | ${typecheckResult} |
231
+ | Tests | ${getEmoji(testResult)} | ${testResult} |
232
+
233
+ ### Required for Merge
234
+ - ${getEmoji(lintResult)} ESLint validation
235
+ - ${getEmoji(typecheckResult)} TypeScript type checking
236
+ - ${getEmoji(testResult)} Test suite passing
237
+
238
+ ### CodeRabbit Review
239
+ 🐰 CodeRabbit will provide automated code review comments separately.
240
+ - **CRITICAL** issues must be resolved before merge
241
+ - **HIGH** issues should be addressed or documented
242
+
243
+ ---
244
+ *Generated by AIOS PR Automation*
245
+ `;
246
+
247
+ // Find existing comment
248
+ const { data: comments } = await github.rest.issues.listComments({
249
+ owner: context.repo.owner,
250
+ repo: context.repo.repo,
251
+ issue_number: context.issue.number,
252
+ });
253
+
254
+ const botComment = comments.find(comment =>
255
+ comment.user.type === 'Bot' &&
256
+ comment.body.includes('📋 Quality Gate Summary')
257
+ );
258
+
259
+ if (botComment) {
260
+ await github.rest.issues.updateComment({
261
+ owner: context.repo.owner,
262
+ repo: context.repo.repo,
263
+ comment_id: botComment.id,
264
+ body: body
265
+ });
266
+ } else {
267
+ await github.rest.issues.createComment({
268
+ owner: context.repo.owner,
269
+ repo: context.repo.repo,
270
+ issue_number: context.issue.number,
271
+ body: body
272
+ });
273
+ }
274
+
275
+ - name: Set final status
276
+ if: always()
277
+ run: |
278
+ LINT="${{ needs.lint.result }}"
279
+ TYPE="${{ needs.typecheck.result }}"
280
+ TEST="${{ needs.test.result }}"
281
+
282
+ echo "=== PR Quality Gate Summary ==="
283
+ echo "Lint: $LINT"
284
+ echo "TypeCheck: $TYPE"
285
+ echo "Tests: $TEST"
286
+
287
+ if [ "$LINT" != "success" ] || [ "$TYPE" != "success" ] || [ "$TEST" != "success" ]; then
288
+ echo "❌ Quality gate failed - merge will be blocked"
289
+ exit 1
290
+ fi
291
+
292
+ echo "✅ All quality gates passed - ready for review"
293
+
294
+ # ===========================================================================
295
+ # CODERABBIT STATUS CHECK
296
+ # ===========================================================================
297
+
298
+ coderabbit-check:
299
+ name: CodeRabbit Status
300
+ runs-on: ubuntu-latest
301
+ needs: [lint, typecheck, test]
302
+ if: always()
303
+ steps:
304
+ - name: Check CodeRabbit configuration
305
+ run: |
306
+ echo "🐰 CodeRabbit Integration Status"
307
+ echo "================================"
308
+ echo ""
309
+ echo "CodeRabbit is configured via .coderabbit.yaml"
310
+ echo "Review will be posted as PR comments automatically"
311
+ echo ""
312
+ echo "Severity Handling:"
313
+ echo " - CRITICAL: Must fix before merge"
314
+ echo " - HIGH: Should address or document"
315
+ echo " - MEDIUM/LOW: Optional"
316
+
317
+ - name: Checkout for config check
318
+ uses: actions/checkout@v4
319
+ with:
320
+ sparse-checkout: .coderabbit.yaml
321
+ sparse-checkout-cone-mode: false
322
+
323
+ - name: Validate config
324
+ run: |
325
+ if [ -f ".coderabbit.yaml" ]; then
326
+ echo "✅ CodeRabbit configuration found"
327
+ else
328
+ echo "âš ī¸ CodeRabbit configuration not found"
329
+ echo "Create .coderabbit.yaml to customize review behavior"
330
+ fi