chore: expose external id getters #34
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: Main | |
on: | |
pull_request: | |
push: | |
branches: | |
- main | |
tags: | |
- "v*.*.*" | |
jobs: | |
build-wasm: | |
name: Build DNA | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install nix | |
uses: cachix/install-nix-action@v18 | |
with: | |
install_url: https://releases.nixos.org/nix/nix-2.13.3/install | |
extra_nix_config: | | |
experimental-features = flakes nix-command | |
- uses: cachix/cachix-action@v10 | |
with: | |
name: holochain-ci | |
- name: Set up Rust cache | |
uses: actions/cache@v3 | |
with: | |
path: | | |
~/.cargo/bin/ | |
~/.cargo/registry/index/ | |
~/.cargo/registry/cache/ | |
~/.cargo/git/db/ | |
target/ | |
key: holoom-dna-${{ hashFiles('**/Cargo.lock') }} | |
- name: Build DNA | |
run: | | |
nix develop --command \ | |
npm run build:dna | |
- uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: happ_workdir | |
path: workdir | |
retention-days: 1 | |
build-rocket: | |
name: Build Rocket | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@v3 | |
- run: scripts/build_rocket_builder.sh | |
- name: Cargo build in docker | |
run: | | |
docker run -i \ | |
-v "$(pwd):/proj" \ | |
-w /proj rocket-builder bash -c \ | |
"cargo build --release --package holoom_rocket_server" | |
- run: sudo chown -R $(whoami) target | |
- name: Ready artifact dir | |
run: mkdir artifact && mv target/release/holoom_rocket_server artifact/ | |
- uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: rocket | |
path: artifact | |
retention-days: 1 | |
dna-tests: | |
name: DNA Tests | |
runs-on: ubuntu-20.04 | |
needs: | |
- build-wasm | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Free Disk Space (Ubuntu) | |
uses: jlumbroso/free-disk-space@main | |
- name: Install nix | |
uses: cachix/install-nix-action@v18 | |
with: | |
install_url: https://releases.nixos.org/nix/nix-2.13.3/install | |
extra_nix_config: | | |
experimental-features = flakes nix-command | |
- uses: cachix/cachix-action@v10 | |
with: | |
name: holochain-ci | |
- name: Set up Rust cache | |
uses: actions/cache@v3 | |
with: | |
path: | | |
~/.cargo/bin/ | |
~/.cargo/registry/index/ | |
~/.cargo/registry/cache/ | |
~/.cargo/git/db/ | |
target/ | |
key: holoom-dna-tests-${{ hashFiles('**/Cargo.lock') }} | |
- run: rm -rf workdir | |
- name: Download DNA | |
uses: actions/download-artifact@v4 | |
with: | |
name: happ_workdir | |
path: workdir | |
- name: Build and run tests | |
run: | | |
nix develop --command \ | |
cargo nextest run -j 1 | |
e2e: | |
name: Build and run end-to-end tests | |
needs: | |
- build-wasm | |
- build-rocket | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Download happ_workdir | |
uses: actions/download-artifact@v4 | |
with: | |
name: happ_workdir | |
path: docker/misc_hc/happ_workdir | |
- name: Download rocket binary | |
uses: actions/download-artifact@v4 | |
with: | |
name: rocket | |
path: rocket-artifact | |
- run: mv rocket-artifact/holoom_rocket_server docker/rocket/ | |
- name: Setup Node | |
uses: actions/setup-node@v3 | |
with: | |
node-version: "18.19.1" | |
cache: "npm" | |
- name: Setup node dependency cache | |
uses: actions/cache@v2 | |
with: | |
path: "**/node_modules" | |
key: node_modules-${{ hashFiles('**/package-lock.json')}} | |
- run: npm i | |
- run: npx puppeteer browsers install chrome | |
- run: npm run build:client | |
- run: npm run build:external-id-attestor | |
- run: npm run build:evm-bytes-signer | |
- run: npm run build:mock-oracle | |
- name: Save client build for possible publish | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: client-dist | |
path: packages/client/dist | |
retention-days: 1 | |
- name: Build images | |
run: | | |
docker build --target local-services -t holoom/local-services docker/misc_hc | |
docker build --target authority-agent-sandbox -t holoom/authority-agent-sandbox docker/misc_hc | |
docker build --target holo-dev-server -t holoom/holo-dev-server docker/misc_hc | |
docker build -t holoom/mock-auth docker/mock-auth | |
docker build \ | |
-t holoom/external-id-attestor \ | |
-f docker/external-id-attestor/Dockerfile \ | |
packages/external-id-attestor | |
docker build \ | |
-t holoom/mock-oracle \ | |
-f docker/mock-oracle/Dockerfile \ | |
packages/mock-oracle | |
docker build \ | |
-t holoom/evm-bytes-signer \ | |
-f docker/evm-bytes-signer/Dockerfile \ | |
packages/evm-bytes-signer | |
docker build -t holoom/rocket docker/rocket | |
- name: Start frontend in background | |
run: npm run dev -w @holoom/e2e & | |
- name: Run e2e tests | |
run: npm run test -w @holoom/e2e | |
release: | |
name: Publish release artefacts | |
if: startsWith(github.ref, 'refs/tags/v') | |
needs: | |
- e2e | |
- dna-tests | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Download happ_workdir | |
uses: actions/download-artifact@v4 | |
with: | |
name: happ_workdir | |
path: happ_workdir | |
- name: Move DNA | |
run: mv happ_workdir/holoom.dna ./holoom.dna | |
- name: Download rocket binary | |
uses: actions/download-artifact@v4 | |
with: | |
name: rocket | |
path: rocket-artifact | |
- name: Move server binary | |
run: mv rocket-artifact/holoom_rocket_server ./holoom_rocket_server-bookworm | |
- name: Download client dist | |
uses: actions/download-artifact@v4 | |
with: | |
name: client-dist | |
path: packages/client/dist | |
- name: Release binaries | |
uses: softprops/action-gh-release@v2 | |
with: | |
files: | | |
holoom.dna | |
holoom_rocket_server-bookworm | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: "18.19.1" | |
registry-url: "https://registry.npmjs.org" | |
- name: Publish client to npm | |
run: npm publish --access public -w @holoom/client | |
env: | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} |