Skip to content

Merge pull request #204 from ministryofjustice/auto/update-npm-deps #301

Merge pull request #204 from ministryofjustice/auto/update-npm-deps

Merge pull request #204 from ministryofjustice/auto/update-npm-deps #301

Workflow file for this run

name: Release
on:
workflow_dispatch:
push:
branches:
- main
env:
GITHUB_USERNAME: "bichard7"
GITHUB_EMAIL: "[email protected]"
jobs:
bump-package-version:
name: Bump package version
runs-on: ubuntu-latest
outputs:
version: ${{ steps.bump.outputs.version }}
steps:
- name: Checkout
uses: actions/checkout@v3
with:
token: ${{ secrets.GH_ACCESS_TOKEN }}
persist-credentials: true
- name: Setup Node.js
uses: actions/setup-node@v2
with:
node-version: "16.19.1"
- name: Bump output package version (and capture it)
id: bump
run: echo "::set-output name=version::$(npm version patch | tr -d 'v')"
working-directory: output-data
- name: Check new version
run: echo "${{ steps.bump.outputs.version }}"
- name: Update pom.xml with new version number
run: envsubst '$PACKAGE_JSON_VERSION' < pom.template.xml > pom.xml
env:
PACKAGE_JSON_VERSION: ${{ steps.bump.outputs.version }}
- name: Commit output package version bump
run: |
git config user.name ${{ env.GITHUB_USERNAME }}
git config user.email ${{ env.GITHUB_EMAIL }}
git add output-data/package*.json pom.xml
git commit -m "Bump package version [skip actions]"
git tag v${{ steps.bump.outputs.version }}
- name: Push new commit and tag
run: git push --follow-tags
release-npm-package:
name: Release NPM package
needs: bump-package-version
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
with:
# We need to specify the branch name, so that we get the updated package.json
# If we don't specify this, the default is to fetch the commit that triggered
# the workflow (which won't include the updated package.json)
ref: ${{ github.ref_name }}
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: "16.19.1"
- name: Install top-level NPM dependencies
run: npm ci
- name: Generate triggers.properties files
run: npm run generate-trigger-config
- name: Install output package NPM dependencies
run: npm ci
working-directory: output-data
- name: Build output package
working-directory: output-data
run: npm run build
- name: Publish output package
run: npm publish
working-directory: output-data
env:
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
release-maven-package:
name: Release Maven package
needs: bump-package-version
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
with:
# We need to specify the branch name, so that we get the updated package.json
# If we don't specify this, the default is to fetch the commit that triggered
# the workflow (which won't include the updated package.json)
ref: ${{ github.ref_name }}
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: "16.19.1"
- name: Install top-level NPM dependencies
run: npm ci
- name: Generate triggers.properties files
run: npm run generate-trigger-config
- name: Setup Java and Maven
uses: actions/setup-java@v1
with:
java-version: 17
server-id: ossrh
server-username: MAVEN_USERNAME
server-password: MAVEN_PASSWORD
- name: Install gpg secret key
run: |
cat <(echo -e "${{ secrets.OSSRH_GPG_SECRET_KEY }}") | gpg --batch --import
gpg --list-secret-keys --keyid-format LONG
- name: Package the data with maven
run: mvn package --no-transfer-progress
- name: Publish maven package
run: mvn deploy
env:
MAVEN_USERNAME: ${{ secrets.SONATYPE_USERNAME }}
MAVEN_PASSWORD: ${{ secrets.SONATYPE_PASSWORD }}
update-core-repo:
name: Update NPM package in core repo
needs:
- bump-package-version
- release-npm-package
runs-on: ubuntu-latest
steps:
- name: Check out core repo
uses: actions/checkout@v3
with:
repository: ministryofjustice/bichard7-next-core
token: ${{ secrets.GH_ACCESS_TOKEN }}
- name: Update standing data npm package
run: >
npm install
bichard7-next-data-latest@npm:@moj-bichard7-developers/bichard7-next-data@${VERSION}
env:
VERSION: ${{ needs.bump-package-version.outputs.version }}
- name: Create pull request
id: cpr
uses: peter-evans/create-pull-request@v4
with:
branch: auto/update-standing-data
delete-branch: true
token: ${{ secrets.GH_ACCESS_TOKEN }}
committer: ${{ env.GITHUB_USERNAME }} <${{ env.GITHUB_EMAIL }}>
author: ${{ env.GITHUB_USERNAME }} <${{ env.GITHUB_EMAIL }}>
commit-message: Update standing data dependency
title: Update standing data
body: >
Automated standing data update generated by the
[Release](https://github.com/ministryofjustice/bichard7-next-data/actions/workflows/release.yml)
workflow.
- name: PR information
run: |
echo "PR #${{ steps.cpr.outputs.pull-request-number }}"
echo "${{ steps.cpr.outputs.pull-request-url }}"
update-b7-repo:
name: Update maven package in bichard7-next repo
needs:
- bump-package-version
- release-maven-package
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v3
with:
repository: ministryofjustice/bichard7-next
token: ${{ secrets.GH_ACCESS_TOKEN }}
- name: Update standing data gradle dependency
run: |
sed -i -r "s/bichardDataVersion = \"[0-9]+\.[0-9]+\.[0-9]+\"$/bichardDataVersion = \"$VERSION\"/g" build.gradle
env:
VERSION: ${{ needs.bump-package-version.outputs.version }}
- name: Create pull request
id: cpr
uses: peter-evans/create-pull-request@v4
with:
branch: auto/update-standing-data
delete-branch: true
token: ${{ secrets.GH_ACCESS_TOKEN }}
committer: ${{ env.GITHUB_USERNAME }} <${{ env.GITHUB_EMAIL }}>
author: ${{ env.GITHUB_USERNAME }} <${{ env.GITHUB_EMAIL }}>
commit-message: Update standing data
title: Update standing data
body: >
Automated standing data update generated by the
[Release](https://github.com/ministryofjustice/bichard7-next-data/actions/workflows/release.yml)
workflow.
- name: PR information
run: |
echo "PR #${{ steps.cpr.outputs.pull-request-number }}"
echo "${{ steps.cpr.outputs.pull-request-url }}"