Fix CI workflow: match DevOpsMCP runner pattern
Some checks failed
Build and Deploy DevOpsDash / build-image (push) Failing after 34s

- Use 'debian-host' runner (not ubuntu-latest)
- Use docker login with robot$gitserver + HARBOR_ROBOT_TOKEN secret
- Plain docker build/push (no docker/build-push-action)
- Add Nomad deploy step (nomad job run devops-dash.nomad)
- Add deployment status check + logs
This commit is contained in:
Henrik Jess Nielsen
2026-05-09 16:38:43 +02:00
parent 6ee58d1e57
commit ab26eb1a91

View File

@@ -1,26 +1,73 @@
name: Build and push DevOpsDash name: Build and Deploy DevOpsDash
on: on:
push: push:
branches: [main] branches:
- main
workflow_dispatch:
env:
SERVICE_NAME: devops-dash
jobs: jobs:
build: build-image:
runs-on: ubuntu-latest runs-on: debian-host
env:
PATH: /usr/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/sbin:/bin:/snap/bin
DOCKER_HOST: unix:///var/run/docker.sock
steps: steps:
- name: Checkout - name: Checkout code
uses: actions/checkout@v4 uses: actions/checkout@v4
- name: Login to registry - name: System info
uses: docker/login-action@v3 run: |
with: uname -a
registry: registry.i80.dk whoami
username: ${{ secrets.REGISTRY_USER }}
password: ${{ secrets.REGISTRY_TOKEN }}
- name: Build and push - name: Log in to Docker Registry
uses: docker/build-push-action@v5 run: |
with: echo "${{ secrets.HARBOR_ROBOT_TOKEN }}" | docker login registry.i80.dk -u "robot\$gitserver" --password-stdin
context: .
push: true - name: Build Docker image
tags: registry.i80.dk/gitea/devops-dash:latest run: |
SHA=$(git rev-parse --short HEAD)
docker build \
-t registry.i80.dk/gitea/devops-dash:latest \
-t registry.i80.dk/gitea/devops-dash:$SHA .
- name: Push Docker image
run: |
SHA=$(git rev-parse --short HEAD)
docker push registry.i80.dk/gitea/devops-dash:latest
docker push registry.i80.dk/gitea/devops-dash:$SHA
env:
PATH: /usr/bin:/usr/local/bin:/bin:/sbin:/usr/sbin
- name: Deploy to Nomad
run: |
nomad job validate ${SERVICE_NAME}.nomad
nomad job run ${SERVICE_NAME}.nomad
env:
NOMAD_ADDR: "https://nomad.i80.dk:4646"
- name: Wait for deployment
run: |
echo "Checking deployment status..."
nomad job status ${SERVICE_NAME}
echo "=== Allocation Details ==="
nomad job allocs ${SERVICE_NAME}
echo "=== Getting logs from allocations ==="
for alloc in $(nomad job allocs ${SERVICE_NAME} -short | tail -n +2 | awk '{print $1}'); do
echo "Logs for allocation $alloc:"
nomad alloc logs $alloc || echo "No logs available for $alloc"
done
env:
NOMAD_ADDR: "https://nomad.i80.dk:4646"
- name: Notify deployment status
run: |
echo "Deployment completed!"
echo "DevOpsDash should be available at: https://dash.i80.dk"
echo "Health check: https://dash.i80.dk/health"