From 4756458b44b2d70701ac622fdd4b023ae0584754 Mon Sep 17 00:00:00 2001 From: Bugs5382 Date: Sat, 2 Nov 2024 19:56:11 -0400 Subject: [PATCH] ci: updates --- .github/workflows/release-drafter.yaml | 144 ++++++++++++------------- .github/workflows/test.yaml | 1 + 2 files changed, 73 insertions(+), 72 deletions(-) diff --git a/.github/workflows/release-drafter.yaml b/.github/workflows/release-drafter.yaml index 46970d4..9b23ed9 100644 --- a/.github/workflows/release-drafter.yaml +++ b/.github/workflows/release-drafter.yaml @@ -3,86 +3,86 @@ on: workflow_dispatch: workflow_call: - jobs: - Next_Version: - runs-on: ubuntu-latest - outputs: - next_version: ${{ steps.get_version.outputs.next_version }} - steps: - - name: Checkout code - uses: actions/checkout@v4 +jobs: + Next_Version: + runs-on: ubuntu-latest + outputs: + next_version: ${{ steps.get_version.outputs.next_version }} + steps: + - name: Checkout code + uses: actions/checkout@v4 - - name: Set Up Git - run: | - git fetch --tags + - name: Set Up Git + run: | + git fetch --tags - - name: Get Current Version Tag - id: get_current_tag - run: | - # Find the latest tag in the current branch (main or develop) - latest_tag=$(git describe --tags $(git rev-list --tags --max-count=1)) - echo "latest_tag=${latest_tag}" >> $GITHUB_ENV + - name: Get Current Version Tag + id: get_current_tag + run: | + # Find the latest tag in the current branch (main or develop) + latest_tag=$(git describe --tags $(git rev-list --tags --max-count=1)) + echo "latest_tag=${latest_tag}" >> $GITHUB_ENV - - name: Determine Next Version - id: get_version - run: | - # Set initial version if no tag found - if [[ -z "$latest_tag" ]]; then - latest_tag="v0.0.0" - fi + - name: Determine Next Version + id: get_version + run: | + # Set initial version if no tag found + if [[ -z "$latest_tag" ]]; then + latest_tag="v0.0.0" + fi - # Extract the version parts - if [[ "$latest_tag" =~ ^v([0-9]+)\.([0-9]+)\.([0-9]+)(-beta\.[0-9]+)?$ ]]; then - major="${BASH_REMATCH[1]}" - minor="${BASH_REMATCH[2]}" - patch="${BASH_REMATCH[3]}" - beta="${BASH_REMATCH[4]}" - else - echo "Invalid tag format: $latest_tag" - exit 1 - fi + # Extract the version parts + if [[ "$latest_tag" =~ ^v([0-9]+)\.([0-9]+)\.([0-9]+)(-beta\.[0-9]+)?$ ]]; then + major="${BASH_REMATCH[1]}" + minor="${BASH_REMATCH[2]}" + patch="${BASH_REMATCH[3]}" + beta="${BASH_REMATCH[4]}" + else + echo "Invalid tag format: $latest_tag" + exit 1 + fi - # Increment the version based on the branch - if [[ "${GITHUB_REF_NAME}" == "main" ]]; then - next_version="v$major.$((minor + 1)).0" # Full release, reset beta + # Increment the version based on the branch + if [[ "${GITHUB_REF_NAME}" == "main" ]]; then + next_version="v$major.$((minor + 1)).0" # Full release, reset beta + else + if [[ -z "$beta" ]]; then + next_version="v$major.$minor.$patch-beta.1" # Start beta versioning else - if [[ -z "$beta" ]]; then - next_version="v$major.$minor.$patch-beta.1" # Start beta versioning - else - # Increment beta version - beta_number="${beta#*-beta.}" - next_version="v$major.$minor.$patch-beta.$((beta_number + 1))" - fi + # Increment beta version + beta_number="${beta#*-beta.}" + next_version="v$major.$minor.$patch-beta.$((beta_number + 1))" fi + fi - echo "next_version=${next_version}" >> $GITHUB_ENV - echo "::set-output name=next_version::${next_version}" + echo "next_version=${next_version}" >> $GITHUB_ENV + echo "::set-output name=next_version::${next_version}" - Create: - runs-on: ubuntu-latest - needs: Next_Version - steps: - - name: Checkout code - uses: actions/checkout@v4 + Create: + runs-on: ubuntu-latest + needs: Next_Version + steps: + - name: Checkout code + uses: actions/checkout@v4 - - name: Draft Release (Develop) - if: github.event.pull_request.base.ref == 'develop' - uses: release-drafter/release-drafter@v6 - with: - name: "${{ needs.compute-version.outputs.next_version }}" - tag: "${{ needs.compute-version.outputs.next_version }}" - prerelease: true - commitish: develop - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Draft Release (Develop) + if: github.event.pull_request.base.ref == 'develop' + uses: release-drafter/release-drafter@v6 + with: + name: "${{ needs.compute-version.outputs.next_version }}" + tag: "${{ needs.compute-version.outputs.next_version }}" + prerelease: true + commitish: develop + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - name: Draft Release - if: github.event.pull_request.base.ref != 'develop' - uses: release-drafter/release-drafter@v6 - with: - name: "${{ needs.compute-version.outputs.next_version }}" - tag: "${{ needs.compute-version.outputs.next_version }}" - prerelease: false - commitish: main - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} \ No newline at end of file + - name: Draft Release + if: github.event.pull_request.base.ref != 'develop' + uses: release-drafter/release-drafter@v6 + with: + name: "${{ needs.compute-version.outputs.next_version }}" + tag: "${{ needs.compute-version.outputs.next_version }}" + prerelease: false + commitish: main + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} \ No newline at end of file diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index ece3539..0b7404b 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -11,6 +11,7 @@ on: - synchronize jobs: + Build: runs-on: ubuntu-latest strategy: