Skip to content

Initialization

Initialization #8

Workflow file for this run

name: Release
on:
push:
tags:
- "v*"
permissions:
# Necessary to trigger the override workflow.
actions: write
# Necessary to publish the release.
contents: write
env:
CARGO_REGISTRIES_CRATES_IO_PROTOCOL: sparse
CARGO_TERM_COLOR: always
RUST_BACKTRACE: full
jobs:
# This job triggers the override workflow for the target runtime.
trigger-override:
name: Trigger override
runs-on: ubuntu-latest
strategy:
matrix:
# Add the runtime here that you want to build its override.
#
# The possible values are defined in the `override.yml` workflow.
runtime: ["polkadot-runtime", "staging-kusama-runtime"]
steps:
- name: Trigger override
env:
# Use a Personal Access Token (PAT) if `GITHUB_TOKEN` does not have enough permissions to trigger the override workflow.
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: gh workflow run override.yml
--repo hack-ink/polkadot-runtime-releaser-workshop
--ref main
-f runtime="${{ matrix.runtime }}"
-f ref="${{ github.ref_name }}"
build-runtime:
name: Build runtime
runs-on: ubuntu-latest
strategy:
matrix:
# Add the runtime here that you want to release.
runtime: ["polkadot-runtime", "staging-kusama-runtime"]
steps:
- name: Fetch latest code
uses: actions/checkout@v4
- name: Build runtime
# It is recommended to use a specific version of the action in production.
#
# For example:
# uses: hack-ink/polkadot-runtime-releaser/action/[email protected]
uses: hack-ink/polkadot-runtime-releaser/action/build@main
with:
runtime: ${{ matrix.runtime }}
# The features to enable for this release build.
#
# Generally, this would be `on-chain-release-build` in order to disable the logging to shrink the WASM binary size.
features: on-chain-release-build
# The output directory of the WASM binary.
output-dir: .
- name: Locate runtime
id: locate
run: |
RUNTIME=$(find . -maxdepth 1 -name '*.wasm' | head -n 1)
echo "runtime=$RUNTIME" >> "$GITHUB_OUTPUT"
- name: Inspect runtime
uses: hack-ink/polkadot-runtime-releaser/action/inspect@main
with:
runtime: ${{ steps.locate.outputs.runtime }}
- name: Construct build info
run: |
echo "${{ steps.inspect.outputs.result }}" | jq '.' > result_pretty.json
jq --arg runtime "${{ matrix.runtime }}"
--argfile res result_pretty.json
'.runtime = $runtime | .result = $res'
<<< '{}' > runtime.json
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
name: ${{ matrix.runtime }}-artifact
path: |
${{ steps.locate.outputs.runtime }}
runtime.json
release:
name: Release
runs-on: ubuntu-latest
needs: build-runtime
steps:
- name: Download artifact
uses: actions/download-artifact@v4
with:
path: download
- name: Construct release notes
run: |
echo "# Release for tag \`${{ github.ref }}\`" > release_note.md
echo "" >> release_note.md
for artifact_dir in download/*-artifact; do
if [ -f "$artifact_dir/runtime.json" ]; then
RUNTIME=$(jq -r '.runtime' "$artifact_dir/runtime.json")
RESULT=$(jq '.result' "$artifact_dir/runtime.json")
echo "## $RUNTIME" >> release_note.md
echo "\`\`\`json" >> release_note.md
echo "$RESULT" | jq '.' >> release_note.md
echo "\`\`\`" >> release_note.md
echo "" >> release_note.md
fi
done
- name: Publish release
uses: softprops/action-gh-release@v2
with:
body_path: release_note.md
files: |
download/**/*.wasm