From f57a4359d0ecbc5121a3f78bd5f4311543c99470 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Wiktor=20Tkaczy=C5=84ski?= Date: Sat, 16 Nov 2024 17:26:50 +0100 Subject: [PATCH] test: improve speed of starknet integration tests 10x (#981) The issue is with starknetjs implementation of waitForTransaction, that will always take at least 10s with default settings. We can improve it a lot by just decreasing intervals. https://github.com/starknet-io/starknet.js/issues/1237#issuecomment-2475861985 --- .../test/integration/starknet/index.test.ts | 30 ++++++++++++++----- .../sx.js/test/integration/starknet/utils.ts | 4 +++ 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/packages/sx.js/test/integration/starknet/index.test.ts b/packages/sx.js/test/integration/starknet/index.test.ts index 201bd0d8f..6538a6a2e 100644 --- a/packages/sx.js/test/integration/starknet/index.test.ts +++ b/packages/sx.js/test/integration/starknet/index.test.ts @@ -10,6 +10,7 @@ import { increaseTime, setTime, setup, + sleep, TestConfig } from './utils'; import { @@ -36,7 +37,10 @@ describe('sx-starknet', () => { const privateKey = '0x9c7d498a8f76dc87564274036988f668'; const starkProvider = new RpcProvider({ - nodeUrl: 'http://127.0.0.1:5050/rpc' + nodeUrl: 'http://127.0.0.1:5050/rpc', + // default is 5s and for some reason each call with call it 2 times (one before looking for receipt, and once after) + // this way it's quick (20s instead of 9 minutes) + transactionRetryIntervalFallback: 100 }); const provider = new JsonRpcProvider(ethUrl); @@ -145,7 +149,8 @@ describe('sx-starknet', () => { } ], proposal: 1, - choice: Choice.For + choice: Choice.For, + metadataUri: '' } }; @@ -197,7 +202,8 @@ describe('sx-starknet', () => { } ], proposal: 2, - choice: Choice.For + choice: Choice.For, + metadataUri: '' }; const envelope = await ethSigClient.vote({ signer: wallet, data }); @@ -256,7 +262,8 @@ describe('sx-starknet', () => { } ], proposal: 3, - choice: Choice.For + choice: Choice.For, + metadataUri: '' }; await ethTxClient.initializeVote(wallet, data); @@ -315,7 +322,8 @@ describe('sx-starknet', () => { } ], proposal: 4, - choice: Choice.For + choice: Choice.For, + metadataUri: '' }; const envelope = await starkSigClient.vote({ signer: account, data }); @@ -375,7 +383,8 @@ describe('sx-starknet', () => { } ], proposal: 5, - choice: Choice.For + choice: Choice.For, + metadataUri: '' } }; @@ -436,7 +445,8 @@ describe('sx-starknet', () => { } ], proposal: 6, - choice: Choice.For + choice: Choice.For, + metadataUri: '' } }; @@ -495,10 +505,14 @@ describe('sx-starknet', () => { } ], proposal: 7, - choice: Choice.For + choice: Choice.For, + metadataUri: '' } }; + // NOTE: to avoid Votes: future lookup + await sleep(10000); + const receipt = await client.vote(account, envelope); console.log('Receipt', receipt); diff --git a/packages/sx.js/test/integration/starknet/utils.ts b/packages/sx.js/test/integration/starknet/utils.ts index 24479bf48..33d20e250 100644 --- a/packages/sx.js/test/integration/starknet/utils.ts +++ b/packages/sx.js/test/integration/starknet/utils.ts @@ -539,3 +539,7 @@ export function loadL1MessagingContract(networkUrl: string, address: string) { export function flush() { return postDevnet('postman/flush', {}); } + +export function sleep(ms: number) { + return new Promise(resolve => setTimeout(resolve, ms)); +}