Skip to content

v0.2.17

v0.2.17 #14

Workflow file for this run

name: Release Build - Javelin Python
on:
release:
types:
- published
env:
env_var: ${{ vars.ENV_CONTEXT_VAR }}
DEVOPS_REPO: "javelin-cloud"
CHANGELOG_BR: main
PY_VER: 3.11.8
jobs:
javelin-prebuild:
permissions:
contents: 'read'
id-token: 'write'
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Setting up Repo Env
id: repo_env_setup
shell: bash
run: |-
echo "repository=$(basename ${{ github.repository }})" >> ${GITHUB_OUTPUT}
echo "shortsha=$(git rev-parse --short=7 HEAD)" >> ${GITHUB_OUTPUT}
- name: Set Lowercase Repo Name
id: lc_repository
env:
REPO_NAME: ${{ steps.repo_env_setup.outputs.repository }}
shell: bash
run: echo "name=${REPO_NAME,,}" >> ${GITHUB_OUTPUT}
- name: DevOps Repository Checkout
uses: actions/checkout@v4
with:
repository: "${{ github.repository_owner }}/${{ env.DEVOPS_REPO }}"
token: ${{ secrets.DEVOPS_GITHUB_TOKEN }}
fetch-depth: 0
persist-credentials: false
ref: main
path: ${{ env.DEVOPS_REPO }}
- name: Get Build Config
id: build_config
shell: bash
run: |-
chglog_pr_reviewers=$(cat ${{ env.DEVOPS_REPO }}/app-config/javelin-default/release-config.json | jq -r '.changelog.pr_reviewers')
echo "chglog_pr_reviewers=${chglog_pr_reviewers}" >> ${GITHUB_OUTPUT}
outputs:
short_sha: ${{ steps.repo_env_setup.outputs.shortsha }}
lc_repository: ${{ steps.lc_repository.outputs.name }}
chglog_pr_reviewers: ${{ steps.build_config.outputs.chglog_pr_reviewers }}
javelin-validate:
permissions:
contents: 'read'
id-token: 'write'
runs-on: ubuntu-latest
steps:
- name: Validate Release
env:
RELEASE_NAME: ${{ github.event.release.name }}
REGEX_PATTERN: "^v[0-9]+\\.[0-9]+\\.[0-9]+$"
shell: bash
run: |-
if [[ "${{ env.RELEASE_NAME }}" =~ ${{ env.REGEX_PATTERN }} ]]; then
echo "Valid version format: ${{ env.RELEASE_NAME }}"
else
echo "Invalid version format: ${{ env.RELEASE_NAME }}"
exit 1
fi
javelin-package:
needs:
- javelin-validate
permissions:
contents: 'read'
id-token: 'write'
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Setting up the Package Version
env:
PY_VER_FILE: "pyproject.toml"
RELEASE_NAME: ${{ github.event.release.name }}
shell: bash
run: |-
export RELEASE_VERSION=$(echo ${{ env.RELEASE_NAME }} | sed 's|^v||g')
if cat ${{ env.PY_VER_FILE }} | grep 'version = "RELEASE_VERSION"' ; then
sed -i "s|^version = \"RELEASE_VERSION\"|version = \"${RELEASE_VERSION}\"|g" ${{ env.PY_VER_FILE }}
cat ${file}
else
echo "Version entry format is wrong in the ${{ env.PY_VER_FILE }} file...!"
cat ${file}
exit 1
fi
- name: Set up Python Version
uses: actions/setup-python@v5
with:
python-version: ${{ env.PY_VER }}
cache: 'pip'
- name: Install Dependencies
shell: bash
run: |-
pip install build
- name: Build Package
shell: bash
run: |-
python -m build
- name: Publish Package
uses: pypa/[email protected]
# with:
# user: __token__
# password: ${{ secrets.PYPI_API_TOKEN }}
javelin-chglog:
needs:
- javelin-prebuild
- javelin-package
permissions:
contents: 'read'
id-token: 'write'
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ secrets.DEVOPS_GITHUB_TOKEN }}
persist-credentials: true
- name: Check chglog config
id: chglog_config
shell: bash
run: |
if test -d ".chglog" ; then
if test -f ".chglog/config.yml" ; then
echo "present=true" >> ${GITHUB_OUTPUT}
fi
fi
- name: Install git-chglog and generate CHANGELOG
if: ${{ steps.chglog_config.outputs.present == 'true' }}
shell: bash
run: |
curl -sLfO https://github.com/git-chglog/git-chglog/releases/download/v0.15.4/git-chglog_0.15.4_linux_amd64.tar.gz
tar -zxvf git-chglog_0.15.4_linux_amd64.tar.gz
chmod +x git-chglog
./git-chglog --config .chglog/config.yml --output CHANGELOG.md
- name: Create Pull Request
if: ${{ steps.chglog_config.outputs.present == 'true' }}
id: create_pr
uses: peter-evans/create-pull-request@v7
with:
token: ${{ secrets.DEVOPS_GITHUB_TOKEN }}
commit-message: 'devops: Update CHANGELOG for ${{ github.event.release.tag_name }}'
title: 'CHANGELOG for ${{ github.event.release.tag_name }}'
committer: GitHub Action <[email protected]>
author: GitHub Action <[email protected]>
body: >
This PR is auto-generated by
[release pipeline](${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }})
base: ${{ env.CHANGELOG_BR }}
branch: cicd-changelog
delete-branch: true
add-paths: CHANGELOG.md
reviewers: ${{ needs.javelin-prebuild.outputs.chglog_pr_reviewers }}
outputs:
pr_url: ${{ steps.create_pr.outputs.pull-request-url }}
pr_num: ${{ steps.create_pr.outputs.pull-request-number }}
javelin-package-notify:
needs:
- javelin-prebuild
- javelin-package
- javelin-chglog
permissions:
contents: 'read'
id-token: 'write'
runs-on: ubuntu-latest
if: always()
env:
CHGLOG_PR_URL: ${{ needs.javelin-chglog.outputs.pr_url }}
CHGLOG_PR_NUM: ${{ needs.javelin-chglog.outputs.pr_num }}
SVC_NAME: ${{ needs.javelin-prebuild.outputs.lc_repository }}
JOB_STATUS: ${{ needs.javelin-package.result }}
JOB_STATUS_FAIL_MARK: ":x:"
JOB_STATUS_SUCCESS_MARK: ":white_check_mark:"
TAG_NAME: ${{ github.event.release.tag_name }}
RELEASE_NAME: ${{ github.event.release.name }}
RELEASE_AUTHOR: ${{ github.event.release.author.login }}
PR_REVIEWERS: ${{ needs.javelin-prebuild.outputs.chglog_pr_reviewers }}
BUILD_URL: "${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"
SLACK_PAYLOAD_JSON: slack-package-payload.json
steps:
- name: DevOps Repository Checkout
uses: actions/checkout@v4
with:
repository: "${{ github.repository_owner }}/${{ env.DEVOPS_REPO }}"
token: ${{ secrets.DEVOPS_GITHUB_TOKEN }}
fetch-depth: 0
persist-credentials: true
ref: main
path: ${{ env.DEVOPS_REPO }}
- name: Slack Payload Template
shell: bash
run: |-
if [[ ${{ needs.javelin-package.result }} == "success" ]] ; then
export JOB_STATUS_MARK=${JOB_STATUS_SUCCESS_MARK}
else
export JOB_STATUS_MARK=${JOB_STATUS_FAIL_MARK}
fi
envsubst < ${{ env.DEVOPS_REPO }}/slack-notify/${{ env.SLACK_PAYLOAD_JSON }} > ${{ env.SLACK_PAYLOAD_JSON }}
cat ${{ env.SLACK_PAYLOAD_JSON }}
- name: Slack Notification
uses: slackapi/[email protected]
env:
SLACK_BOT_TOKEN: ${{ secrets.SLACK_BOT_TOKEN }}
with:
channel-id: "${{ vars.SLACK_CHANNEL_ID }}"
payload-file-path: "${{ env.SLACK_PAYLOAD_JSON }}"