ci: wip actions #5
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Release Program | |
on: | |
# TODO: switch to triggering only on tag with regex | |
# workflow_dispatch: | |
# inputs: | |
# program_lib_name: | |
# description: "Program library name" | |
# required: true | |
# type: choice | |
# options: | |
# - marginfi | |
# - liquidity_incentive_program | |
push: | |
tags: | |
- "testest-program-*" # Push events to matching program-*, i.e. program-circuit-breaker-0.0.1 | |
env: | |
RUST_TOOLCHAIN: 1.71.0 | |
SOLANA_CLI_VERSION: 1.16.20 | |
ANCHOR_CLI_VERSION: 0.29.0 | |
ANCHOR_SHA: fc9fd6d24b9be84abb2f40e47ed3faf7b11864ae | |
CARGO_TERM_COLOR: always | |
CARGO_BUILD_TARGET: x86_64-unknown-linux-gnu | |
jobs: | |
build-verifiable: | |
name: Generate verifiable build | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install common dependencies | |
uses: ./.github/actions/setup-common/ | |
- name: Install Anchor CLI | |
uses: ./.github/actions/setup-anchor-cli/ | |
- name: Extract tag information | |
run: | | |
TAG=${GITHUB_REF#refs/tags/} # Extract tag name from ref | |
echo "Tag name: $TAG" | |
PROGRAM=$(echo $TAG | sed 's/testest-program-\(.*\)-[0-9]\{1,\}\.[0-9]\{1,\}\.[0-9]\{1,\}/\1/') | |
VERSION=$(echo $TAG | sed 's/.*-\([0-9]\{1,\}\.[0-9]\{1,\}\.[0-9]\{1,\}\)$/\1/') | |
PROGRAM_LIB_NAME=${PROGRAM//-/_} # Substitute dashes with underscores | |
PROGRAM_ID=$(~/.cargo/bin/toml get Anchor.toml programs.mainnet.${PROGRAM_LIB_NAME} | tr -d '"') | |
echo "Program: $PROGRAM" | |
echo "Program ID: $PROGRAM_ID" | |
echo "Version: $VERSION" | |
echo "PROGRAM_ID=${PROGRAM_ID}" >> $GITHUB_ENV | |
echo "PROGRAM_LIB_NAME=${PROGRAM_LIB_NAME}" >> $GITHUB_ENV | |
# Solely to generate the IDL | |
- name: Build program using Anchor | |
uses: ./.github/actions/build-program/ | |
with: | |
program_lib_name: ${{ env.PROGRAM_LIB_NAME }} | |
# Build verifiable program - store it in target/deploy/${PROGRAM_LIB_NAME}.so | |
- name: Build verifiable program | |
uses: ./.github/actions/build-verifiable-program/ | |
with: | |
program_lib_name: ${{ env.PROGRAM_LIB_NAME }} | |
- name: Patch IDL and TS files | |
run: cargo run --release -p marginfi-v2-cli --features dev -- patch-idl target/idl/marginfi.json | |
# Display contents of /target/deploy and /target/idl | |
- run: ls -l target/deploy | |
- run: ls -l target/idl | |
- name: Upload program | |
uses: actions/upload-artifact@v2 | |
with: | |
name: ${{ inputs.program_lib_name }}-verifiable_build-${{ github.run_id }}-${{ github.run_attempt }} | |
path: ./target/deploy/${{ inputs.program_lib_name }}.so | |
- name: Upload IDL (json) | |
uses: actions/upload-artifact@v2 | |
with: | |
name: ${{ inputs.program_lib_name }}-idl-${{ github.run_id }}-${{ github.run_attempt }} | |
path: ./target/idl/${{ inputs.program_lib_name }}_patched.json | |
- name: Upload IDL (types) | |
uses: actions/upload-artifact@v2 | |
with: | |
name: ${{ inputs.program_lib_name }}-types-${{ github.run_id }}-${{ github.run_attempt }} | |
path: ./target/idl/${{ inputs.program_lib_name }}_patched.ts | |
# # Deploy the program to the buffer account | |
# - uses: ./.github/actions/buffer-deploy/ | |
# id: buffer-deploy | |
# with: | |
# network: https://api.mainnet-beta.solana.com | |
# program: ${{ env.PROGRAM_LIB_NAME }} | |
# keypair: ${{ secrets.DEPLOYER_KEYPAIR }} | |
# program-id: ${{ env.PROGRAM_ID }} | |
# buffer-authority: ${{ secrets.MULTISIG_VAULT }} | |
# # Create MS proposal for program upgrade | |
# - name: Squads program upgrade | |
# uses: helium/[email protected] | |
# with: | |
# network-url: "https://api.mainnet-beta.solana.com" | |
# program-multisig: ${{ secrets.MULTISIG }} | |
# program-id: ${{ env.PROGRAM_ID }} | |
# buffer: ${{ steps.buffer-deploy.outputs.buffer }} | |
# idl-buffer: ${{ steps.buffer-deploy.outputs.idl-buffer }} | |
# spill-address: ${{ secrets.DEPLOYER_ADDRESS }} | |
# authority: ${{ secrets.MULTISIG_VAULT }} | |
# name: "Deploy ${{env.PROGRAM_LIB_NAME}} ${{env.VERSION}}" | |
# keypair: ${{ secrets.DEPLOYER_KEYPAIR }} |