55 lines
2.1 KiB
YAML
55 lines
2.1 KiB
YAML
# require the secrets DOCKER_HUB_PASSWORD
|
|
|
|
name: Release Docker Image
|
|
on:
|
|
push:
|
|
tags:
|
|
- v*
|
|
jobs:
|
|
test:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v2
|
|
- name: Run tests
|
|
run: |
|
|
if [ -f docker-compose.test.yml ]; then
|
|
docker-compose --file docker-compose.test.yml build
|
|
docker-compose --file docker-compose.test.yml run sut
|
|
else
|
|
docker build . --file Dockerfile
|
|
fi
|
|
push:
|
|
runs-on: ubuntu-latest
|
|
if: github.event_name == 'push'
|
|
steps:
|
|
- name: Set up Checkout
|
|
uses: actions/checkout@v2
|
|
- name: Install Buildx and QEMU
|
|
run: |
|
|
export DOCKER_BUILDKIT=1
|
|
docker build --platform=local -o . git://github.com/docker/buildx
|
|
mkdir -p ~/.docker/cli-plugins
|
|
mv buildx ~/.docker/cli-plugins/docker-buildx
|
|
docker run --rm --privileged multiarch/qemu-user-static:latest --reset -p yes --credential yes
|
|
docker buildx create --use --name build --node build --driver-opt network=host
|
|
- name: Log in to Docker Hub
|
|
env:
|
|
DOCKER_USERNAME: ${{ github.actor }}
|
|
DOCKER_PASSWORD: ${{ secrets.DOCKER_HUB_PASSWORD }}
|
|
run: |
|
|
echo "${DOCKER_PASSWORD}" | docker login --username ${DOCKER_USERNAME} --password-stdin
|
|
- name: Build and push Docker image
|
|
env:
|
|
DOCKER_USERNAME: ${{ github.actor }}
|
|
DOCKER_IMAGE_PLATFORM: linux/amd64,linux/arm/v7,linux/arm64
|
|
REPOSITORY_NAME: ${{ github.repository }}
|
|
run: |
|
|
IFS='/' read -ra repository_name_array <<<"$REPOSITORY_NAME"
|
|
DOCKER_IMAGE_NAME=$(echo $DOCKER_USERNAME/${repository_name_array[1]} | tr '[:upper:]' '[:lower:]')
|
|
DOCKER_IMAGE_VERSION=${GITHUB_REF#refs/*/}
|
|
docker buildx build \
|
|
--platform "$DOCKER_IMAGE_PLATFORM" \
|
|
--output "type=image,push=true" \
|
|
--tag "$DOCKER_IMAGE_NAME":"$DOCKER_IMAGE_VERSION" \
|
|
--tag "$DOCKER_IMAGE_NAME":latest \
|
|
--file ./Dockerfile .
|