The install endpoint POST returned 404 because FORGEJO__database__DB_TYPE env var auto-configured Forgejo, bypassing install mode. Fix: run the Forgejo image as the step container instead of a service. This gives CLI access to `forgejo admin user create` for bootstrap admin setup — no install endpoint needed. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
27 lines
1.6 KiB
YAML
27 lines
1.6 KiB
YAML
# .woodpecker/smoke-init.yml — End-to-end smoke test for disinto init
|
|
#
|
|
# Uses the Forgejo image directly (not as a service) so we have CLI
|
|
# access to set up Forgejo and create the bootstrap admin user.
|
|
# Then runs disinto init --bare --yes against the local Forgejo instance.
|
|
|
|
when:
|
|
event: [push, pull_request]
|
|
|
|
steps:
|
|
- name: smoke-init
|
|
image: codeberg.org/forgejo/forgejo:11.0
|
|
environment:
|
|
SMOKE_FORGE_URL: http://localhost:3000
|
|
commands:
|
|
# Install test dependencies (Alpine-based image)
|
|
- apk add --no-cache bash curl jq python3 git >/dev/null 2>&1
|
|
# Set up Forgejo data directories and config
|
|
- mkdir -p /data/gitea/conf /data/gitea/repositories /data/gitea/lfs /data/gitea/log /data/git/.ssh /data/ssh
|
|
- printf '[database]\nDB_TYPE = sqlite3\nPATH = /data/gitea/forgejo.db\n\n[server]\nHTTP_PORT = 3000\nROOT_URL = http://localhost:3000/\nLFS_START_SERVER = false\n\n[security]\nINSTALL_LOCK = true\n\n[service]\nDISABLE_REGISTRATION = true\n' > /data/gitea/conf/app.ini
|
|
# Start Forgejo in background and wait for it
|
|
- forgejo web --config /data/gitea/conf/app.ini &
|
|
- for i in $(seq 1 30); do curl -sf http://localhost:3000/api/v1/version >/dev/null 2>&1 && break; sleep 1; done
|
|
# Create bootstrap admin user via CLI (this is why we use the Forgejo image)
|
|
- forgejo admin user create --admin --username setup-admin --password "SetupPass-789xyz" --email "setup-admin@smoke.test" --must-change-password=false --config /data/gitea/conf/app.ini
|
|
# Run the smoke test
|
|
- bash tests/smoke-init.sh
|