Skip to content

Merge branch 'main' into next-major #295

Merge branch 'main' into next-major

Merge branch 'main' into next-major #295

---
#------------------------------------------------------------------------------
# Lawrence McDaniel - https://lawrencemcdaniel.com
# Version Bump Workflow for Python package openai_utils
#
# Calculate the version of the 'next' branch based on semantic-release rules.
# Compares the existing value of __version__.py to the calculated value.
# If they are different, it will update __version__.py and push the changes
# to the main branch.
#------------------------------------------------------------------------------
name: Semantic Version Bump (next)
on:
workflow_dispatch:
push:
branches:
- alpha
- beta
- next
- next-major
jobs:
bump-version-next:
runs-on: ubuntu-latest
env:
VERSION_FILE: __version__.py
PACKAGE_PATH: ${{ github.workspace }}/app/
steps:
- uses: actions/checkout@v4
with:
persist-credentials: false
- name: Cache NPM dependencies
uses: actions/cache@v4
with:
path: ~/.npm
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node
- name: Set up Python 3.11
uses: actions/setup-python@v5
with:
python-version: "3.11"
- name: Setup Node.js environment
uses: actions/setup-node@v4
with:
node-version: "20.9.0"
- name: Install npm dev dependencies
run: npm install
- name: Get current version
# step 1
# the current version persisted to __version__.py
id: current_version
run: |
cd ${{ env.PACKAGE_PATH }}
echo "CURRENT_VERSION=$(python -c 'from __version__ import __version__; print(__version__)')" >> $GITHUB_ENV
env:
GITHUB_TOKEN: ${{ secrets.PAT }}
- name: null step
id: null_step1
run: echo "i ensure that CURRENT_VERSION is set."
- name: Get next version
# step 2
# calculate the next version based on semantic-release rules
# this will return a null string is there in fact is no version bump.
# so set NEXT_VERSION to CURRENT_VERSION if there is no version bump.
id: next_version
run: |
NEXT_VERSION=$(npx semantic-release --dry-run --no-ci | awk '/The next release version is/{print $NF}')
echo "NEXT_VERSION=${NEXT_VERSION:-${{ env.CURRENT_VERSION }}}" >> $GITHUB_ENV
env:
GITHUB_TOKEN: ${{ secrets.PAT }}
CURRENT_VERSION: ${{ env.CURRENT_VERSION }}
- name: null step
id: null_step2
run: echo "i ensure that NEXT_VERSION is set."
- name: Check versions
# step 3
# compare the current version to the next version.
# if they are different, set VERSION_CHANGED to true
id: check_versions
run: |
if [ "$CURRENT_VERSION" != "$NEXT_VERSION" ]; then
echo "VERSION_CHANGED=true" >> $GITHUB_ENV
else
echo "VERSION_CHANGED=false" >> $GITHUB_ENV
fi
env:
CURRENT_VERSION: ${{ env.CURRENT_VERSION }}
NEXT_VERSION: ${{ env.NEXT_VERSION }}
- name: another null step
id: null_step3
run: echo "i ensure that CURRENT_VERSION, NEXT_VERSION and VERSION_CHANGED are set."
- name: Update __version__.py
# step 4
# if VERSION_CHANGED is true, update __version__.py and push the changes to the
# branch that triggered this workflow.
if: env.VERSION_CHANGED == 'true'
id: update_version
run: |
echo "# -*- coding: utf-8 -*-" > ${{ env.VERSION_FILE }}
echo "# DO NOT EDIT." >> ${{ env.VERSION_FILE }}
echo "# Managed via automated CI/CD in .github/workflows/semanticVersionBump.yml." >> ${{ env.VERSION_FILE }}
echo "__version__ = \"${{ env.NEXT_VERSION }}\"" >> ${{ env.VERSION_FILE }}
git config --local user.email "[email protected]"
git config --local user.name "GitHub Action"
git add ${{ env.VERSION_FILE }}
git commit -m "chore: [gh] Update __version__.py to ${{ env.NEXT_VERSION }} [skip ci]"
git push https://${{ secrets.PAT }}@github.com/${{ github.repository }}.git HEAD:${{ github.ref }}
env:
VERSION_FILE: ${{ env.PACKAGE_PATH }}${{ env.VERSION_FILE }}
GITHUB_TOKEN: ${{ secrets.PAT }}
NEXT_VERSION: ${{ env.NEXT_VERSION }}
VERSION_CHANGED: ${{ env.VERSION_CHANGED }}