Skip to content

CU hashchain validation #855

CU hashchain validation

CU hashchain validation #855

Workflow file for this run

name: 🦘 Test & Deploy AO Compute Unit
on:
pull_request:
branches:
- main
paths:
- "servers/cu/**"
push:
branches:
- main
paths:
- "servers/cu/**"
defaults:
run:
shell: bash
jobs:
test:
runs-on: ubuntu-latest
steps:
- name: ⬇️ Checkout repo
uses: actions/checkout@v4
- name: βŽ” Setup node
uses: actions/setup-node@v4
with:
node-version: 22
- name: πŸ“₯ Download repo deps
run: |
npm i
- name: πŸ“₯ Download deps
working-directory: servers/cu
run: |
npm i
- name: ⚑ Run Tests
working-directory: servers/cu
run: |
npm run lint
npm test
env:
CI: true
publish:
runs-on: ubuntu-latest
# Only publish on main branch
if: github.ref == 'refs/heads/main'
needs: [test]
permissions:
id-token: write
contents: read
checks: write
packages: write
steps:
- name: ⬇️ Checkout repo
uses: actions/checkout@v4
- name: Log in to the GitHub Container Registry
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and push container image to GitHub Container Registry
uses: docker/build-push-action@v4
with:
push: true
context: servers/cu
tags: |
ghcr.io/permaweb/ao-cu:latest
ghcr.io/permaweb/ao-cu:${{ github.sha }}
deploy:
runs-on: ubuntu-latest
# Only deploy on main branch
if: github.ref == 'refs/heads/main'
# Uncomment if we ever start running the release job
# needs: [test, release]
needs: [test]
steps:
- name: ⬇️ Checkout repo
uses: actions/checkout@v4
with:
ref: ${{ needs.bump.outputs.TAG }}
- name: βŽ” Setup node
uses: actions/setup-node@v4
with:
node-version: 22
- name: πŸ“₯ Download deps
working-directory: servers/cu
run: |
npm i
- name: πŸ‘€ Env
run: |
echo "Event name: ${{ github.event_name }}"
echo "Git ref: ${{ github.ref }}"
echo "GH actor: ${{ github.actor }}"
echo "SHA: ${{ github.sha }}"
VER=`node --version`; echo "Node ver: $VER"
VER=`npm --version`; echo "npm ver: $VER"
- name: πŸš€ Deploy
working-directory: servers/cu
env:
DEPLOY_HOOKS: ${{ secrets.CU_RENDER_DEPLOY_HOOKS }}
run: |
node deploy.js