Skip to content

COMMIT STAGE - Demonstrators build #186

COMMIT STAGE - Demonstrators build

COMMIT STAGE - Demonstrators build #186

# Main COMMIT STAGE workflow regarding the Official Techstack version managed via Maven tool
name: Techstack Official Version CI (COMMIT STAGE)
run-name: COMMIT STAGE - Demonstrators build
on:
push:
# execution when development pom codes commit is pushed by a demonstrator developer
branches:
- 'feature*'
- 'hotfix*'
- 'fix*'
# execute only when changes detected on pom.xml files
# becarefull, path filters are not evaluated on tags
paths:
- 'demonstrators-line/demonstrator-v*/pom.xml'
- '.github/workflows/techstack-demonstrator-ci.yml'
- '.github/workflows/publish-version-to-repository.yml'
# execute when a alpha tag is added on the feature branch as "finished work" (e.g by techstack implementation developer)
tags:
- '[0-9]+.[0-9]+.[0-9]+-*'
- '*-reviewed'
- 'reviewed*'
- '*-alpha'
- '[0-9]+.[0-9]+.[0-9]+'
pull_request:
# execution when pull request is requested by a developer (e.g to reviewer)
types: [opened, reopened, review_requested]
branches:
- 'feature*'
- 'hotfix*'
- 'fix*'
# execute only when reviewed files or demonstrator sub-projects
paths:
- 'demonstrators-line/demonstrator-v*/pom.xml'
pull_request_target:
# when a pull request merges, the pull request is automatically closed (so check the merged state)
types: [closed]
# execution when feature's artifacts (e.g implementation doc, maven pom.xml) were reviewed
branches:
- 'feature*'
- 'hotfix*'
- 'fix*'
# execute only when reviewed files
paths:
- 'demonstrators-line/pom.xml'
- 'demonstrators-line/demonstrator-v*/pom.xml'
# The commit stage workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
define_project_release_name:
name: Release name preparation
runs-on: ubuntu-latest
permissions:
contents: read
outputs:
release_name: ${{ env.release_name }}
is_snapshot: ${{ env.is_snapshot }}
steps:
- name: Check existing project defined version name
if: ${{ github.event.release.tag_name != '' }}
# Read the release name defined into the GitHub project
run: |
echo The current demonstration line release tag is ${{ github.event.release.tag_name }}
echo "TAG_VERSION=${{ github.event.release.tag_name }}" >> $GITHUB_ENV
echo "is_snapshot=${{ contains(github.event.release.tag_name, 'snapshot') || contains(github.event.release.tag_name, 'reviewed') }}" >> $GITHUB_ENV
# Build specific release name because none tag is existing on GitHub project
- name: Define reusable environment variables about current commit
if: ${{ env.TAG_VERSION == '' }}
uses: FranzDiebold/[email protected]
# Only tagged version based on x.y.z format are published on remote releases repository
- name: Check the demonstration line tag pattern (x.z.y) identifying a final release
if: ${{ env.TAG_VERSION == '' }}
run: |
if [[ ${{ github.event.ref }} =~ ^refs/tags/[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
echo "TAG_VERSION=${{ github.ref_name }}" >> $GITHUB_ENV
echo "is_snapshot=false" >> $GITHUB_ENV
else
echo "is_snapshot=true" >> $GITHUB_ENV
fi
- name: Set the identified release name of the demonstrators line from tag
if: ${{ env.TAG_VERSION != '' }}
run: |
echo "Define the final version identifier from the current tag name"
echo "release_name=$TAG_VERSION" >> $GITHUB_ENV
echo "Version type is detected as is_snapshot=${{ env.is_snapshot }}"
- name: Define an unique revision name (pattern <<feature branch name>>.<<commit id abbrev>>) regarding development alpha
if: ${{ env.TAG_VERSION == '' }}
run: |
echo "Git commit revision $CI_SHA_SHORT abbreviation based on 7 characters (default) maximum (origin based: $CI_SHA)"
echo "COMMIT_ID=$CI_SHA_SHORT" >> $GITHUB_ENV
echo "FEATURE_NAME=$CI_ACTION_REF_NAME_SLUG" >> $GITHUB_ENV
echo "is_snapshot=true" >> $GITHUB_ENV
echo "Development version type is defined as snapshot based on $CI_SHA_SHORT commit revision number"
- name: Set a snapshot feature name based on unique commit id
# Build final name about featureX name, but avoiding COMMIT_ID and SNAPSHOT suffix
if: ${{ env.TAG_VERSION == '' && ( !contains(env.FEATURE_NAME, 'alpha') && !contains(env.FEATURE_NAME, 'reviewed') ) }}
# Build unique name including commit_id suffix based
# Example of output name: feature-133.9efbb506-SNAPSHOT
run: echo "release_name=$FEATURE_NAME.$COMMIT_ID-SNAPSHOT" >> $GITHUB_ENV
- name: Set a snapshot reviewed version name of the demonstration line based on CYBNITY versioning strategy
# Build final name about any tag named branch (maybe don't include feature name including -reviewed or -release)
if: ${{ env.TAG_VERSION == '' && env.release_name == '' }}
# Build name based on a potential included tag (e.g 0.0.7-reviewed, 0.0.7-release, 0.0.7) without commit_id suffix
# Example of output name 0.0.7-reviewed-SNAPSHOT, feature133-release-SNAPSHOT
# THE NAMING IMPACT ONLY THE DEMONSTRATION LINE (not the demonstrators which managed themselve their statically defined pom.xml versions)
run: echo "release_name=$FEATURE_NAME-SNAPSHOT" >> $GITHUB_ENV
demonstrators_line_build:
name: Demonstrators build
if: success() && github.event_name == 'push'
needs: [define_project_release_name]
runs-on: ubuntu-latest
permissions:
contents: read
env:
RELEASE_NAME: ${{ needs.define_project_release_name.outputs.release_name }}
MAVEN_USERNAME: ${{ secrets.AGNET_REPO_USERNAME }}
MAVEN_PASSWORD: ${{ secrets.AGNET_REPO_PASSWORD }}
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_GPG_PASSPHRASE }}
GITHUB_TOKEN: ${{ github.token }} # GITHUB_TOKEN is the default env for the password
outputs:
release_name: ${{ env.RELEASE_NAME }}
steps:
- name: Checkout source codes from branch
id: checkout_step
uses: actions/checkout@v3
with:
repository: ${{ github.repository }}
token: ${{ github.token }}
ref: ${{ inputs.branch_name }}
- name: Set up java runtime (Temurin JDK)
uses: actions/setup-java@v4
with:
java-version: '11'
distribution: 'temurin'
cache: maven
server-id: agnet # Value of the distributionManagement/repository/id filed of the pom.xml
server-username: MAVEN_USERNAME
server-password: MAVEN_PASSWORD
gpg-private-key: ${{ secrets.MAVEN_GPG_PRIVATE_KEY }} # Value (without an modification than exported by the gpg --export-secret-keys command) of the GPG private key (33105BFD367D25B3) to import
gpg-passphrase: MAVEN_GPG_PASSPHRASE # env variable for GPG private key passphrase
- name: Install gpg secret key used for artefacts signing
run: |
# Install gpg secret key
cat <(echo -e "${{ secrets.MAVEN_GPG_PRIVATE_KEY }}") | gpg --batch --import
# Verify gpg secret key
gpg --list-secret-keys --keyid-format LONG
- name: Build techstack official demonstrators in their distributable formats (e.g Maven pom.xml)
run: |
cd demonstrators-line
echo "Set the demonstrators line version"
mvn -B -DgenerateBackupPoms=true -DprocessAllModules=true versions:set -DnewVersion=${{ env.RELEASE_NAME }}
mvn --batch-mode --update-snapshots --show-version -Drevision=${{ env.RELEASE_NAME }} --fail-fast --file pom.xml clean install -Dmaven.test.skip=true
# Prepare a release for remote repository installation (published in place of old equals release name in remote repository, reviewed or not)
# Publish release of Maven pom.xml (reusable by other development) that potentially replace previous equals version named
# All demonstrator are always published on release repository only because they are statically versioned
publish_version_to_release_remote_repository:
name: Techstack releases publishing
if: ${{ success() && needs.define_project_release_name.outputs.is_snapshot == 'false' }}
needs: [define_project_release_name, demonstrators_line_build]
uses: ./.github/workflows/publish-version-to-repository.yml
with:
config-path: ${{ needs.demonstrators_line_build.steps.checkout_step.ref }}
target_repository: RELEASE
package_release_name: ${{ needs.demonstrators_line_build.outputs.release_name }}
pom-base-path: 'demonstrators-line/'
secrets: inherit