[Dispatch] Release #32
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: "[Dispatch] Release" | |
on: | |
workflow_dispatch: | |
inputs: | |
version: | |
description: 'enter version(x.y.z)' | |
required: true | |
default: '2.0.0' | |
container_arch: | |
type: choice | |
description: 'choose container architecture' | |
default: linux/amd64 | |
options: | |
- "linux/amd64" | |
- "linux/amd64,linux/arm64" | |
env: | |
ARCH: ${{ github.event.inputs.container_arch }} | |
VERSION: ${{ github.event.inputs.version }} | |
PACKAGE_VERSION: ${{ github.event.inputs.version }} | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} | |
BRANCH_NAME: ${{ github.ref_name }} | |
jobs: | |
tagging: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
token: ${{ secrets.PAT_TOKEN }} | |
- name: tagging | |
run: | | |
git config user.email [email protected] | |
git config user.name cloudforet-admin | |
git tag ${{ env.VERSION }} | |
git push origin ${{ env.VERSION }} | |
- name: Notice when job fails | |
if: failure() | |
uses: 8398a7/[email protected] | |
with: | |
status: ${{job.status}} | |
fields: repo,workflow,job | |
author_name: Github Action Slack | |
pypi: | |
needs: tagging | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
token: ${{ secrets.PAT_TOKEN }} | |
- name: Set python | |
uses: actions/setup-python@v4 | |
with: | |
python-version: '3.8' | |
- name: Install dependencies | |
run: | | |
python -m pip install --upgrade pip | |
pip install setuptools wheel twine | |
- name: Make all and Packaging | |
run: | | |
cd src | |
python setup.py sdist bdist_wheel | |
- name: Publish a Python distribution to PyPI | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
with: | |
user: __token__ | |
password: ${{ secrets.PYPI_API_TOKEN }} | |
verbose: true | |
packages-dir: src/dist/ | |
- name: Notice when job fails | |
if: failure() | |
uses: 8398a7/[email protected] | |
with: | |
status: ${{job.status}} | |
fields: repo,workflow,job | |
author_name: Github Action Slack | |
docker: | |
needs: pypi | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
token: ${{ secrets.PAT_TOKEN }} | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Login to Docker Hub | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.CLOUDFORET_DEV_DOCKER_USERNAME }} | |
password: ${{ secrets.CLOUDFORET_DEV_DOCKER_PASSWORD }} | |
- name: Build and push to dockerhub | |
uses: docker/build-push-action@v4 | |
with: | |
context: . | |
platforms: ${{ env.ARCH }} | |
push: true | |
tags: cloudforet/${{ github.event.repository.name }}:${{ env.VERSION }} | |
build-args: | | |
PACKAGE_VERSION=${{ env.PACKAGE_VERSION }} | |
BRANCH_NAME=${{ env.BRANCH_NAME }} | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v2 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: us-east-1 | |
- name: Login to Amazon ECR | |
run: aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin ${{ secrets.ECR_REPO }} | |
- name: Build and push to ECR | |
uses: docker/build-push-action@v4 | |
with: | |
context: . | |
platforms: ${{ env.ARCH }} | |
push: true | |
tags: ${{ secrets.ECR_REPO }}/${{ github.event.repository.name }}:${{ env.VERSION }} | |
build-args: | | |
PACKAGE_VERSION=${{ env.PACKAGE_VERSION }} | |
BRANCH_NAME=${{ env.BRANCH_NAME }} | |
provenance: false | |
- name: Notice when job fails | |
if: failure() | |
uses: 8398a7/[email protected] | |
with: | |
status: ${{job.status}} | |
fields: repo,workflow,job | |
author_name: Github Action Slack | |
notification: | |
needs: docker | |
runs-on: ubuntu-latest | |
steps: | |
- name: Slack | |
if: always() | |
uses: 8398a7/[email protected] | |
with: | |
status: ${{job.status}} | |
fields: repo,message,commit,author,action,ref,workflow,job | |
author_name: Github Action Slack |