1
0
mirror of https://github.com/bpatrik/pigallery2.git synced 2024-12-14 11:23:17 +02:00
pigallery2/.github/workflows/build.yml

195 lines
5.7 KiB
YAML
Raw Normal View History

2019-12-23 22:00:08 +02:00
name: docker-buildx
2019-12-20 20:12:34 +02:00
on:
pull_request:
branches: master
push:
branches: master
2019-12-30 01:43:52 +02:00
tags:
2019-12-30 01:50:47 +02:00
- '*.*'
2019-12-20 20:12:34 +02:00
jobs:
test:
runs-on: ubuntu-latest
2020-01-29 14:15:02 +02:00
strategy:
matrix:
node-version: [10.x, 12.x, 13.x]
2020-01-29 14:15:02 +02:00
services:
mariadb:
image: mariadb:latest
ports:
2020-01-29 17:15:39 +02:00
- 3306
2020-01-29 14:15:02 +02:00
env:
MYSQL_USER: user
MYSQL_PASSWORD: password
2020-01-30 00:02:07 +02:00
MYSQL_DATABASE: pigallery_test
2020-01-29 14:15:02 +02:00
MYSQL_ROOT_PASSWORD: password
options: --health-cmd="mysqladmin ping" --health-interval=5s --health-timeout=2s --health-retries=3
steps:
- uses: actions/checkout@v1
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
2020-01-29 14:15:02 +02:00
- name: Verify MariaDB connection
env:
PORT: ${{ job.services.mariadb.ports[3306] }}
run: |
while ! mysqladmin ping -h"127.0.0.1" -P"$PORT" --silent; do
sleep 1
done
- name: npm install, build, and test
run: |
npm ci
npm run build --if-present
npm test
env:
2020-01-29 14:15:02 +02:00
MYSQL_HOST: localhost
2020-01-29 17:47:28 +02:00
MYSQL_USERNAME: user
2020-01-29 14:15:02 +02:00
MYSQL_PASSWORD: password
2020-01-29 17:15:39 +02:00
MYSQL_PORT: ${{ job.services.mariadb.ports[3306] }}
2020-01-30 00:02:07 +02:00
MYSQL_DATABASE: pigallery_test
2020-01-29 13:29:25 +02:00
PORT: 35000
CI: true
2019-12-20 20:12:34 +02:00
create-release:
runs-on: [ubuntu-latest]
needs: [test]
2019-12-20 20:12:34 +02:00
steps:
-
name: Checkout
uses: actions/checkout@v1
2019-12-20 21:44:15 +02:00
-
2019-12-20 20:12:34 +02:00
name: Setup Node.js for use with actions
uses: actions/setup-node@v1.1.0
with:
version: 12
2019-12-20 21:44:15 +02:00
-
2019-12-20 20:12:34 +02:00
name: Install Deps
run: npm install --unsafe-perm
-
name: Create Release
run: npm run create-release -- --skip-opt-packages=ffmpeg,ffprobe --force-opt-packages
2019-12-20 20:12:34 +02:00
- uses: actions/upload-artifact@v1
with:
name: pigallery2-release
path: release
2020-01-01 15:15:15 +02:00
build-alpine:
runs-on: [ubuntu-latest]
needs: [create-release]
steps:
-
name: Set tag
id: vars
run: echo ::set-output name=tag::$(echo ${GITHUB_REF:10}) && echo ::set-output name=type::$(echo ${GITHUB_REF:5})
-
name: Checkout
uses: actions/checkout@v1
-
uses: actions/download-artifact@v1
with:
name: pigallery2-release
-
name: Set up Docker Buildx
id: buildx
uses: crazy-max/ghaction-docker-buildx@v1
with:
version: latest
-
name: Available platforms
run: echo ${{ steps.buildx.outputs.platforms }}
-
name: Docker login
run: |
docker login -u "${DOCKER_REGISTRY_USERNAME}" -p "${DOCKER_REGISTRY_PASSWORD}"
env:
DOCKER_REGISTRY_USERNAME: ${{ secrets.REGISTRY_USERNAME }}
DOCKER_REGISTRY_PASSWORD: ${{ secrets.REGISTRY_PASSWORD }}
-
name: Run Buildx alpine
if: startsWith(steps.vars.outputs.type , 'head')
run: |
docker buildx build \
--platform linux/amd64,linux/arm64,linux/arm/v7 \
--output "type=image,push=true" \
--tag bpatrik/pigallery2:nightly-alpine \
--file docker/alpine/Dockerfile.build .
- name: Run Buildx alpine for tag
if: startsWith(steps.vars.outputs.type , 'tag')
env:
RELEASE_VERSION: ${{ steps.vars.outputs.tag }}
run: |
docker buildx build \
--platform linux/amd64,linux/arm64,linux/arm/v7 \
--output "type=image,push=true" \
--tag bpatrik/pigallery2:nightly-alpine \
--tag bpatrik/pigallery2:$RELEASE_VERSION-alpine \
--tag bpatrik/pigallery2:latest-alpine \
--file docker/alpine/Dockerfile.build .
-
name: Docker logout
run: |
docker logout
build-stretch:
runs-on: [ubuntu-latest]
needs: [create-release]
steps:
2019-12-30 01:43:52 +02:00
-
name: Set tag
id: vars
2019-12-30 01:50:03 +02:00
run: echo ::set-output name=tag::$(echo ${GITHUB_REF:10}) && echo ::set-output name=type::$(echo ${GITHUB_REF:5})
-
name: Checkout
uses: actions/checkout@v1
-
uses: actions/download-artifact@v1
with:
name: pigallery2-release
-
name: Set up Docker Buildx
id: buildx
uses: crazy-max/ghaction-docker-buildx@v1
with:
version: latest
-
name: Available platforms
run: echo ${{ steps.buildx.outputs.platforms }}
-
name: Docker login
run: |
docker login -u "${DOCKER_REGISTRY_USERNAME}" -p "${DOCKER_REGISTRY_PASSWORD}"
env:
DOCKER_REGISTRY_USERNAME: ${{ secrets.REGISTRY_USERNAME }}
DOCKER_REGISTRY_PASSWORD: ${{ secrets.REGISTRY_PASSWORD }}
-
name: Run Buildx stretch
2019-12-30 01:50:03 +02:00
if: startsWith(steps.vars.outputs.type , 'head')
2019-12-30 01:43:52 +02:00
run: |
docker buildx build \
--platform linux/amd64,linux/arm64,linux/arm/v7 \
--output "type=image,push=true" \
--tag bpatrik/pigallery2:nightly-stretch \
--file docker/debian-stretch/Dockerfile.build .
-
name: Run Buildx stretch for tag
2019-12-30 01:50:03 +02:00
if: startsWith(steps.vars.outputs.type , 'tag')
2019-12-30 01:43:52 +02:00
env:
RELEASE_VERSION: ${{ steps.vars.outputs.tag }}
run: |
docker buildx build \
--platform linux/amd64,linux/arm64,linux/arm/v7 \
--output "type=image,push=true" \
--tag bpatrik/pigallery2:nightly-stretch \
2019-12-30 01:43:52 +02:00
--tag bpatrik/pigallery2:$RELEASE_VERSION \
--tag bpatrik/pigallery2:latest \
--file docker/debian-stretch/Dockerfile.build .
-
name: Docker logout
run: |
docker logout