From 7c630b82cd01d82f454bf2e14badb0a2e03e8399 Mon Sep 17 00:00:00 2001 From: woodser Date: Tue, 31 May 2022 14:05:31 -0400 Subject: [PATCH] fix unintended mining when funding outputs --- src/HavenoClient.test.ts | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/HavenoClient.test.ts b/src/HavenoClient.test.ts index 52e7d35e..936d2c73 100644 --- a/src/HavenoClient.test.ts +++ b/src/HavenoClient.test.ts @@ -1940,7 +1940,7 @@ async function waitForUnlockedTxs(...txHashes: string[]) { } /** - * Indicates if the wallet has an unlocked amount. + * Indicates if the given wallets have unspent outputs. * * @param {MoneroWallet[]} wallets - wallets to check * @param {BigInt} amt - amount to check @@ -1976,6 +1976,7 @@ async function fundOutputs(wallets: any[], amt: bigint, numOutputs?: number, wai destinations.push(new MoneroDestination((await wallet.createSubaddress()).getAddress(), monerojs.BigInteger(amt.toString()))); } } + if (!destinations.length) return; // fund destinations let txConfig = new MoneroTxConfig().setAccountIndex(0).setRelay(true); @@ -1992,9 +1993,13 @@ async function fundOutputs(wallets: any[], amt: bigint, numOutputs?: number, wai } } + // wait for wallets to see transfers + await wait(TestConfig.walletSyncPeriodMs); + // mine until outputs unlock + if (!waitForUnlock) return; let miningStarted = false; - while (!await hasUnspentOutputs(wallets, amt, numOutputs, waitForUnlock ? false : undefined)) { + while (!await hasUnspentOutputs(wallets, amt, numOutputs, false)) { if (!miningStarted) { await startMining(); miningStarted = true;