92 lines
2.7 KiB
YAML
92 lines
2.7 KiB
YAML
# Woodpecker CI for rdev platform
|
|
# Builds and deploys rdev-api, rdev-worker, and rdev-claudebox
|
|
#
|
|
# TODO: Remove skip-tls-verify from Kaniko steps once cert verification is tested.
|
|
# Registry has valid LE cert via Traefik — Kaniko should be able to verify it.
|
|
# Test by removing from one step first. If Kaniko can't verify (runs inside
|
|
# cluster hitting internal service), mount the CA bundle instead.
|
|
|
|
variables:
|
|
- &when_main
|
|
branch: main
|
|
event: push
|
|
|
|
steps:
|
|
# Run tests first
|
|
test:
|
|
image: golang:1.25-alpine
|
|
depends_on: []
|
|
commands:
|
|
- apk add --no-cache git
|
|
- go test ./...
|
|
when:
|
|
<<: *when_main
|
|
|
|
# Build rdev-api image
|
|
build-api:
|
|
image: woodpeckerci/plugin-kaniko
|
|
depends_on: [test]
|
|
settings:
|
|
registry: registry.threesix.ai
|
|
repo: rdev/api
|
|
tags:
|
|
- latest
|
|
- ${CI_COMMIT_SHA:0:8}
|
|
context: .
|
|
dockerfile: Dockerfile.api
|
|
cache: true
|
|
skip-tls-verify: true
|
|
when:
|
|
<<: *when_main
|
|
|
|
# Build rdev-worker image
|
|
build-worker:
|
|
image: woodpeckerci/plugin-kaniko
|
|
depends_on: [test]
|
|
settings:
|
|
registry: registry.threesix.ai
|
|
repo: rdev/worker
|
|
tags:
|
|
- latest
|
|
- ${CI_COMMIT_SHA:0:8}
|
|
context: .
|
|
dockerfile: Dockerfile.worker
|
|
cache: true
|
|
skip-tls-verify: true
|
|
when:
|
|
<<: *when_main
|
|
|
|
# Build rdev-claudebox image
|
|
build-claudebox:
|
|
image: woodpeckerci/plugin-kaniko
|
|
depends_on: [test]
|
|
settings:
|
|
registry: registry.threesix.ai
|
|
repo: rdev/claudebox
|
|
tags:
|
|
- latest
|
|
- ${CI_COMMIT_SHA:0:8}
|
|
context: .
|
|
dockerfile: Dockerfile
|
|
cache: true
|
|
skip-tls-verify: true
|
|
when:
|
|
<<: *when_main
|
|
|
|
# Deploy to k3s cluster
|
|
deploy:
|
|
image: bitnami/kubectl:latest
|
|
depends_on: [build-api, build-worker, build-claudebox]
|
|
commands:
|
|
- echo "Deploying rdev-api..."
|
|
- kubectl set image deployment/rdev-api rdev-api=registry.threesix.ai/rdev/api:${CI_COMMIT_SHA:0:8} -n rdev
|
|
- kubectl rollout status deployment/rdev-api -n rdev --timeout=120s
|
|
- echo "Deploying rdev-worker..."
|
|
- kubectl set image deployment/rdev-worker worker=registry.threesix.ai/rdev/worker:${CI_COMMIT_SHA:0:8} claudebox=registry.threesix.ai/rdev/claudebox:${CI_COMMIT_SHA:0:8} -n rdev
|
|
- kubectl rollout status deployment/rdev-worker -n rdev --timeout=120s
|
|
- echo "Deploying claudebox statefulset..."
|
|
- kubectl set image statefulset/claudebox claudebox=registry.threesix.ai/rdev/claudebox:${CI_COMMIT_SHA:0:8} -n rdev
|
|
- kubectl rollout status statefulset/claudebox -n rdev --timeout=300s
|
|
when:
|
|
<<: *when_main
|