From 9fb830be487c371c4bbfd7db1099046efd3cd69f Mon Sep 17 00:00:00 2001 From: syedhasandigi <82388499+syedhasandigi@users.noreply.github.com> Date: Thu, 17 Oct 2024 09:58:15 +0100 Subject: [PATCH 1/4] BUG - Testing release --- .github/workflows/release.yml | 44 +++++++++++++---------------------- package-lock.json | 4 ++-- package.json | 2 +- 3 files changed, 19 insertions(+), 31 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 886b45a..188f144 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -2,7 +2,7 @@ name: Release on: push: - branches: ['main'] + branches: ['main', 'bug/publish-release-failing'] jobs: preconditions: runs-on: ubuntu-latest @@ -121,7 +121,7 @@ jobs: node-version: '16.x' registry-url: 'https://npm.pkg.github.com' scope: '@digicatapult' - - name: Install packages + - name: Install packages run: npm ci - name: Publish to github packages run: npm publish --access public @@ -161,38 +161,26 @@ jobs: publish: name: 'Publish release' - needs: [publish-npm, publish-gh] + needs: + - publish-npm + - publish-gh runs-on: ubuntu-latest if: ${{ needs.check-version.outputs.is_new_version == 'true' }} steps: - uses: actions/checkout@v4 - + # Build github release - name: Build release version - uses: softprops/action-gh-release@v2 - with: - token: '${{ secrets.GITHUB_TOKEN }}' - tag_name: ${{ needs.check-version.outputs.version }} - prerelease: false - name: ${{ needs.check-version.outputs.version }} - generate_release_notes: true - - name: Delete release latest - uses: actions/github-script@v7 + uses: 'marvinpinto/action-automatic-releases@latest' with: - github-token: ${{secrets.GITHUB_TOKEN}} - script: | - const { owner, repo } = context.repo - try { - await github.rest.git.deleteRef({ owner, repo, ref: 'tags/latest' }) - } - catch (err) { - if (err.status !== 422) throw err - } + repo_token: '${{ secrets.GITHUB_TOKEN }}' + automatic_release_tag: ${{ needs.check-version.outputs.version }} + prerelease: false + title: Release ${{ needs.check-version.outputs.version }} - name: Build release latest - uses: softprops/action-gh-release@v2 + uses: 'marvinpinto/action-automatic-releases@latest' with: - token: '${{ secrets.GITHUB_TOKEN }}' - tag_name: latest - prerelease: false - name: Latest ${{ needs.check-version.outputs.version }} - generate_release_notes: true + repo_token: '${{ secrets.GITHUB_TOKEN }}' + automatic_release_tag: latest + prerelease: false + title: Latest Release ${{ needs.check-version.outputs.version }} diff --git a/package-lock.json b/package-lock.json index 8e862d7..60a8a6c 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@digicatapult/dtdl-parser", - "version": "0.0.19", + "version": "0.0.20", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "@digicatapult/dtdl-parser", - "version": "0.0.19", + "version": "0.0.20", "license": "Apache-2.0", "devDependencies": { "@eslint/eslintrc": "^3.1.0", diff --git a/package.json b/package.json index 57cd45f..18ff76d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@digicatapult/dtdl-parser", - "version": "0.0.19", + "version": "0.0.20", "description": "JS tool to parse DTDL defined Ontologies", "main": "build/index.js", "type": "module", From 712b62165725dc7db5fc925da610baa39ed2f454 Mon Sep 17 00:00:00 2001 From: syedhasandigi <82388499+syedhasandigi@users.noreply.github.com> Date: Thu, 17 Oct 2024 10:14:31 +0100 Subject: [PATCH 2/4] removing gh package release and release tags --- .github/workflows/release.yml | 291 +++++++++++++--------------------- 1 file changed, 114 insertions(+), 177 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 188f144..3949dc5 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,186 +1,123 @@ name: Release -on: - push: - branches: ['main', 'bug/publish-release-failing'] +on: + push: + branches: ["main"] + jobs: - preconditions: - runs-on: ubuntu-latest - outputs: - repo_name: ${{ steps.repo_ids.outputs.REPO_NAME }} - org_name: ${{ steps.repo_ids.outputs.ORG_NAME }} - steps: - - name: Checkout - uses: actions/checkout@v4 - with: - fetch-depth: 0 - - name: Check Github token - run: | - if [ -z "${{ secrets.GITHUB_TOKEN }}"]; then - echo "Must provide a GITHUB_TOKEN secret in order to run release workflow" - exit 1 - fi - - name: Check npmjs token - run: | - if [ -z "${{ secrets.NPMJS_TOKEN }}"]; then - echo "Must provide a NPMJS_TOKEN secret in order to run release workflow" - exit 1 - fi - - name: Get repository identifiers - id: repo_ids - run: | - REPO_NAME=$(echo "${{ github.event.repository.name }}" | tr '[:upper:]' '[:lower:]') - ORG_NAME=$(echo "${{ github.event.repository.owner.name }}" | tr '[:upper:]' '[:lower:]') - echo "REPO_NAME=$REPO_NAME" >> $GITHUB_OUTPUT - echo "ORG_NAME=$ORG_NAME" >> $GITHUB_OUTPUT - static-checks: - name: Run Static Analysis Checks - strategy: - fail-fast: false - matrix: - command: [lint, depcheck, check] - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-node@v4 - with: - node-version: 20.x - - name: Cache Node.js modules - uses: actions/cache@v4 - with: - path: ~/.npm # npm cache files are stored in `~/.npm` on Linux/macOS - key: ${{ runner.OS }}-node-${{ hashFiles('**/package-lock.json') }} - restore-keys: | - ${{ runner.OS }}-node- - ${{ runner.OS }}- - - name: Install Packages - run: npm ci - - name: Checks - run: npm run ${{ matrix.command }} - tests: - name: Run tests - strategy: - fail-fast: false - matrix: - command: ['test'] - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-dotnet@v4 - with: - dotnet-version: '8.0.x' - - uses: actions/setup-node@v4 - with: - node-version: 20.x - - name: Cache Node.js modules - uses: actions/cache@v4 - with: - path: ~/.npm # npm cache files are stored in `~/.npm` on Linux/macOS - key: ${{ runner.OS }}-node-${{ hashFiles('**/package-lock.json') }} - restore-keys: | - ${{ runner.OS }}-node- - ${{ runner.OS }}- - - name: Install wasm tools - run: dotnet workload install wasm-tools - - name: Install Packages - run: npm ci - - name: Build - run: npm run build - - name: Run tests - run: npm run ${{ matrix.command }} - check-version: - name: 'Check version' - runs-on: ubuntu-latest - outputs: - is_new_version: ${{ steps.get_version.outputs.IS_NEW_VERSION }} - version: ${{ steps.get_version.outputs.VERSION }} - build_date: ${{ steps.get_version.outputs.BUILD_DATE }} - is_prerelease: ${{ steps.get_version.outputs.IS_PRERELEASE }} - steps: - - uses: actions/checkout@v4 - - name: Check version - id: get_version - uses: digicatapult/check-version@v1 - with: - token: ${{ secrets.GITHUB_TOKEN }} - publish-gh: - name: 'Publish Github package' - needs: - - preconditions - - static-checks - - tests - - check-version - runs-on: ubuntu-latest - if: ${{ needs.check-version.outputs.is_new_version == 'true' }} + preconditions: + runs-on: ubuntu-latest + outputs: + repo_name: ${{ steps.repo_ids.outputs.REPO_NAME }} + org_name: ${{ steps.repo_ids.outputs.ORG_NAME }} + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Check token + run: | + if [ -z "${{ secrets.GITHUB_TOKEN }}"]; then + echo "Must provide a GITHUB_TOKEN secret in order to run release workflow" + exit 1 + fi + - name: Get repository identifiers + id: repo_ids + run: | + REPO_NAME=$(echo "${{ github.event.repository.name }}" | tr '[:upper:]' '[:lower:]') + ORG_NAME=$(echo "${{ github.event.repository.owner.name }}" | tr '[:upper:]' '[:lower:]') + echo "REPO_NAME=$REPO_NAME" >> $GITHUB_OUTPUT + echo "ORG_NAME=$ORG_NAME" >> $GITHUB_OUTPUT + + static-checks: + name: Run Static Analysis Checks + strategy: + matrix: + command: [lint, depcheck, check] + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-node@v4 + with: + node-version: 20.x + - name: Cache Node.js modules + uses: actions/cache@v4 + with: + path: ~/.npm # npm cache files are stored in `~/.npm` on Linux/macOS + key: ${{ runner.OS }}-node-${{ hashFiles('**/package-lock.json') }} + restore-keys: | + ${{ runner.OS }}-node- + ${{ runner.OS }}- + - name: Install Packages + run: npm ci + - name: Lint + run: npm run ${{ matrix.command }} - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-node@v4 - with: - node-version: '16.x' - registry-url: 'https://npm.pkg.github.com' - scope: '@digicatapult' - - name: Install packages - run: npm ci - - name: Publish to github packages - run: npm publish --access public - env: - NODE_AUTH_TOKEN: ${{ secrets.GITHUB_TOKEN }} + tests: + name: Run tests + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-node@v4 + with: + node-version: 20.x + - name: Cache Node.js modules + uses: actions/cache@v4 + with: + path: ~/.npm # npm cache files are stored in `~/.npm` on Linux/macOS + key: ${{ runner.OS }}-node-${{ hashFiles('**/package-lock.json') }} + restore-keys: | + ${{ runner.OS }}-node- + ${{ runner.OS }}- + - name: Install Packages + run: npm ci + - name: Run tests + run: npm run test - publish-npm: - name: 'Publish package to NPMJS' - needs: - - preconditions - - static-checks - - tests - - check-version - runs-on: ubuntu-latest - if: ${{ needs.check-version.outputs.is_new_version == 'true' }} + check-version: + name: "Check version" + runs-on: ubuntu-latest + outputs: + is_new_version: ${{ steps.get_version.outputs.IS_NEW_VERSION }} + version: ${{ steps.get_version.outputs.VERSION }} + build_date: ${{ steps.get_version.outputs.BUILD_DATE }} + is_prerelease: ${{ steps.get_version.outputs.IS_PRERELEASE }} - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-node@v4 - with: - node-version: '18.x' - registry-url: 'https://registry.npmjs.org' - scope: '@digicatapult' - - uses: actions/setup-dotnet@v4 - with: - dotnet-version: '8.0.x' - - name: Install wasm tools - run: dotnet workload install wasm-tools - - name: Install packages - run: npm ci - - name: Build - run: npm run build - - name: Publish to npmjs packages - run: npm publish --access public - env: - NODE_AUTH_TOKEN: ${{ secrets.NPMJS_TOKEN }} + steps: + - uses: actions/checkout@v4 + - name: Check version + id: get_version + uses: digicatapult/check-version@v1 + with: + token: ${{ secrets.GITHUB_TOKEN }} - publish: - name: 'Publish release' - needs: - - publish-npm - - publish-gh - runs-on: ubuntu-latest - if: ${{ needs.check-version.outputs.is_new_version == 'true' }} + publish-npm: + name: 'Publish package to NPMJS' + needs: + - static-checks + - tests + - check-version + runs-on: ubuntu-latest + if: ${{ needs.check-version.outputs.is_new_version == 'true' }} - steps: - - uses: actions/checkout@v4 - # Build github release - - name: Build release version - uses: 'marvinpinto/action-automatic-releases@latest' - with: - repo_token: '${{ secrets.GITHUB_TOKEN }}' - automatic_release_tag: ${{ needs.check-version.outputs.version }} - prerelease: false - title: Release ${{ needs.check-version.outputs.version }} - - name: Build release latest - uses: 'marvinpinto/action-automatic-releases@latest' - with: - repo_token: '${{ secrets.GITHUB_TOKEN }}' - automatic_release_tag: latest - prerelease: false - title: Latest Release ${{ needs.check-version.outputs.version }} + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-node@v4 + with: + node-version: '20.x' + registry-url: 'https://registry.npmjs.org' + scope: '@digicatapult' + - uses: actions/setup-dotnet@v4 + with: + dotnet-version: '8.0.x' + - name: Install wasm tools + run: dotnet workload install wasm-tools + - name: Install Packages + run: npm ci + - name: Build + run: npm run build + - name: Publish to npmjs packages + run: npm publish --access public + env: + NODE_AUTH_TOKEN: ${{ secrets.NPMJS_TOKEN }} \ No newline at end of file From 3672dc935264161498a2ea04df027bcae6619240 Mon Sep 17 00:00:00 2001 From: syedhasandigi <82388499+syedhasandigi@users.noreply.github.com> Date: Thu, 17 Oct 2024 10:15:11 +0100 Subject: [PATCH 3/4] version bump --- package-lock.json | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/package-lock.json b/package-lock.json index 60a8a6c..8dc100e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@digicatapult/dtdl-parser", - "version": "0.0.20", + "version": "0.0.21", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "@digicatapult/dtdl-parser", - "version": "0.0.20", + "version": "0.0.21", "license": "Apache-2.0", "devDependencies": { "@eslint/eslintrc": "^3.1.0", diff --git a/package.json b/package.json index 18ff76d..6571344 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@digicatapult/dtdl-parser", - "version": "0.0.20", + "version": "0.0.21", "description": "JS tool to parse DTDL defined Ontologies", "main": "build/index.js", "type": "module", From e48c3640a289169cb7b789ccd0c388c191f6f6aa Mon Sep 17 00:00:00 2001 From: syedhasandigi <82388499+syedhasandigi@users.noreply.github.com> Date: Thu, 17 Oct 2024 13:38:38 +0100 Subject: [PATCH 4/4] including publish release tag --- .github/workflows/release.yml | 26 +++++++++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 3949dc5..efbc17e 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -120,4 +120,28 @@ jobs: - name: Publish to npmjs packages run: npm publish --access public env: - NODE_AUTH_TOKEN: ${{ secrets.NPMJS_TOKEN }} \ No newline at end of file + NODE_AUTH_TOKEN: ${{ secrets.NPMJS_TOKEN }} + + publish: + name: 'Publish release' + needs: [publish-npm, check-version] + runs-on: ubuntu-latest + if: ${{ needs.check-version.outputs.is_new_version == 'true' }} + + steps: + - uses: actions/checkout@v4 + # Build github release + - name: Build release version + uses: 'marvinpinto/action-automatic-releases@latest' + with: + repo_token: '${{ secrets.GITHUB_TOKEN }}' + automatic_release_tag: ${{ needs.check-version.outputs.version }} + prerelease: false + title: Release ${{ needs.check-version.outputs.version }} + - name: Build release latest + uses: 'marvinpinto/action-automatic-releases@latest' + with: + repo_token: '${{ secrets.GITHUB_TOKEN }}' + automatic_release_tag: latest + prerelease: false + title: Latest Release ${{ needs.check-version.outputs.version }} \ No newline at end of file