Skip to content

Release Pipeline - Network: , Requestor: , Provider: , WASI: , VM: #910

Release Pipeline - Network: , Requestor: , Provider: , WASI: , VM:

Release Pipeline - Network: , Requestor: , Provider: , WASI: , VM: #910

Workflow file for this run

name: Release Pipeline
on:
push:
branches:
# Regular release channels
- master
- next
- beta
- alpha
# Support, hotfix branches like: 1.0.x or 1.x
- '([0-9]+)(\.([0-9]+))?\.x'
# Allows triggering the workflow manually
workflow_dispatch:
inputs:
payment_network:
description: "Payment network (hoodi, amoy, polygon)"
required: false
default: "hoodi"
provider_version:
description: "Provider version (e.g., v0.15.0 or pre-rel-v0.15.1)"
required: false
default: "pre-rel-v0.17.1-hoodi3"
requestor_version:
description: "Requestor version (e.g., v0.15.0 or pre-rel-v0.15.1)"
required: false
default: "pre-rel-v0.17.1-hoodi3"
provider_wasi_version:
description: "Provider WASI version (e.g., v0.2.2)"
required: false
default: "v0.2.2"
provider_vm_version:
description: "Provider VM version (e.g., v0.5.3)"
required: false
default: "v0.5.3"
log_level:
description: "The log level to force on golem-js pino-logger"
required: false
default: "info"
# We're going to interact with GH from the pipelines, so we need to get some permissions
permissions:
contents: read # for checkout
env:
PROVIDER_VERSION: ${{ github.event.inputs.provider_version || 'pre-rel-v0.17.1-hoodi3' }}
REQUESTOR_VERSION: ${{ github.event.inputs.requestor_version || 'pre-rel-v0.17.1-hoodi3' }}
PROVIDER_WASI_VERSION: ${{ github.event.inputs.provider_wasi_version || 'v0.2.2' }}
PROVIDER_VM_VERSION: ${{ github.event.inputs.provider_vm_version || 'v0.5.3' }}
PAYMENT_NETWORK: ${{ github.event.inputs.payment_network || 'hoodi' }}
GOLEM_PINO_LOG_LEVEL: ${{ github.event.inputs.log_level || 'info' }}
jobs:
run-e2e-tests:
name: Run E2E tests
runs-on: goth2
steps:
- uses: actions/checkout@v4
- name: Prepare providers and requestor
uses: ./.github/actions/prepare-tests
- name: Start the E2E test
run: docker exec -t docker-requestor-1 /bin/sh -c "cd /golem-js && npm run test:e2e"
- name: Upload E2E reports
uses: actions/upload-artifact@v4
if: always()
with:
name: e2e-test-report
path: reports/e2e-report.xml
- name: Cleanup test environment
uses: ./.github/actions/cleanup-tests
if: always()
with:
type: "e2e"
run-examples-tests:
name: Run Examples tests
runs-on: goth2
steps:
- uses: actions/checkout@v4
- name: Prepare providers and requestor
uses: ./.github/actions/prepare-tests
- name: Run the Examples tests
run: docker exec -t -e GOLEM_PINO_LOG_LEVEL="${{ env.GOLEM_PINO_LOG_LEVEL }}" docker-requestor-1 /bin/sh -c "cd /golem-js && npm run test:examples -- --exitOnError"
- name: Cleanup test environment
uses: ./.github/actions/cleanup-tests
if: always()
with:
type: "examples"
run-cypress-tests:
name: Run Cypress tests
runs-on: goth2
steps:
- uses: actions/checkout@v4
- name: Prepare providers and requestor
uses: ./.github/actions/prepare-tests
with:
type: "cypress"
- name: Run web server
run: docker exec -t -d docker-requestor-1 /bin/sh -c "cd /golem-js/examples && npm run web"
- name: Run test suite
run: docker exec -t docker-requestor-1 /bin/sh -c "cd /golem-js && npm run test:cypress -- --browser chromium"
- name: Upload test logs
uses: actions/upload-artifact@v4
if: always()
with:
name: cypress-logs
path: .cypress
- name: Cleanup test environment
uses: ./.github/actions/cleanup-tests
with:
type: "cypress"
release:
name: Release the SDK to NPM and GitHub
runs-on: ubuntu-latest
permissions:
contents: write # to be able to publish a GitHub release
issues: write # to be able to comment on released issues
pull-requests: write # to be able to comment on released pull requests
id-token: write # to enable use of OIDC for npm provenance
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup NodeJS
uses: actions/setup-node@v4
with:
# Semantic release requires this as bare minimum
node-version: 20
# Why this? https://github.com/npm/cli/issues/7279
# Why this way? https://github.com/actions/setup-node/issues/213
- name: Install latest npm
shell: bash
run: |
npm install -g npm@latest &&
npm --version &&
npm list -g --depth 0
- name: Install dependencies
run: npm install
- name: Verify the integrity of provenance attestations and registry signatures for installed dependencies
run: npm audit signatures
- name: Build the SDK for release
run: npm run build
- name: Release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
run: npx semantic-release
run-name: "${{ github.workflow }} - Network: ${{ github.event.inputs.payment_network }}, Requestor: ${{ github.event.inputs.requestor_version }}, Provider: ${{ github.event.inputs.provider_version }}, WASI: ${{ github.event.inputs.provider_wasi_version }}, VM: ${{ github.event.inputs.provider_vm_version }}"