Javascript Wrapper Release #1
Workflow file for this run
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Javascript Wrapper Release | |
on: | |
workflow_call: | |
inputs: | |
cliTag: | |
description: 'CLI tag name' | |
required: false | |
type: string | |
default: 2.0.0-nightly | |
jsTag: | |
description: 'JS Wrapper tag name' | |
required: false | |
type: string | |
default: nightly | |
dev: | |
description: 'Is dev build' | |
required: false | |
default: true | |
type: boolean | |
workflow_dispatch: | |
inputs: | |
cliTag: | |
description: 'CLI tag name (ignored if not dev build)' | |
required: false | |
jsTag: | |
description: 'Tag name (ignored if not dev build)' | |
required: false | |
type: string | |
default: rc | |
dev: | |
description: 'Is dev build' | |
required: false | |
default: true | |
type: boolean | |
permissions: | |
id-token: write | |
contents: write | |
packages: write | |
jobs: | |
delete: | |
uses: CheckmarxDev/ast-cli-javascript-wrapper-runtime-cli/.github/workflows/delete-packages-and-releases.yml@main | |
with: | |
tag: ${{ inputs.jsTag }} | |
secrets: inherit | |
if: inputs.dev == true | |
release: | |
runs-on: ubuntu-latest | |
env: | |
GITHUB_TOKEN: ${{ secrets.OR_GITHUB_TOKEN }} | |
BRANCH_NAME: npm-version-patch | |
steps: | |
# CHECKOUT PROJECT | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
# GIT CONFIGURATION | |
- run: | | |
git config user.name github-actions | |
git config user.email [email protected] | |
# SETUP NODE | |
- uses: actions/[email protected] | |
with: | |
node-version: 14 | |
registry-url: https://npm.pkg.github.com/ | |
# GET TAG NAME | |
- name: Generate Tag name | |
run: | | |
if [ ${{ inputs.dev }} == true ]; then | |
echo "TAG_NAME=$(npm version prerelease --preid=${{ inputs.jsTag }} --no-git-tag-version --allow-same-version)" >> $GITHUB_ENV | |
else | |
echo "TAG_NAME=$(npm version patch --no-git-tag-version)" >> $GITHUB_ENV | |
fi | |
# RUN NPM INSTALL AND BUILD | |
- name: NPM ci and build | |
run: | | |
npm ci | |
npm run build | |
# CREATE PR FOR VERSION | |
- name: Create Pull Request | |
id: create_pr | |
if: inputs.dev == false | |
uses: peter-evans/create-pull-request@c5a7806660adbe173f04e3e038b0ccdcd758773c #v6.1.0 | |
with: | |
token: ${{ env.GITHUB_TOKEN }} | |
branch: ${{ env.BRANCH_NAME }} | |
title: "Update Version - Automated Changes" | |
body: "This is an automated PR created by GitHub Actions" | |
base: main | |
draft: false | |
# WAIT FOR PR CREATION | |
- name: Wait for PR to be created | |
id: pr | |
if: inputs.dev == false | |
uses: octokit/request-action@872c5c97b3c85c23516a572f02b31401ef82415d #v2.3.1 | |
with: | |
route: GET /repos/${{ github.repository }}/pulls?head=${{ github.repository_owner }}:${{ env.BRANCH_NAME }} | |
# MERGE PR TO MAIN | |
- name: Merge Pull Request | |
if: inputs.dev == false | |
uses: octokit/request-action@872c5c97b3c85c23516a572f02b31401ef82415d #v2.3.1 | |
with: | |
route: PUT /repos/${{ github.repository }}/pulls/${{ steps.create_pr.outputs.pull-request-number }}/merge | |
merge_method: squash | |
# PUSH TAGS IF IT IS A RELEASE | |
- name: Push tag | |
if: inputs.dev == false | |
run: | | |
git pull | |
git tag ${{env.TAG_NAME}} | |
git push --tags | |
# PUBLISH NPM PACKAGE | |
- name: Publish npm package | |
run: | | |
if [ ${{ inputs.dev }} == true ]; then | |
npm publish --tag=${{ inputs.jsTag }} | |
else | |
npm publish --access public | |
fi | |
env: | |
NODE_AUTH_TOKEN: ${{secrets.PERSONAL_ACCESS_TOKEN}} | |
# CREATE RELEASE | |
- name: Create Release | |
uses: softprops/action-gh-release@a74c6b72af54cfa997e81df42d94703d6313a2d0 #v2 | |
with: | |
name: ${{env.TAG_NAME}} | |
tag_name: ${{env.TAG_NAME}} | |
generate_release_notes: true | |
prerelease: ${{ inputs.dev }} |