Files
jsmr/.gitea/workflows/ci.yml
Brian Bicknell e1ee0d1b45
Some checks failed
ci / build-test (push) Has been skipped
ci / publish-image (push) Failing after 1m0s
Added dockerfile.
2025-11-02 22:34:06 -05:00

69 lines
2.2 KiB
YAML

name: ci
on:
push:
pull_request:
jobs:
build-test:
if: ${{ false }} # disabled for now
runs-on: [self-hosted, linux, x64, docker]
container:
image: ghcr.io/catthehacker/ubuntu:act-latest
options: >-
--privileged
env:
TESTCONTAINERS_RYUK_DISABLED: 'true'
TESTCONTAINERS_CHECKS_DISABLE: 'true'
TESTCONTAINERS_HOST_OVERRIDE: host.docker.internal
steps:
- uses: actions/checkout@v4
- uses: actions/setup-dotnet@v4
with:
dotnet-version: '9.0.x'
- name: Docker sanity (ensures socket mount is working)
run: docker version
- run: dotnet restore
- run: dotnet build --configuration Release --no-restore
- run: dotnet test --configuration Release --no-build --logger "trx;LogFileName=test-results.trx"
publish-image:
runs-on: [self-hosted, linux, x64, docker]
container:
image: ghcr.io/catthehacker/ubuntu:act-latest
options: >-
--privileged
env:
REGISTRY: ${{ secrets.REGISTRY_HOST }}
OWNER_REPO: ${{ github.repository }}
DOCKERFILE: src/JSMR.Api/Dockerfile
CONTEXT: .
steps:
- uses: actions/checkout@v4
- name: Normalize image name (lowercase)
id: names
run: |
IMAGE_LC="$(echo "${REGISTRY}/${OWNER_REPO}" | tr '[:upper:]' '[:lower:]')"
echo "image=${IMAGE_LC}" >> "$GITHUB_OUTPUT"
- name: Docker login
run: |
echo "${{ secrets.REGISTRY_PASSWORD }}" \
| docker login "${{ env.REGISTRY }}" \
-u "${{ secrets.REGISTRY_USER }}" \
--password-stdin
- name: Enable BuildKit
run: echo "DOCKER_BUILDKIT=1" >> $GITHUB_ENV
- name: Build
run: docker build -f "$DOCKERFILE" -t "${{ steps.names.outputs.image }}:${{ github.sha }}" "$CONTEXT"
- name: Push
run: |
docker push "${{ steps.names.outputs.image }}:${{ github.sha }}"
docker tag "${{ steps.names.outputs.image }}:${{ github.sha }}" "${{ steps.names.outputs.image }}:latest"
docker push "${{ steps.names.outputs.image }}:latest"