Updated CI to publish-images on push to default branch.
This commit is contained in:
@@ -48,7 +48,8 @@ jobs:
|
|||||||
- run: dotnet test --configuration Release --no-build --logger "trx;LogFileName=test-results.trx"
|
- run: dotnet test --configuration Release --no-build --logger "trx;LogFileName=test-results.trx"
|
||||||
|
|
||||||
publish-image:
|
publish-image:
|
||||||
if: ${{ false }} # disabled for now
|
if: github.ref == format('refs/heads/{0}', github.event.repository.default_branch)
|
||||||
|
needs: build-test
|
||||||
runs-on: [self-hosted, linux, x64, docker]
|
runs-on: [self-hosted, linux, x64, docker]
|
||||||
container:
|
container:
|
||||||
image: ghcr.io/catthehacker/ubuntu:act-latest
|
image: ghcr.io/catthehacker/ubuntu:act-latest
|
||||||
@@ -56,33 +57,55 @@ jobs:
|
|||||||
--privileged
|
--privileged
|
||||||
env:
|
env:
|
||||||
REGISTRY: ${{ secrets.REGISTRY_HOST }}
|
REGISTRY: ${{ secrets.REGISTRY_HOST }}
|
||||||
OWNER_REPO: ${{ github.repository }}
|
|
||||||
DOCKERFILE: JSMR.Api/Dockerfile
|
|
||||||
CONTEXT: .
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Normalize image name (lowercase)
|
- name: Set image variables
|
||||||
id: names
|
id: vars
|
||||||
run: |
|
shell: bash
|
||||||
IMAGE_LC="$(echo "${REGISTRY}/${OWNER_REPO}" | tr '[:upper:]' '[:lower:]')"
|
run: |
|
||||||
echo "image=${IMAGE_LC}" >> "$GITHUB_OUTPUT"
|
OWNER_LC="$(echo "${{ github.repository_owner }}" | tr '[:upper:]' '[:lower:]')"
|
||||||
|
SHA_SHORT="$(echo "${{ github.sha }}" | cut -c1-7)"
|
||||||
|
echo "owner_lc=$OWNER_LC" >> "$GITHUB_OUTPUT"
|
||||||
|
echo "sha_short=$SHA_SHORT" >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
- name: Docker login
|
- name: Docker login
|
||||||
run: |
|
shell: bash
|
||||||
echo "${{ secrets.REGISTRY_PASSWORD }}" \
|
run: |
|
||||||
| docker login "${{ env.REGISTRY }}" \
|
echo "${{ secrets.REGISTRY_PASSWORD }}" \
|
||||||
-u "${{ secrets.REGISTRY_USER }}" \
|
| docker login "${{ env.REGISTRY }}" \
|
||||||
--password-stdin
|
-u "${{ secrets.REGISTRY_USER }}" \
|
||||||
|
--password-stdin
|
||||||
|
|
||||||
- name: Enable BuildKit
|
- name: Enable BuildKit
|
||||||
run: echo "DOCKER_BUILDKIT=1" >> $GITHUB_ENV
|
run: echo "DOCKER_BUILDKIT=1" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Build
|
|
||||||
run: docker build -f "$DOCKERFILE" -t "${{ steps.names.outputs.image }}:${{ github.sha }}" "$CONTEXT"
|
|
||||||
|
|
||||||
- name: Push
|
- name: Build API image
|
||||||
run: |
|
shell: bash
|
||||||
docker push "${{ steps.names.outputs.image }}:${{ github.sha }}"
|
run: |
|
||||||
docker tag "${{ steps.names.outputs.image }}:${{ github.sha }}" "${{ steps.names.outputs.image }}:latest"
|
docker build \
|
||||||
docker push "${{ steps.names.outputs.image }}:latest"
|
-f JSMR.Api/Dockerfile \
|
||||||
|
-t "${{ env.REGISTRY }}/${{ steps.vars.outputs.owner_lc }}/jsmr-api:${{ steps.vars.outputs.sha_short }}" \
|
||||||
|
-t "${{ env.REGISTRY }}/${{ steps.vars.outputs.owner_lc }}/jsmr-api:main" \
|
||||||
|
.
|
||||||
|
|
||||||
|
- name: Push API image
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
docker push "${{ env.REGISTRY }}/${{ steps.vars.outputs.owner_lc }}/jsmr-api:${{ steps.vars.outputs.sha_short }}"
|
||||||
|
docker push "${{ env.REGISTRY }}/${{ steps.vars.outputs.owner_lc }}/jsmr-api:main"
|
||||||
|
|
||||||
|
- name: Build Web image
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
docker build \
|
||||||
|
-f JSMR.UI.Blazor/Dockerfile \
|
||||||
|
-t "${{ env.REGISTRY }}/${{ steps.vars.outputs.owner_lc }}/jsmr-web:${{ steps.vars.outputs.sha_short }}" \
|
||||||
|
-t "${{ env.REGISTRY }}/${{ steps.vars.outputs.owner_lc }}/jsmr-web:main" \
|
||||||
|
.
|
||||||
|
|
||||||
|
- name: Push Web image
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
docker push "${{ env.REGISTRY }}/${{ steps.vars.outputs.owner_lc }}/jsmr-web:${{ steps.vars.outputs.sha_short }}"
|
||||||
|
docker push "${{ env.REGISTRY }}/${{ steps.vars.outputs.owner_lc }}/jsmr-web:main"
|
||||||
Reference in New Issue
Block a user