From 1b7c376328fb2c3cb6a50a32b645c0a0b539732c Mon Sep 17 00:00:00 2001 From: Luqi Pan Date: Mon, 18 Mar 2024 13:11:16 -0700 Subject: [PATCH] ci: add integration test to GitHub Action (#24) * ci: add integration test to GitHub Action * ci: add comment and switch up order for steps * ci: add a step to verify contracts started onchain And bump the block height threshold for being healthy * ci: add additional tests for other contracts * ci: bump timeout to 300 seconds * ci: remove bogus curl line for testing * ci: remove test for swaparoo for now Ref: https://github.com/Agoric/dapp-agoric-basics/pull/24#discussion_r1529192563 --- .github/workflows/pr.yml | 54 ++++++++++++++++++++++++++++++++++------ 1 file changed, 47 insertions(+), 7 deletions(-) diff --git a/.github/workflows/pr.yml b/.github/workflows/pr.yml index da505b34..4e63b7fd 100644 --- a/.github/workflows/pr.yml +++ b/.github/workflows/pr.yml @@ -1,19 +1,18 @@ -name: Lint and Test +name: CI on: pull_request: jobs: - all: + unit: runs-on: ubuntu-latest steps: - name: Checkout Repo - uses: actions/checkout@v3 - - name: Use Node.js 18.8.x - uses: actions/setup-node@v3 + uses: actions/checkout@v4 + - name: Use Node.js 18 + uses: actions/setup-node@v4 with: - # use node 18.8.x until Agoric/agoric-sdk#8636 - node-version: '18.8.x' + node-version: "18" - name: yarn install run: yarn - name: yarn lint @@ -24,3 +23,44 @@ jobs: run: yarn test - name: yarn test:e2e run: yarn test:e2e + integration: + runs-on: ubuntu-latest + steps: + - name: Checkout Repo + uses: actions/checkout@v4 + - name: Use Node.js 18 + uses: actions/setup-node@v4 + with: + node-version: "18" + - name: yarn install + run: yarn + - name: yarn start:docker + run: yarn start:docker + - name: yarn build + run: yarn build + # Borrowed from https://github.com/DCFoundation/cosmos-proposal-builder/blob/main/.github/workflows/pr.yml#L43-L61 + - name: Wait for Docker container to be ready + run: | + timeout 300 bash -c ' + TARGET_HEIGHT=1111 + SLEEP=10 + echo "Waiting for the Agoric service to be fully ready..." + echo "Target block height: $TARGET_HEIGHT" + while true; do + response=$(curl --silent http://localhost:26657/abci_info); + height=$(echo $response | jq -r ".result.response.last_block_height | tonumber"); + if [ "$height" -ge $TARGET_HEIGHT ]; then + echo "Service is ready! Last block height: $height"; + break; + else + echo "Waiting for last block height to reach $TARGET_HEIGHT. Current height: $height"; + fi; + sleep $SLEEP; + done + ' + - name: yarn start:contract + run: yarn start:contract + - name: verify contracts started onchain + run: | + curl http://localhost:1317/agoric/vstorage/data/published.agoricNames.instance | grep sellConcertTickets + curl http://localhost:1317/agoric/vstorage/data/published.agoricNames.instance | grep postalService