196 lines
4.6 KiB
YAML
196 lines
4.6 KiB
YAML
name: ci
|
|
|
|
on:
|
|
workflow_dispatch:
|
|
schedule:
|
|
- cron: '0 10 * * *' # everyday at 10am
|
|
push:
|
|
branches:
|
|
- master
|
|
|
|
jobs:
|
|
dind:
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
DOCKER_CONFIG: $HOME/.docker
|
|
steps:
|
|
-
|
|
name: Checkout
|
|
uses: actions/checkout@v2
|
|
-
|
|
name: Login to GitHub Container Registry
|
|
uses: ./
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ secrets.GHCR_USERNAME }}
|
|
password: ${{ secrets.GHCR_PAT }}
|
|
-
|
|
name: DinD
|
|
uses: docker://docker
|
|
with:
|
|
entrypoint: docker
|
|
args: pull ghcr.io/docker-ghactiontest/test
|
|
-
|
|
name: Pull private image
|
|
run: |
|
|
docker image prune -a -f >/dev/null 2>&1
|
|
docker pull ghcr.io/docker-ghactiontest/test
|
|
|
|
dockerhub:
|
|
runs-on: ${{ matrix.os }}
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
os:
|
|
- ubuntu-20.04
|
|
- ubuntu-18.04
|
|
- ubuntu-16.04
|
|
steps:
|
|
-
|
|
name: Checkout
|
|
uses: actions/checkout@v2
|
|
-
|
|
name: Login to Docker Hub
|
|
uses: ./
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
|
|
ecr:
|
|
runs-on: ${{ matrix.os }}
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
os:
|
|
- ubuntu-20.04
|
|
- ubuntu-18.04
|
|
- ubuntu-16.04
|
|
steps:
|
|
-
|
|
name: Checkout
|
|
uses: actions/checkout@v2
|
|
-
|
|
name: Login to ECR
|
|
uses: ./
|
|
with:
|
|
registry: ${{ secrets.AWS_ACCOUNT_NUMBER }}.dkr.ecr.${{ secrets.AWS_REGION }}.amazonaws.com
|
|
username: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
|
password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
|
|
|
ecr-aws-creds:
|
|
runs-on: ${{ matrix.os }}
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
os:
|
|
- ubuntu-20.04
|
|
- ubuntu-18.04
|
|
- ubuntu-16.04
|
|
steps:
|
|
-
|
|
name: Checkout
|
|
uses: actions/checkout@v2
|
|
-
|
|
name: Configure AWS Credentials
|
|
uses: aws-actions/configure-aws-credentials@v1
|
|
with:
|
|
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
|
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
|
aws-region: ${{ secrets.AWS_REGION }}
|
|
-
|
|
name: Login to ECR
|
|
uses: ./
|
|
with:
|
|
registry: ${{ secrets.AWS_ACCOUNT_NUMBER }}.dkr.ecr.${{ secrets.AWS_REGION }}.amazonaws.com
|
|
|
|
ecr-public:
|
|
runs-on: ${{ matrix.os }}
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
os:
|
|
- ubuntu-20.04
|
|
- ubuntu-18.04
|
|
- ubuntu-16.04
|
|
steps:
|
|
-
|
|
name: Checkout
|
|
uses: actions/checkout@v2
|
|
-
|
|
name: Login to Public ECR
|
|
uses: ./
|
|
with:
|
|
registry: public.ecr.aws
|
|
username: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
|
password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
|
|
|
github-package:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
-
|
|
name: Checkout
|
|
uses: actions/checkout@v2
|
|
-
|
|
name: Login to GitHub Package Registry
|
|
uses: ./
|
|
with:
|
|
registry: docker.pkg.github.com
|
|
username: ${{ github.repository_owner }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
github-container:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
-
|
|
name: Checkout
|
|
uses: actions/checkout@v2
|
|
-
|
|
name: Login to GitHub Container Registry
|
|
uses: ./
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ secrets.GHCR_USERNAME }}
|
|
password: ${{ secrets.GHCR_PAT }}
|
|
|
|
gitlab:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
-
|
|
name: Checkout
|
|
uses: actions/checkout@v2
|
|
-
|
|
name: Login to GitLab
|
|
uses: ./
|
|
with:
|
|
registry: registry.gitlab.com
|
|
username: ${{ secrets.GITLAB_USERNAME }}
|
|
password: ${{ secrets.GITLAB_TOKEN }}
|
|
|
|
# google-artifact:
|
|
# runs-on: ubuntu-latest
|
|
# steps:
|
|
# -
|
|
# name: Checkout
|
|
# uses: actions/checkout@v2
|
|
# -
|
|
# name: Login to Google Artifact Registry
|
|
# uses: ./
|
|
# with:
|
|
# registry: ${{ secrets.GAR_LOCATION }}-docker.pkg.dev
|
|
# username: _json_key
|
|
# password: ${{ secrets.GAR_JSON_KEY }}
|
|
#
|
|
# google-container:
|
|
# runs-on: ubuntu-latest
|
|
# steps:
|
|
# -
|
|
# name: Checkout
|
|
# uses: actions/checkout@v2
|
|
# -
|
|
# name: Login to Google Container Registry
|
|
# uses: ./
|
|
# with:
|
|
# registry: gcr.io
|
|
# username: _json_key
|
|
# password: ${{ secrets.GCR_JSON_KEY }}
|