disinto/disinto-factory/references/troubleshooting.md
johba cbe5df52b2
All checks were successful
ci/woodpecker/push/ci Pipeline was successful
feat: add disinto-factory skill for guided setup and operations
Distributable skill file (SKILL.md) that walks an AI agent through:
- First-time factory setup with interactive [ASK] prompts
- Post-init verification checklist
- Mirror configuration to GitHub/Codeberg
- Backlog seeding and issue creation
- Ongoing monitoring: agent status, CI, PRs
- Unsticking blocked issues

Includes:
- scripts/factory-status.sh — one-command factory health check
- references/troubleshooting.md — common issues from real deployments
- Slimmed CLAUDE.md pointing to the skill

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-28 11:13:24 +00:00

2.1 KiB

Troubleshooting

WOODPECKER_TOKEN empty after init

The OAuth2 flow failed. Common causes:

  1. URL-encoded redirect_uri mismatch: Forgejo logs show "Unregistered Redirect URI". The init script must rewrite both plain and URL-encoded Docker hostnames.

  2. Forgejo must_change_password: Admin user was created with forced password change. The init script calls --must-change-password=false but Forgejo 11.x sometimes ignores it.

  3. WOODPECKER_OPEN not set: WP refuses first-user OAuth registration without it.

Manual fix: reset admin password and re-run the token generation manually, or use the Woodpecker UI to create a token.

WP CI agent won't connect (DeadlineExceeded)

gRPC over Docker bridge fails in LXD (and possibly other nested container environments). The compose template uses network_mode: host + privileged: true for the agent. If you see this error, check:

  • Server exposes port 9000: grep "9000:9000" docker-compose.yml
  • Agent uses localhost:9000: grep "WOODPECKER_SERVER" docker-compose.yml
  • Agent has network_mode: host

CI clone fails (could not resolve host)

CI containers need to resolve Docker service names (e.g., forgejo). Check WOODPECKER_BACKEND_DOCKER_NETWORK is set on the agent.

Webhooks not delivered

Forgejo blocks outgoing webhooks by default. Check:

docker logs disinto-forgejo-1 2>&1 | grep "webhook.*ALLOWED_HOST_LIST"

Fix: add FORGEJO__webhook__ALLOWED_HOST_LIST: "private" to Forgejo environment.

Also verify the webhook exists:

curl -sf -u "disinto-admin:<password>" "http://localhost:3000/api/v1/repos/<org>/<repo>/hooks" | jq '.[].config.url'

If missing, deactivate and reactivate the repo in Woodpecker to auto-create it.

Dev-agent fails with "cd: no such file or directory"

PROJECT_REPO_ROOT inside the agents container points to a host path that doesn't exist in the container. Check the compose env:

docker inspect disinto-agents-1 --format '{{range .Config.Env}}{{println .}}{{end}}' | grep PROJECT_REPO_ROOT

Should be /home/agent/repos/<name>, not /home/<user>/<name>.