dotfiles/.github/workflows/ubuntu.yaml

77 lines
2.6 KiB
YAML
Raw Normal View History

2020-12-21 17:06:30 +00:00
name: Ubuntu
2020-12-21 13:06:10 +00:00
on:
schedule:
- cron: '0 6 * * *'
pull_request:
branches: main
push:
branches: main
tags:
- v*
jobs:
2020-12-21 17:06:30 +00:00
ubuntu:
2020-12-21 13:06:10 +00:00
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Prepare
id: prepare
run: |
2020-12-23 19:31:35 +00:00
DOCKER_IMAGE=ghcr.io/mentos1386/workspace-ubuntu
2020-12-22 20:23:51 +00:00
DOCKER_PLATFORMS=linux/amd64,linux/arm64
2020-12-21 13:06:10 +00:00
VERSION=edge
if [[ $GITHUB_REF == refs/tags/* ]]; then
VERSION=${GITHUB_REF#refs/tags/v}
fi
if [ "${{ github.event_name }}" = "schedule" ]; then
VERSION=nightly
fi
TAGS="--tag ${DOCKER_IMAGE}:${VERSION}"
if [[ $VERSION =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
TAGS="$TAGS --tag ${DOCKER_IMAGE}:latest"
fi
echo ::set-output name=docker_image::${DOCKER_IMAGE}
echo ::set-output name=version::${VERSION}
echo ::set-output name=buildx_args::--platform ${DOCKER_PLATFORMS} \
--build-arg VERSION=${VERSION} \
--build-arg BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ') \
--build-arg VCS_REF=${GITHUB_SHA::8} \
--cache-from "type=local,src=/tmp/.buildx-cache" \
--cache-to "type=local,dest=/tmp/.buildx-cache" \
${TAGS} --file ./Dockerfile.ubuntu .
- name: Cache Docker layers
uses: actions/cache@v2
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-buildx-${{ github.sha }}
restore-keys: |
${{ runner.os }}-buildx-
2020-12-21 17:28:10 +00:00
- name: Set up QEMU
uses: docker/setup-qemu-action@v1
2020-12-21 13:06:10 +00:00
- name: Set up Docker Buildx
2020-12-21 13:20:53 +00:00
uses: docker/setup-buildx-action@v1
2020-12-21 13:06:10 +00:00
- name: Docker Buildx (build)
run: |
docker buildx build --output "type=image,push=false" ${{ steps.prepare.outputs.buildx_args }}
- name: Login to Github Registry
if: success() && github.event_name != 'pull_request'
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.CR_PAT }}
- name: Docker Buildx (push)
if: success() && github.event_name != 'pull_request'
run: |
docker buildx build --output "type=image,push=true" ${{ steps.prepare.outputs.buildx_args }}
- name: Inspect image
if: always() && github.event_name != 'pull_request'
run: |
docker buildx imagetools inspect ${{ steps.prepare.outputs.docker_image }}:${{ steps.prepare.outputs.version }}