Skip to content

Add seperate check for valid version #44

Add seperate check for valid version

Add seperate check for valid version #44

Workflow file for this run

name: Test & Deploy
on:
push:
pull_request:
defaults:
run:
shell: bash
env:
# regexr.com/7mmq7
TAG_REGEX: '^v(0|[1-9][0-9]*)(\.(0|[1-9][0-9]*))((a|b|rc)(0|[1-9][0-9]*))?(\.(dev|post)(0|[1-9][0-9]*))?$'
DEV_TAG_REGEX: '\.(dev|post)(0|[1-9][0-9]*)$'
jobs:
test:
name: Python ${{ matrix.python-version }} (${{ matrix.os }})
runs-on: ${{ matrix.os }}
continue-on-error: ${{ matrix.python-version == '3.13.0-alpha.1' }}
strategy:
matrix:
os: [ubuntu-latest] #, macos-latest, windows-latest, macos-13]
python-version: ["3.12"] #, "3.10", "3.11"]
# include:
# - os: macos-13
# python-version: "3.13.0-alpha.1"
steps:
- name: Checkout repo
uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Display Python version (${{ matrix.python-version }})
run: python -c "import sys; print(sys.version)"
# Skip for Windows; path setting there isn't worth the trouble
- name: Run eyeball checks
if: runner.os != 'Windows'
run: |
pip install termcolor
PYTHONPATH=. python tests/eyeball.py
- name: Test with pytest
run: |
pip install pytest
pytest tests/ --maxfail=3 --showlocals --color=yes -v
validate_version:
name: Validate Version
runs-on: ubuntu-latest
needs: test
outputs:
PACKAGE_VERSION: ${{ steps.get_version.outputs.PACKAGE_VERSION }}
PACKAGE_VALID: ${{ steps.get_version.outputs.PACKAGE_VALID }}
steps:
- name: Checkout repo
uses: actions/checkout@v4
- name: Set up Python (3.12)
uses: actions/setup-python@v4
with:
python-version: 3.12
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Validate package version
id: get_version
run: |
# python -c "import automata; print(automata.__version__)"
echo "PACKAGE_VERSION=$(python -c 'import automata; print(automata.__version__)')" >> $GITHUB_OUTPUT
echo "Package version: $PACKAGE_VERSION"
# Check if the tag name matches the version pattern
if [[ "${PACKAGE_VERSION}" =~ v${TAG_REGEX} ]]; then PACKAGE_VALID="true"; else PACKAGE_VALID="false"; fi
echo "PACKAGE_VALID=$PACKAGE_VALID" >> $GITHUB_OUTPUT
if [[ $PACKAGE_VALID == "true" ]]; then
echo "Valid package version"
else
echo "Invalid package version"
# exit 1 # Tests fail if the package version is invalid
fi
validate_tag:
name: Validate Tag
runs-on: ubuntu-latest
needs: validate_version
if: >-
needs.validate_version.outputs.PACKAGE_VALID == 'true'
outputs:
IS_TAG: ${{ steps.validate.outputs.IS_TAG }}
TAG_VALID: ${{ steps.validate.outputs.TAG_VALID }}
TAG_IS_DEV: ${{ steps.validate.outputs.TAG_IS_DEV }}
TAG_VERSION_MATCH: ${{ steps.validate.outputs.TAG_VERSION_MATCH }}
steps:
- name: Checkout repo
uses: actions/checkout@v4
# - name: Set up Python (3.12)
# uses: actions/setup-python@v4
# with:
# python-version: 3.12
#
# - name: Install dependencies
# run: |
# python -m pip install --upgrade pip #
# pip install -r requirements.txt
- name: Validate version tag
id: validate
run: |
TAG_REGEX="${{ env.TAG_REGEX }}"
DEV_TAG_REGEX="${{ env.DEV_TAG_REGEX }}"
TAG_NAME=${GITHUB_REF#refs/tags/}
PACKAGE_VERSION=${{ needs.validate_version.outputs.PACKAGE_VERSION }}
if [[ "${TAG_NAME}" =~ "refs/tags/" ]]; then IS_TAG="true"; else IS_TAG="false"; fi
echo "IS_TAG=IS_TAG" >> $GITHUB_OUTPUT
if [[ TAG_NAME == "true" ]]; then
echo "Tag: $TAG_NAME"
else
echo "Not a tag: $TAG_NAME"
fi
# Check if the tag name matches the version pattern
if [[ "${TAG_NAME}" =~ ${TAG_REGEX} ]]; then TAG_VALID="true"; else TAG_VALID="false"; fi
echo "TAG_VALID=$TAG_VALID" >> $GITHUB_OUTPUT
if [[ $TAG_VALID == "true" ]]; then
echo "Valid version tag"
else
echo "Invalid (remember the v) or missing version tag"
fi
# Check if the tag name matches the dev version pattern
if [[ "${TAG_NAME}" =~ ${DEV_TAG_REGEX} ]]; then TAG_IS_DEV="true"; else TAG_IS_DEV="false"; fi
echo "TAG_IS_DEV=$TAG_IS_DEV" >> $GITHUB_OUTPUT
if [[ $TAG_IS_DEV == "true" ]]; then
echo "Development version tag"
else
echo "Release or invalid (remember the v) version tag"
fi
if [[ ${TAG_NAME#v} == $PACKAGE_VERSION ]]; then TAG_VERSION_MATCH="true"; else TAG_VERSION_MATCH="false"; fi
echo "TAG_VERSION_MATCH=$TAG_VERSION_MATCH" >> $GITHUB_OUTPUT
if [[ $TAG_VERSION_MATCH == "true" ]]; then
echo "Version in tag matches package version: $PACKAGE_VERSION != ${TAG_NAME#v}"
else
echo "Version in tag does not match package version: $PACKAGE_VERSION != ${TAG_NAME#v}"
fi
publish:
name: Build and Publish
needs: validate_tag
runs-on: ubuntu-latest
environment: deployment
# if: needs.validate_tag.outputs.TAG_VALID == 'true'
if: >-
needs.validate_tag.outputs.IS_TAG == 'true' &&
needs.validate_tag.outputs.TAG_VALID == 'true' &&
needs.validate_tag.outputs.TAG_VERSION_MATCH == 'true' &&
github.event_name == 'push'
permissions:
id-token: write # Mandatory for trusted publishing
steps:
- name: DEBUG Check inputs
run: |
IS_TAG=${{ needs.validate_tag.outputs.IS_TAG }}
TEST_TAG_VALID=${{ needs.validate_tag.outputs.TAG_VALID }}
TEST_TAG_VERSION_MATCH=${{ needs.validate_tag.outputs.TAG_VERSION_MATCH }}
TAG_IS_DEV=${{ needs.validate_tag.outputs.TAG_IS_DEV }}
echo "IS_TAG: IS_TAG"
echo "TEST_TAG_VALID: $TEST_TAG_VALID"
echo "TEST_TAG_VERSION_MATCH: $TEST_TAG_VERSION_MATCH"
echo "TAG_IS_DEV: $TAG_IS_DEV"
- name: Checkout repo
uses: actions/checkout@v4
- name: Set up Python (3.12)
uses: actions/setup-python@v4
with:
python-version: 3.12
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Determine PyPI repository URL
id: pypi_repository
run: |
TAG_IS_DEV=${{ needs.validate_tag.outputs.TAG_IS_DEV }}
if [[ "${TAG_IS_DEV}" == 'true' ]]; then
echo "Will publish to test PyPI..."
echo "REPOSITORY_LEVEL=Test" >> $GITHUB_OUTPUT
echo "REPOSITORY_URL=https://test.pypi.org/legacy/" >> $GITHUB_OUTPUT
else
echo "Will publish to production PyPI..."
echo "REPOSITORY_LEVEL=Production" >> $GITHUB_OUTPUT
echo "REPOSITORY_URL=https://upload.pypi.org/legacy/" >> $GITHUB_OUTPUT
fi
# - name: Install Flit
# run: |
# python -m pip install --upgrade pip
# python -m pip install flit #
# flit --version
#
# - name: Build the package
# run: flit build --no-use-vcs
#
# - name: Publish to PyPI (${{ steps.pypi_repository.outputs.REPOSITORY_LEVEL }})
# uses: pypa/gh-action-pypi-publish@release/v1
# with:
# repository-url: ${{ steps.pypi_repository.outputs.REPOSITORY_URL }}
# TAG_REGEX='^v(0|[1-9]\d*)\.(0|[1-9]\d*)(?:\.(0|[1-9]\d+))?((?:[ab]|rc)(0|[1-9]\d*))?(?:\.(?:dev|post)(0|[1-9]\d*))?$'
# DEV_TAG_REGEX='\.(dev|post)(0|[1-9]\d*)$'
# [[ $TAG_NAME =~ $DEV_TAG_REGEX ]] && TAG_IS_DEV="true" || TAG_IS_DEV="false"
# - name: Get package version
# id: package_version
# run: |
# PACKAGE_VERSION=$(python -c "from automata import __version__; print(__version__)")
# echo "PACKAGE_VERSION=$PACKAGE_VERSION" >> $GITHUB_OUTPUT
# - name: Determine PyPI repository URL
# id: pypi_repository
# run: |
# TAG_NAME=${GITHUB_REF#refs/tags/}
# VERSION_REGEX='^v([0-9]+(\.[0-9]+){1,2}((a|b|rc)[0-9]+)?)$'
# PACKAGE_VERSION=${{ steps.package_version.outputs.PACKAGE_VERSION }}
#
# echo "GITHUB_REF: $GITHUB_REF"
# echo "TAG_NAME: $TAG_NAME"
# echo "PACKAGE_VERSION $PACKAGE_VERSION"
#
# if [[ "${TAG_NAME}" =~ ${VERSION_REGEX} ]]; then
# echo "Tag matches version regex: T"
# else
# echo "Tag matches version regex: F"
# fi
# if [[ "v${PACKAGE_VERSION}" =~ ${VERSION_REGEX} ]]; then
# echo "Package version matches version regex: T"
# else
# echo "Package version matches version regex: F"
# fi
# if [[ "v${PACKAGE_VERSION}" == "${TAG_NAME}" ]]; then
# echo "Tag matches the package version: T"
# else
# echo "Tag matches the package version: F"
# fi
#
# if [[ "v${PACKAGE_VERSION}" =~ ${VERSION_REGEX} && "v${PACKAGE_VERSION}" == "${TAG_NAME}" ]]; then
# echo "Will publish to production PyPI..."
# echo "REPOSITORY_LEVEL=Production" >> $GITHUB_OUTPUT
# echo "REPOSITORY_URL=https://upload.pypi.org/legacy/" >> $GITHUB_OUTPUT
# else
# echo "Will publish to test PyPI..."
# echo "REPOSITORY_LEVEL=Test" >> $GITHUB_OUTPUT
# echo "REPOSITORY_URL=https://test.pypi.org/legacy/" >> $GITHUB_OUTPUT
# fi
# - name: Notify - Completion
# uses: tsickert/[email protected]
# with:
# webhook-url: ${{ secrets.DISCORD_CODING_WEBHOOK_URL }}
# content: "${{ github.repository }} - [${{ github.actor }}] ${{ github.workflow }} - ended\n<@${{ secrets.DISCORD_USER_ID }}>"
# - name: Notify - Start
# uses: tsickert/[email protected]
# with:
# webhook-url: ${{ secrets.DISCORD_CODING_WEBHOOK_URL }}
# content: "[${{ github.repository }}] (${{ github.actor }}) ${{ github.workflow }} - started"
# if: >-
# github.event_name == 'push' &&
# github.actor == 'orome' &&
# (
# startsWith(github.ref, 'refs/tags/v') ||
# contains(fromJson('["master", "main", "develop"]'), github.ref_name)
# )
# TAG_REGEX='^v(\d+\.\d+(?:\.\d+)?)([ab]|rc)?\d*(\.dev|\.post)?\d*$'
# TAG_REGEX='^v([0-9]+(\.[0-9]+){1,2}((a|b|rc)[0-9]+)?)$'
# if [[ $TAG_NAME =~ $TAG_REGEX ]]; then
# echo "Valid version tag: $TAG_NAME"
# echo "TAG_VALID=true" >> $GITHUB_OUTPUT
# else
# echo "Invalid version tag: $TAG_NAME"
# echo "TAG_VALID=false" >> $GITHUB_OUTPUT
# fi