From 4f4eabc2012bc03f98f299557946b52d57c75224 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?V=C3=ADctor=20Garc=C3=ADa?= Date: Thu, 11 Apr 2024 15:53:01 +0200 Subject: [PATCH] Update readme and keys (#127) * Update readme file to add development section * Add signing keys --- .github/workflows/job-publish.yml | 4 +++- README.md | 23 ++++++++++++++++++++++- 2 files changed, 25 insertions(+), 2 deletions(-) diff --git a/.github/workflows/job-publish.yml b/.github/workflows/job-publish.yml index 20b63313..bce2865e 100644 --- a/.github/workflows/job-publish.yml +++ b/.github/workflows/job-publish.yml @@ -32,8 +32,10 @@ jobs: env: OSSRH_USERNAME: ${{ secrets.SONATYPE_OSSRH_USERNAME }} OSSRH_PASSWORD: ${{ secrets.SONATYPE_OSSRH_PASSWORD }} + SIGNING_PRIVATE_KEY: ${{ secrets.PGP_PRIVATE_KEY }} + SIGNING_PASSWORD: ${{ secrets.PGP_PASSPHRASE }} - name: Publish NPMJS run: ./.github/workflows/scripts/publish-npm.sh env: - NPMJS_TOKEN: ${{ secrets.DHIS2_BOT_NPM_TOKEN }} \ No newline at end of file + NPMJS_TOKEN: ${{ secrets.DHIS2_BOT_NPM_TOKEN }} diff --git a/README.md b/README.md index 0e9ac61d..2eec2543 100644 --- a/README.md +++ b/README.md @@ -60,7 +60,28 @@ List of supported environment (contextual) variables: - enrollment_id - enrollment_count - incident_date - - tei_count + - tei_count + +### Development +This library implements the semantic release setup, which means that version numbers are not manually maintained but +derived from the commit/PR history. + +Branches: +- `main`: a push to `main` branch will trigger a new production release (both Maven and NPMJS). +- `beta`: a push to `beta` branch will trigger a SNAPSHOT release in Maven and a new beta release in NPMJS. + +Version number are determined by the presence of commits with these suffixes: +- `fix:`: it will increase the patch number. +- `feat:`: it will increase the minor version number. +- `feat!:`: it will increase the major version number. + +If there is not any commit with any of this tags between the previous version and the current commit, nothing will be published. + +Typical workflow: +1. Do work in a feature branch. There is no need to add tags to the commits. +2. Create a PR to `beta` branch including a tag in the PR title depending on the kind of changes. +3. Merge the PR using **Squash and merge**. It will publish a SNAPSHOT/BETA release if there is a version change. +4. Create a PR to `main` branch. Once merged, it will publish a production release. --- WIP