Skip to content

fix(dev): inject PLATFORM_TEMPLATES_DIR and harden controller startup wait#971

Merged
lefarcen merged 2 commits intomainfrom
fix/dev-controller-platform-templates
Apr 9, 2026
Merged

fix(dev): inject PLATFORM_TEMPLATES_DIR and harden controller startup wait#971
lefarcen merged 2 commits intomainfrom
fix/dev-controller-platform-templates

Conversation

@lefarcen
Copy link
Copy Markdown
Collaborator

@lefarcen lefarcen commented Apr 9, 2026

Summary

  • Inject PLATFORM_TEMPLATES_DIR into dev controller env so bots created via pnpm dev start receive platform docs (AGENTS.md, BOOTSTRAP.md, IDENTITY.md, etc.). The packaged desktop path sets it via manifests.ts, but dev mode bypasses that entirely.
  • Promote the missing-platformTemplatesDir log from debug to warn so this regression is loud next time.
  • Bump controller dev startup wait from 30 attempts / 15s to 120 attempts / 60s — Windows cold-start (tsx loader + bootstrap Promise.all) was timing out on the listener-bind boundary.

Test plan

  • pnpm dev start → create a new bot → verify AGENTS.md / BOOTSTRAP.md appear in workspace
  • Confirm controller starts cleanly on a cold machine without timeout

🤖 Generated with Claude Code

Bots created via `pnpm dev start` were missing platform docs (AGENTS.md,
BOOTSTRAP.md, IDENTITY.md, ...) because the dev controller env never
received PLATFORM_TEMPLATES_DIR, so WorkspaceTemplateWriter silently
skipped the copy. The packaged desktop path (manifests.ts) sets it, but
dev mode runs the controller as a standalone supervisor and bypasses
that path entirely.

Three changes:

1. scripts/dev/src/shared/dev-runtime-config.ts:
   inject PLATFORM_TEMPLATES_DIR pointing at apps/controller/static/platform-templates.

2. apps/controller/src/runtime/workspace-template-writer.ts:
   promote the missing-platformTemplatesDir branch from debug to warn
   so this regression is loud next time.

3. scripts/dev/src/{services,supervisors}/controller.ts:
   bump the controller dev startup wait from 30 attempts (15s) to 120
   (60s). Windows cold-start (tsx loader + bootstrap Promise.all) takes
   ~15s and was timing out on the listener-bind boundary, blocking
   `pnpm dev restart controller`.
@sentry
Copy link
Copy Markdown

sentry Bot commented Apr 9, 2026

Copy link
Copy Markdown

@chatgpt-codex-connector chatgpt-codex-connector Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

💡 Codex Review

Here are some automated review suggestions for this pull request.

Reviewed commit: 02fc757acf

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

Comment thread scripts/dev/src/services/controller.ts
When the controller supervisor crashes on start, the port wait now
exits immediately instead of polling for the full 60s timeout.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
@lefarcen lefarcen merged commit 247589d into main Apr 9, 2026
11 checks passed
@lefarcen lefarcen mentioned this pull request Apr 10, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants