diff --git a/.github/workflows/job-check-new-version.yml b/.github/workflows/job-check-new-version.yml deleted file mode 100644 index e48e41a0..00000000 --- a/.github/workflows/job-check-new-version.yml +++ /dev/null @@ -1,28 +0,0 @@ -on: - workflow_call: - outputs: - isNewVersion: - description: "Indicates if this build generates a new version" - value: ${{ jobs.check-new-version.outputs.isNewVersion }} - -jobs: - check-new-version: - name: Check new version - runs-on: ubuntu-latest - outputs: - isNewVersion: ${{ steps.newVersion.outputs.isNewVersion }} - steps: - - uses: actions/checkout@v4 - with: - fetch-depth: 0 - - name: Set up JDK 17 - uses: actions/setup-java@v4 - with: - java-version: 17 - distribution: temurin - cache: 'gradle' - - name: Change wrapper permission - run: chmod +x ./gradlew - - id: newVersion - name: Check new version - run: ./.github/workflows/scripts/check-new-version.sh \ No newline at end of file diff --git a/.github/workflows/job-publish.yml b/.github/workflows/job-publish.yml deleted file mode 100644 index bce2865e..00000000 --- a/.github/workflows/job-publish.yml +++ /dev/null @@ -1,41 +0,0 @@ -on: - workflow_call - -jobs: - publish: - name: Publish - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - with: - fetch-depth: 0 - - name: Set up JDK 17 - uses: actions/setup-java@v4 - with: - java-version: 17 - distribution: temurin - cache: 'gradle' - - name: Change wrapper permission - run: chmod +x ./gradlew - - - uses: actions/setup-node@v4 - with: - node-version: 14.x - - - name: Create tag and publish Github release - run: ./gradlew :nyxPublish - env: - GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - - name: Publish Maven - run: ./.github/workflows/scripts/publish-maven.sh - 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 }} diff --git a/.github/workflows/job-test.yml b/.github/workflows/job-test.yml deleted file mode 100644 index 4d6e58aa..00000000 --- a/.github/workflows/job-test.yml +++ /dev/null @@ -1,19 +0,0 @@ -on: - workflow_call - -jobs: - unit-test: - name: Run tests - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - name: Set up JDK 17 - uses: actions/setup-java@v4 - with: - java-version: 17 - distribution: temurin - cache: 'gradle' - - name: Change wrapper permission - run: chmod +x ./gradlew - - name: Test - run: ./gradlew clean allTests \ No newline at end of file diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 85feb67e..6cc19129 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -1,22 +1,62 @@ name: Main on: - push: + pull_request: + types: + - closed branches: - - 'main' - - 'master' - - 'beta' + - main + - master jobs: unit-test: - uses: ./.github/workflows/job-test.yml + name: Run tests + if: ${{ github.event.pull_request.merged == true }} + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: Set up JDK 17 + uses: actions/setup-java@v4 + with: + java-version: 17 + distribution: temurin + cache: 'gradle' + - name: Change wrapper permission + run: chmod +x ./gradlew - check-new-version: - needs: unit-test - uses: ./.github/workflows/job-check-new-version.yml + - name: Test + run: ./gradlew clean allTests publish: - needs: check-new-version - if: ${{ needs.check-new-version.outputs.isNewVersion == 'true' }} - uses: ./.github/workflows/job-publish.yml - secrets: inherit \ No newline at end of file + needs: unit-test + if: ${{ github.event.pull_request.merged == true && !contains(github.event.pull_request.title, '[skip publish]') }} + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Set up JDK 17 + uses: actions/setup-java@v4 + with: + java-version: 17 + distribution: temurin + cache: 'gradle' + - name: Change wrapper permission + run: chmod +x ./gradlew + + - uses: actions/setup-node@v4 + with: + node-version: 14.x + + - name: Publish Maven + run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository -PremoveSnapshotSuffix + 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-prod.sh + env: + NPMJS_TOKEN: ${{ secrets.DHIS2_BOT_NPM_TOKEN }} diff --git a/.github/workflows/publish_npm_beta.yml b/.github/workflows/publish_npm_beta.yml new file mode 100644 index 00000000..ff5e1316 --- /dev/null +++ b/.github/workflows/publish_npm_beta.yml @@ -0,0 +1,30 @@ +name: Publish NPM beta + +on: + workflow_dispatch + +jobs: + publish: + name: Publish NPM beta + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Set up JDK 17 + uses: actions/setup-java@v4 + with: + java-version: 17 + distribution: temurin + cache: 'gradle' + - name: Change wrapper permission + run: chmod +x ./gradlew + + - uses: actions/setup-node@v4 + with: + node-version: 14.x + + - name: Publish NPMJS + run: ./.github/workflows/scripts/publish-npm-beta.sh + env: + NPMJS_TOKEN: ${{ secrets.DHIS2_BOT_NPM_TOKEN }} diff --git a/.github/workflows/pull_request.yml b/.github/workflows/pull_request.yml index 424092b4..fd5a3fe1 100644 --- a/.github/workflows/pull_request.yml +++ b/.github/workflows/pull_request.yml @@ -1,7 +1,46 @@ name: Pull request -on: [pull_request] +on: + pull_request jobs: unit-test: - uses: ./.github/workflows/job-test.yml + name: Run tests + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: Set up JDK 17 + uses: actions/setup-java@v4 + with: + java-version: 17 + distribution: temurin + cache: 'gradle' + - name: Change wrapper permission + run: chmod +x ./gradlew + + - name: Test + run: ./gradlew clean allTests + + publish: + name: Publish + needs: unit-test + if: ${{ !contains(github.event.pull_request.title, '[skip publish]') }} + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Set up JDK 17 + uses: actions/setup-java@v4 + with: + java-version: 17 + distribution: temurin + cache: 'gradle' + - name: Change wrapper permission + run: chmod +x ./gradlew + + - name: Publish Maven Snapshot + run: ./gradlew publishToSonatype + env: + OSSRH_USERNAME: ${{ secrets.SONATYPE_OSSRH_USERNAME }} + OSSRH_PASSWORD: ${{ secrets.SONATYPE_OSSRH_PASSWORD }} diff --git a/.github/workflows/scripts/check-new-version.sh b/.github/workflows/scripts/check-new-version.sh deleted file mode 100755 index 1d80e584..00000000 --- a/.github/workflows/scripts/check-new-version.sh +++ /dev/null @@ -1,8 +0,0 @@ -# Check if new version -./gradlew checkIsNewVersion -q; newVersion=$? - -if [ $newVersion -ne 0 ]; then - echo "isNewVersion=false" >> "$GITHUB_OUTPUT" -else - echo "isNewVersion=true" >> "$GITHUB_OUTPUT" -fi \ No newline at end of file diff --git a/.github/workflows/scripts/publish-maven.sh b/.github/workflows/scripts/publish-maven.sh deleted file mode 100755 index c6efaee3..00000000 --- a/.github/workflows/scripts/publish-maven.sh +++ /dev/null @@ -1,9 +0,0 @@ -set -x - -branch=$(git rev-parse --abbrev-ref HEAD) - -if [ "$branch" = "main" ] || [ "$branch" = "master" ]; then - ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository -elif [ "$branch" = "beta" ]; then - ./gradlew publishToSonatype -PbetaToSnapshot -fi diff --git a/.github/workflows/scripts/publish-npm-beta.sh b/.github/workflows/scripts/publish-npm-beta.sh new file mode 100755 index 00000000..17f62dde --- /dev/null +++ b/.github/workflows/scripts/publish-npm-beta.sh @@ -0,0 +1,32 @@ +set -x + +./gradlew packJsPackage +./gradlew packJsPackage -PuseCommonJs + +cd build/packages/js || exit + +# Set authentication token for npmjs registry +npm set //registry.npmjs.org/:_authToken="$NPMJS_TOKEN" + +# Set 'beta' suffix in the version starting with beta.0 +sed -i -e 's/-SNAPSHOT"/-beta.0"/g' package.json + +# Try to upload the beta version. If it is not available, increase the beta number and try again. +# Iterate a maximum of MAX_ITERATION times. +n=1 +MAX_ITERATIONS=30 +while [ $n -le $MAX_ITERATIONS ]; do + if ! output=$(npm publish --tag beta 2>&1); then + if [[ "$output" == *"ERR! code E403"* ]]; then + # This error code is likely to be thrown when the version already exists + # Increase beta version number to try again + npm version prerelease + n=$(( n + 1 )) + else + exit 1 + fi + else + # If upload is successful, exit + exit 0 + fi +done diff --git a/.github/workflows/scripts/publish-npm.sh b/.github/workflows/scripts/publish-npm-prod.sh similarity index 53% rename from .github/workflows/scripts/publish-npm.sh rename to .github/workflows/scripts/publish-npm-prod.sh index 86fab572..60d732e9 100755 --- a/.github/workflows/scripts/publish-npm.sh +++ b/.github/workflows/scripts/publish-npm-prod.sh @@ -1,7 +1,5 @@ set -x -branch=$(git rev-parse --abbrev-ref HEAD) - ./gradlew packJsPackage ./gradlew packJsPackage -PuseCommonJs @@ -10,8 +8,4 @@ cd build/packages/js || exit # Set authentication token for npmjs registry npm set //registry.npmjs.org/:_authToken="$NPMJS_TOKEN" -if [ "$branch" = "main" ] || [ "$branch" = "master" ]; then - npm publish -elif [ "$branch" = "beta" ]; then - npm publish --tag beta -fi +npm publish diff --git a/.nyx.yaml b/.nyx.yaml deleted file mode 100644 index a55f70d4..00000000 --- a/.nyx.yaml +++ /dev/null @@ -1,57 +0,0 @@ ---- -# starting from the "simple" preset gives us: -# - the Conventional Commits convention -preset: "simple" -changelog: - path: "CHANGELOG.md" - sections: - "Added": "^feat$" - "Fixed": "^fix$" -releaseTypes: - enabled: - - mainline - - maturity - - internal - publicationServices: - - github - items: - mainline: - description: "{{#fileContent}}CHANGELOG.md{{/fileContent}}" - filterTags: "^({{configuration.releasePrefix}})?([0-9]\\d*)\\.([0-9]\\d*)\\.([0-9]\\d*)$" - gitPush: "true" - gitTag: "true" - matchBranches: "^(master|main)$" - matchEnvironmentVariables: - CI: "^true$" - matchWorkspaceStatus: "CLEAN" - publish: "true" - maturity: - description: "{{#fileContent}}CHANGELOG.md{{/fileContent}}" - collapseVersions: true - collapsedVersionQualifier: "{{#sanitizeLower}}{{branch}}{{/sanitizeLower}}" - filterTags: "^({{configuration.releasePrefix}})?([0-9]\\d*)\\.([0-9]\\d*)\\.([0-9]\\d*)(-(alpha|beta)(\\.([0-9]\\d*))?)?$" - gitPush: "true" - gitTag: "true" - matchBranches: "^(alpha|beta)$" - matchEnvironmentVariables: - CI: "^true$" - matchWorkspaceStatus: "CLEAN" - publish: "true" - publishPreRelease: "true" - internal: - collapseVersions: true - collapsedVersionQualifier: "internal" - gitPush: "false" - gitTag: "false" - identifiers: - - - qualifier: "{{#timestampYYYYMMDDHHMMSS}}{{timestamp}}{{/timestampYYYYMMDDHHMMSS}}" - position: "BUILD" - publish: "false" -services: - github: - type: "GITHUB" - options: - AUTHENTICATION_TOKEN: "{{#environmentVariable}}GH_TOKEN{{/environmentVariable}}" - REPOSITORY_NAME: "dhis2-rule-engine" - REPOSITORY_OWNER: "dhis2" \ No newline at end of file diff --git a/README.md b/README.md index 46db7acf..40ad14a1 100644 --- a/README.md +++ b/README.md @@ -62,27 +62,26 @@ List of supported environment (contextual) variables: - incident_date - 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. +## Development -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 +Library version is defined in the file `build.gradle.kts`. The version must be manually increased +and include the `-SNAPSHOT` suffix. Please make sure the version is updated before opening the PR. -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. +### Publications -If there is not any commit with any of this tags between the previous version and the current commit, nothing will be published. +On merged pull request to `main`: +- Production release to Maven. +- Production release to NPMJS. -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. +On pull request creation/update: +- Snapshot release to Maven. +On demand: +- Beta releases to NPMJS can be triggered on demand by using the action "Publish NPM beta". + Please make sure you select the right branch in the selector. + +Publication can be skipped by adding `[skip publish]` to the pull request title. --- WIP diff --git a/build.gradle.kts b/build.gradle.kts index 68799eb0..1fb044fa 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -1,5 +1,3 @@ -import com.mooltiverse.oss.nyx.gradle.CoreTask - plugins { kotlin("multiplatform") id("maven-publish-conventions") @@ -11,22 +9,12 @@ repositories { maven { url = uri("https://oss.sonatype.org/content/repositories/snapshots") } } +version = "3.0.0-SNAPSHOT" group = "org.hisp.dhis.rules" -if (project.hasProperty("betaToSnapshot")) { - val mainVersion = (version as String).split("-beta")[0] - version = "$mainVersion-SNAPSHOT" -} - -tasks.register("checkIsNewVersion") { - val state = project.properties[CoreTask.NYX_STATE_PROPERTY] as com.mooltiverse.oss.nyx.state.State - - if (state.newVersion) { - println("This build generates a new version ${state.version}") - } else { - println("This build does not generate a new version ${state.version}") - throw StopExecutionException("There is no new version") - } +if (project.hasProperty("removeSnapshotSuffix")) { + val mainVersion = (version as String).split("-SNAPSHOT")[0] + version = mainVersion } kotlin { diff --git a/settings.gradle.kts b/settings.gradle.kts index 10f3cc1e..c4debce4 100644 --- a/settings.gradle.kts +++ b/settings.gradle.kts @@ -5,8 +5,4 @@ pluginManagement { } } -plugins { - id("com.mooltiverse.oss.nyx") version "2.5.2" -} - rootProject.name = "rule-engine"