forked from MystenLabs/sui
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Enable e2e test against devent and testnet branch (MystenLabs#7800)
- Added CI workflow to verify that the TypeScript/Explorer/Rust changes are compatible with TestNet and DevNet branch - Edited the existing localnet e2e tests for Explorer and wallet: previously we only run Explorer/Wallet test when there is a rust change or an Explorer/Wallet change, now the test will also run when there's a TypeScript change(since TS change can also break Explorer). - Fixed some backward incompatibility on the SDK and Explorer side with the testnet branch
- Loading branch information
Showing
9 changed files
with
151 additions
and
24 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,9 +4,10 @@ jobs: | |
diff: | ||
runs-on: ubuntu-latest | ||
outputs: | ||
isWallet: ${{ (steps.turbo.outputs.packages && contains(fromJson(steps.turbo.outputs.packages), 'sui-wallet')) || steps.diff.outputs.isRust }} | ||
isExplorer: ${{ (steps.turbo.outputs.packages && contains(fromJson(steps.turbo.outputs.packages), 'sui-explorer')) || steps.diff.outputs.isRust }} | ||
isTypescriptSDK: ${{ (steps.turbo.outputs.packages && contains(fromJson(steps.turbo.outputs.packages), '@mysten/sui.js')) || steps.diff.outputs.isRust }} | ||
isWallet: ${{ (steps.turbo.outputs.packages && contains(fromJson(steps.turbo.outputs.packages), 'sui-wallet')) }} | ||
isExplorer: ${{ (steps.turbo.outputs.packages && contains(fromJson(steps.turbo.outputs.packages), 'sui-explorer')) }} | ||
isTypescriptSDK: ${{ (steps.turbo.outputs.packages && contains(fromJson(steps.turbo.outputs.packages), '@mysten/sui.js')) }} | ||
isRust: ${{ steps.diff.outputs.isRust }} | ||
steps: | ||
- uses: actions/checkout@7dd9e2a3dc350cf687eb1b2a4fadfee8c8e49675 # pin@v3 | ||
- name: Detect Changes (turbo) | ||
|
@@ -16,10 +17,11 @@ jobs: | |
uses: "./.github/actions/diffs" | ||
id: diff | ||
|
||
# Run e2e test against localnet built on the main branch | ||
localnet: | ||
name: Localnet | ||
needs: diff | ||
if: needs.diff.outputs.isExplorer == 'true' || needs.diff.outputs.isTypescriptSDK == 'true' || needs.diff.outputs.isWallet == 'true' | ||
if: needs.diff.outputs.isExplorer == 'true' || needs.diff.outputs.isTypescriptSDK == 'true' || needs.diff.outputs.isWallet == 'true' || needs.diff.outputs.isRust == 'true' | ||
runs-on: ubuntu-ghcloud | ||
steps: | ||
- uses: actions/checkout@7dd9e2a3dc350cf687eb1b2a4fadfee8c8e49675 # pin@v3 | ||
|
@@ -40,11 +42,12 @@ jobs: | |
run: pnpm explorer playwright install --with-deps chromium | ||
|
||
- name: Run TS SDK e2e tests | ||
if: ${{ needs.diff.outputs.isTypescriptSDK == 'true' }} | ||
if: ${{ needs.diff.outputs.isTypescriptSDK == 'true' || needs.diff.outputs.isRust == 'true'}} | ||
run: pnpm dlx concurrently --kill-others --success command-1 'RUST_LOG="consensus=off" cargo run --bin sui-test-validator' 'pnpm sdk test:e2e' | ||
|
||
- name: Run Explorer e2e tests | ||
if: ${{ needs.diff.outputs.isExplorer == 'true' }} | ||
# need to run Explorer e2e when its upstream(TS SDK and Rust) or itself is changed | ||
if: ${{ needs.diff.outputs.isTypescriptSDK == 'true' || needs.diff.outputs.isExplorer == 'true' || needs.diff.outputs.isRust == 'true'}} | ||
run: pnpm explorer playwright test | ||
- uses: actions/upload-artifact@v3 | ||
if: always() | ||
|
@@ -54,14 +57,123 @@ jobs: | |
retention-days: 30 | ||
|
||
- name: Build Wallet | ||
if: ${{ needs.diff.outputs.isWallet == 'true' }} | ||
# need to run Wallet e2e when its upstream(TS SDK and Rust) or itself is changed | ||
if: ${{ needs.diff.outputs.isWallet == 'true' || needs.diff.outputs.isRust == 'true' || needs.diff.outputs.isTypescriptSDK == 'true'}} | ||
run: pnpm wallet build | ||
- name: Run Wallet e2e tests | ||
if: ${{ needs.diff.outputs.isWallet == 'true' }} | ||
if: ${{ needs.diff.outputs.isWallet == 'true' || needs.diff.outputs.isRust == 'true' || needs.diff.outputs.isTypescriptSDK == 'true'}} | ||
run: xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- pnpm wallet playwright test | ||
- uses: actions/upload-artifact@v3 | ||
if: always() | ||
with: | ||
name: playwright-report-wallet | ||
path: apps/wallet/playwright-report/ | ||
retention-days: 30 | ||
|
||
# Run e2e test against localnet built on the devnet branch for backward compatibility check | ||
local_devnet_branch: | ||
name: Local Network Built on devnet branch | ||
needs: diff | ||
# TODO: add wallet e2e to the `if` condition when available | ||
if: needs.diff.outputs.isExplorer == 'true' || needs.diff.outputs.isTypescriptSDK == 'true' | ||
runs-on: ubuntu-ghcloud | ||
steps: | ||
# checkout the devnet branch | ||
- uses: actions/checkout@7dd9e2a3dc350cf687eb1b2a4fadfee8c8e49675 # pin@v3 | ||
with: | ||
ref: devnet | ||
- uses: actions-rs/toolchain@16499b5e05bf2e26879000db0c1d13f7e13fa3af # pin@v1 | ||
- uses: bmwill/rust-cache@v1 # Fork of 'Swatinem/rust-cache' which allows caching additional paths | ||
- uses: pnpm/action-setup@c3b53f6a16e57305370b4ae5a540c2077a1d50dd # [email protected] | ||
with: | ||
version: 7 | ||
- run: cargo build --bin sui-test-validator --bin sui --profile dev | ||
|
||
# checkout the current branch | ||
- uses: actions/checkout@7dd9e2a3dc350cf687eb1b2a4fadfee8c8e49675 # pin@v3 | ||
with: | ||
clean: false | ||
|
||
- name: Install Nodejs | ||
uses: actions/setup-node@8c91899e586c5b171469028077307d293428b516 # pin@v3 | ||
with: | ||
node-version: "18" | ||
cache: "pnpm" | ||
- name: Install dependencies | ||
run: pnpm install --frozen-lockfile | ||
- name: Install Playwright Browsers | ||
run: pnpm explorer playwright install --with-deps chromium | ||
|
||
- name: Set env | ||
run: echo "E2E_RUN_LOCAL_NET_CMD=(RUST_LOG=\"consensus=off\" $(echo $PWD/target/debug/sui-test-validator))" >> $GITHUB_ENV | ||
|
||
- name: Run TS SDK e2e tests | ||
if: ${{ needs.diff.outputs.isTypescriptSDK == 'true' }} | ||
run: pnpm dlx concurrently --kill-others --success command-1 "$E2E_RUN_LOCAL_NET_CMD" 'pnpm sdk test:e2e' | ||
|
||
- name: Run Explorer e2e tests | ||
if: ${{ needs.diff.outputs.isExplorer == 'true' || needs.diff.outputs.isTypescriptSDK == 'true'}} | ||
run: pnpm explorer playwright test | ||
|
||
# TODO: add wallet e2e when available | ||
|
||
- uses: actions/upload-artifact@v3 | ||
if: always() | ||
with: | ||
name: playwright-report-explorer | ||
path: apps/explorer/playwright-report/ | ||
retention-days: 30 | ||
|
||
# Run e2e test against localnet built on the Testnet branch for backward compatibility check | ||
local_testnet_branch: | ||
name: Local Network Built on testnet branch | ||
needs: diff | ||
# TODO: add wallet e2e to the `if` condition when available | ||
if: needs.diff.outputs.isExplorer == 'true' || needs.diff.outputs.isTypescriptSDK == 'true' | ||
runs-on: ubuntu-ghcloud | ||
steps: | ||
# checkout the testnet branch | ||
- uses: actions/checkout@7dd9e2a3dc350cf687eb1b2a4fadfee8c8e49675 # pin@v3 | ||
with: | ||
ref: testnet | ||
- uses: actions-rs/toolchain@16499b5e05bf2e26879000db0c1d13f7e13fa3af # pin@v1 | ||
- uses: bmwill/rust-cache@v1 # Fork of 'Swatinem/rust-cache' which allows caching additional paths | ||
- uses: pnpm/action-setup@c3b53f6a16e57305370b4ae5a540c2077a1d50dd # [email protected] | ||
with: | ||
version: 7 | ||
- run: cargo build --bin sui-test-validator --bin sui --profile dev | ||
|
||
# checkout the current branch | ||
- uses: actions/checkout@7dd9e2a3dc350cf687eb1b2a4fadfee8c8e49675 # pin@v3 | ||
with: | ||
clean: false | ||
|
||
- name: Install Nodejs | ||
uses: actions/setup-node@8c91899e586c5b171469028077307d293428b516 # pin@v3 | ||
with: | ||
node-version: "18" | ||
cache: "pnpm" | ||
- name: Install dependencies | ||
run: pnpm install --frozen-lockfile | ||
- name: Install Playwright Browsers | ||
run: pnpm explorer playwright install --with-deps chromium | ||
|
||
- name: Set env | ||
run: echo "E2E_RUN_LOCAL_NET_CMD=(RUST_LOG="consensus=off "$(echo $PWD/target/debug/sui-test-validator))" >> $GITHUB_ENV | ||
|
||
- name: Run TS SDK e2e tests | ||
if: ${{ needs.diff.outputs.isTypescriptSDK == 'true' }} | ||
run: pnpm dlx concurrently --kill-others --success command-1 "$E2E_RUN_LOCAL_NET_CMD" 'pnpm sdk test:e2e' | ||
|
||
- name: Run Explorer e2e tests | ||
if: ${{ needs.diff.outputs.isExplorer == 'true' || needs.diff.outputs.isTypescriptSDK == 'true'}} | ||
run: pnpm explorer playwright test | ||
|
||
# TODO: add wallet e2e when available | ||
|
||
- uses: actions/upload-artifact@v3 | ||
if: always() | ||
with: | ||
name: playwright-report-explorer | ||
path: apps/explorer/playwright-report/ | ||
retention-days: 30 |
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
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
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
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
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
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
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
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