split up workflow files #1
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Docker - v2 previous | |
on: | |
pull_request: null | |
push: | |
paths: | |
- .github/workflows/v2-previous.yaml | |
- '2.3/**' | |
- '2.4/**' | |
- '2.5/**' | |
env: | |
AWS_REGION: us-east-1 | |
ECR_REPO: public.ecr.aws/u0u1j5s3/composer | |
build-previous: | |
name: Build previous versions | |
runs-on: ubuntu-latest | |
timeout-minutes: 20 | |
strategy: | |
fail-fast: false | |
matrix: | |
version: | |
- "2.3" | |
- "2.4" | |
- "2.5" | |
steps: | |
- uses: actions/checkout@v3 | |
# Build full image: binary with runtime | |
- name: Build full image | |
working-directory: ${{ matrix.version }} | |
run: | | |
docker build \ | |
--pull \ | |
--no-cache \ | |
--target binary-with-runtime \ | |
--tag composer/composer:${{ matrix.version }} \ | |
--tag composer/composer:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+') \ | |
. | |
# Build low-size image with binary only | |
- name: Build binary-only image | |
working-directory: ${{ matrix.version }} | |
run: | | |
docker build \ | |
--pull \ | |
--no-cache \ | |
--target standalone-binary \ | |
--tag composer/composer:${{ matrix.version }}-bin \ | |
--tag composer/composer:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+')-bin \ | |
. | |
- name: Login to Docker Hub | |
if: github.ref == 'refs/heads/main' | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_PASSWORD }} | |
- name: Push tag(s) to Docker Hub | |
if: github.ref == 'refs/heads/main' | |
working-directory: ${{ matrix.version }} | |
run: | | |
docker push composer/composer:${{ matrix.version }} | |
docker push composer/composer:${{ matrix.version }}-bin | |
docker push composer/composer:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+') | |
docker push composer/composer:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+')-bin | |
- name: Login to Amazon Public ECR | |
if: github.ref == 'refs/heads/main' | |
uses: docker/login-action@v2 | |
with: | |
registry: public.ecr.aws | |
username: ${{ secrets.AWS_ECR_ACCESS_KEY }} | |
password: ${{ secrets.AWS_ECR_SECRET_KEY }} | |
- name: Push tag(s) to Amazon Public ECR | |
if: github.ref == 'refs/heads/main' | |
working-directory: ${{ matrix.version }} | |
run: | | |
docker tag composer/composer:${{ matrix.version }} $ECR_REPO:${{ matrix.version }} | |
docker tag composer/composer:${{ matrix.version }}-bin $ECR_REPO:${{ matrix.version }}-bin | |
docker tag composer/composer:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+') $ECR_REPO:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+') | |
docker tag composer/composer:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+')-bin $ECR_REPO:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+')-bin | |
docker push $ECR_REPO:${{ matrix.version }} | |
docker push $ECR_REPO:${{ matrix.version }}-bin | |
docker push $ECR_REPO:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+') | |
docker push $ECR_REPO:$(grep -oP 'COMPOSER_VERSION ${{ matrix.version }}.\d+' Dockerfile | grep -oP '${{ matrix.version }}.\d+')-bin |