From ab26eb1a9118bd65af280779b7726bad5113a7a2 Mon Sep 17 00:00:00 2001 From: Henrik Jess Nielsen Date: Sat, 9 May 2026 16:38:43 +0200 Subject: [PATCH] Fix CI workflow: match DevOpsMCP runner pattern - 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 --- .gitea/workflows/ci.yml | 81 ++++++++++++++++++++++++++++++++--------- 1 file changed, 64 insertions(+), 17 deletions(-) diff --git a/.gitea/workflows/ci.yml b/.gitea/workflows/ci.yml index 8164c0b..dfca3e4 100644 --- a/.gitea/workflows/ci.yml +++ b/.gitea/workflows/ci.yml @@ -1,26 +1,73 @@ -name: Build and push DevOpsDash +name: Build and Deploy DevOpsDash on: push: - branches: [main] + branches: + - main + workflow_dispatch: + +env: + SERVICE_NAME: devops-dash jobs: - build: - runs-on: ubuntu-latest + build-image: + 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: - - name: Checkout + - name: Checkout code uses: actions/checkout@v4 - - name: Login to registry - uses: docker/login-action@v3 - with: - registry: registry.i80.dk - username: ${{ secrets.REGISTRY_USER }} - password: ${{ secrets.REGISTRY_TOKEN }} + - name: System info + run: | + uname -a + whoami - - name: Build and push - uses: docker/build-push-action@v5 - with: - context: . - push: true - tags: registry.i80.dk/gitea/devops-dash:latest + - name: Log in to Docker Registry + run: | + echo "${{ secrets.HARBOR_ROBOT_TOKEN }}" | docker login registry.i80.dk -u "robot\$gitserver" --password-stdin + + - name: Build Docker image + 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"