From df2f48008da940615bec8fb6665b17b7c1bb5878 Mon Sep 17 00:00:00 2001 From: Arvin <17693119+vindard@users.noreply.github.com> Date: Tue, 2 Jan 2024 16:02:28 -0400 Subject: [PATCH] test(core): move 01-setup steps to hedge tests (#3711) * test(core): add bootstrap steps to hedge tests * test(core): remove non-needed bootstrap deps from hedge test * chore(core): remove legacy 01-setup integration tests * refactor(core): make hedge tests re-runnable * test(core): skip non-effective routing fees test --- core/api/test/helpers/bitcoin-core.ts | 14 ++ .../test/integration/services/bria.spec.ts | 15 +- .../01-setup/01-funds-bitcoind-lnds.spec.ts | 100 ----------- .../01-setup/01-lightning-channels.spec.ts | 155 ------------------ .../services/dealer/hedge-price.spec.ts | 66 +++++++- .../services/lnd/utils.spec.ts | 5 +- 6 files changed, 84 insertions(+), 271 deletions(-) delete mode 100644 core/api/test/legacy-integration/01-setup/01-funds-bitcoind-lnds.spec.ts delete mode 100644 core/api/test/legacy-integration/01-setup/01-lightning-channels.spec.ts diff --git a/core/api/test/helpers/bitcoin-core.ts b/core/api/test/helpers/bitcoin-core.ts index c253553c7f..23bb80bad5 100644 --- a/core/api/test/helpers/bitcoin-core.ts +++ b/core/api/test/helpers/bitcoin-core.ts @@ -166,3 +166,17 @@ const getBitcoindSignerClient = (walletName?: string) => { walletName, }) } + +export const loadBitcoindWallet = async (walletName: string) => { + const wallets = await bitcoindClient.listWallets() + if (!wallets.includes(walletName)) { + try { + await bitcoindClient.createWallet({ walletName }) + } catch (err) { + const error = err as Error + if (error.message.includes("Database already exists")) { + await bitcoindClient.loadWallet({ filename: walletName }) + } + } + } +} diff --git a/core/api/test/integration/services/bria.spec.ts b/core/api/test/integration/services/bria.spec.ts index 7c4ed789cf..f5278b04ca 100644 --- a/core/api/test/integration/services/bria.spec.ts +++ b/core/api/test/integration/services/bria.spec.ts @@ -13,6 +13,7 @@ import { createMandatoryUsers, createUserAndWalletFromPhone, getDefaultWalletIdByPhone, + loadBitcoindWallet, mineAndConfirm, randomPhone, sendToAddressAndConfirm, @@ -25,20 +26,6 @@ const TIMEOUT_BRIA_EVENT = 60_000 const phone = randomPhone() -const loadBitcoindWallet = async (walletName: string) => { - const wallets = await bitcoindClient.listWallets() - if (!wallets.includes(walletName)) { - try { - await bitcoindClient.createWallet({ walletName }) - } catch (err) { - const error = err as Error - if (error.message.includes("Database already exists")) { - await bitcoindClient.loadWallet({ filename: walletName }) - } - } - } -} - const fundOutsideOnChainWallet = async () => { // Setup outside bitcoind const walletName = "outside" diff --git a/core/api/test/legacy-integration/01-setup/01-funds-bitcoind-lnds.spec.ts b/core/api/test/legacy-integration/01-setup/01-funds-bitcoind-lnds.spec.ts deleted file mode 100644 index bd7c1fb574..0000000000 --- a/core/api/test/legacy-integration/01-setup/01-funds-bitcoind-lnds.spec.ts +++ /dev/null @@ -1,100 +0,0 @@ -import { btc2sat, sat2btc } from "@/domain/bitcoin" -import { getFunderWalletId } from "@/services/ledger/caching" - -import { - bitcoindClient, - bitcoindSignerClient, - checkIsBalanced, - createMandatoryUsers, - createSignerWallet, - fundLnd, - fundWalletIdFromOnchain, - getChainBalance, - lnd1, - lndOutside1, - mineAndConfirm, - resetLegacyIntegrationLnds, -} from "test/helpers" -import { BitcoindWalletClient } from "test/helpers/bitcoind" - -let bitcoindOutside: BitcoindWalletClient - -beforeAll(async () => { - await createMandatoryUsers() - await resetLegacyIntegrationLnds() -}) - -afterAll(async () => { - await bitcoindClient.unloadWallet({ walletName: "outside" }) -}) - -afterEach(async () => { - await checkIsBalanced() -}) - -describe("Bitcoind", () => { - it("check no wallet", async () => { - const wallets = await bitcoindClient.listWallets() - expect(wallets.length).toBe(0) - }) - - it("create signer wallet for bria", async () => { - const walletName = "dev" - const { name } = await createSignerWallet(walletName) - expect(name).toBe(walletName) - - const wallets = await bitcoindSignerClient.listWallets() - expect(wallets).toContain(walletName) - }) - - it("create outside wallet", async () => { - const walletName = "outside" - const { name } = await bitcoindClient.createWallet({ walletName }) - expect(name).toBe(walletName) - const wallets = await bitcoindClient.listWallets() - expect(wallets).toContain(walletName) - bitcoindOutside = new BitcoindWalletClient(walletName) - }) - - it("should be funded mining 10 blocks", async () => { - const numOfBlocks = 10 - const bitcoindAddress = await bitcoindOutside.getNewAddress() - await mineAndConfirm({ - walletClient: bitcoindOutside, - numOfBlocks, - address: bitcoindAddress, - }) - const balance = await bitcoindOutside.getBalance() - expect(balance).toBeGreaterThanOrEqual(50 * numOfBlocks) - }) - - it("funds outside lnd node", async () => { - const outsideLnds = [lndOutside1] - for (const lnd of outsideLnds) { - const amount = btc2sat(1) - const { chain_balance: initialBalance } = await getChainBalance({ - lnd, - }) - const sats = initialBalance + amount - await fundLnd(lnd, sat2btc(amount)) - const { chain_balance: balance } = await getChainBalance({ lnd }) - expect(balance).toBe(sats) - } - }) - - it("funds lnd1 node", async () => { - const amount = btc2sat(1) - const { chain_balance: initialBalance } = await getChainBalance({ lnd: lnd1 }) - const sats = initialBalance + amount - - const funderWalletId = await getFunderWalletId() - await fundWalletIdFromOnchain({ - walletId: funderWalletId, - amountInBitcoin: sat2btc(amount), - lnd: lnd1, - }) - - const { chain_balance: balance } = await getChainBalance({ lnd: lnd1 }) - expect(balance).toBe(sats) - }) -}) diff --git a/core/api/test/legacy-integration/01-setup/01-lightning-channels.spec.ts b/core/api/test/legacy-integration/01-setup/01-lightning-channels.spec.ts deleted file mode 100644 index 8a999a3457..0000000000 --- a/core/api/test/legacy-integration/01-setup/01-lightning-channels.spec.ts +++ /dev/null @@ -1,155 +0,0 @@ -import { ledgerAdmin } from "@/services/mongodb" -import { sleep } from "@/utils" - -import { - checkIsBalanced, - getChannel, - getChannels, - lnd1, - lnd2, - lndOutside1, - lndOutside2, - openChannelTesting, - setChannelFees, - waitUntilSync, -} from "test/helpers" - -//this is the fixed opening and closing channel fee on devnet -const channelFee = 7700 -const lnds = [lnd1, lnd2, lndOutside1, lndOutside1] -let channelLengthMain: number, channelLengthOutside1: number - -beforeEach(async () => { - await waitUntilSync({ lnds }) - channelLengthMain = (await getChannels({ lnd: lnd1 })).channels.length - channelLengthOutside1 = (await getChannels({ lnd: lndOutside1 })).channels.length -}) - -afterEach(async () => { - await checkIsBalanced() -}) - -// Setup the next network -// lnd2 <- lnd1 <-> lndOutside1 -> lndOutside2 -// this setup avoids close channels for routing fees tests -describe("Lightning channels", () => { - it("opens channel from lnd1 to lnd2", async () => { - const socket = `lnd2:9735` - const { lndNewChannel: channel } = await openChannelTesting({ - lnd: lnd1, - lndPartner: lnd2, - socket, - }) - - const { channels } = await getChannels({ lnd: lnd1 }) - expect(channels.length).toEqual(channelLengthMain + 1) - - // @ts-ignore-next-line no-implicit-any error - await setChannelFees({ lnd: lnd1, channel, base: 0, rate: 0 }) - // @ts-ignore-next-line no-implicit-any error - await setChannelFees({ lnd: lnd2, channel, base: 0, rate: 0 }) - }) - - it("opens channel from lnd1 to lndOutside1", async () => { - const socket = `lnd-outside-1:9735` - - const initFeeInLedger = await ledgerAdmin.getBankOwnerBalance() - - const { lndNewChannel: channel } = await openChannelTesting({ - lnd: lnd1, - lndPartner: lndOutside1, - socket, - }) - - const { channels } = await getChannels({ lnd: lnd1 }) - expect(channels.length).toEqual(channelLengthMain + 1) - - const finalFeeInLedger = await ledgerAdmin.getBankOwnerBalance() - expect(finalFeeInLedger - initFeeInLedger).toBe(channelFee * -1) - - // @ts-ignore-next-line no-implicit-any error - await setChannelFees({ lnd: lnd1, channel, base: 1, rate: 0 }) - // @ts-ignore-next-line no-implicit-any error - await setChannelFees({ lnd: lndOutside1, channel, base: 1, rate: 0 }) - }) - - it("opens channel from lndOutside1 to lnd1", async () => { - const socket = `lnd1:9735` - - const { lndNewChannel: channel } = await openChannelTesting({ - lnd: lndOutside1, - lndPartner: lnd1, - socket, - }) - - const { channels } = await getChannels({ lnd: lnd1 }) - expect(channels.length).toEqual(channelLengthMain + 1) - - // @ts-ignore-next-line no-implicit-any error - await setChannelFees({ lnd: lnd1, channel, base: 1, rate: 0 }) - // @ts-ignore-next-line no-implicit-any error - await setChannelFees({ lnd: lndOutside1, channel, base: 1, rate: 0 }) - }) - - it("opens private channel from lndOutside1 to lndOutside2", async () => { - const socket = `lnd-outside-2:9735` - - const { lndNewChannel: channel } = await openChannelTesting({ - lnd: lndOutside1, - lndPartner: lndOutside2, - socket, - is_private: true, - }) - - const { channels } = await getChannels({ lnd: lndOutside1 }) - expect(channels.length).toEqual(channelLengthOutside1 + 1) - expect(channels.some((e) => e.is_private)).toBe(true) - - // Set fee policy on lndOutside1 as routing node between lnd1 and lndOutside2 - let count = 0 - let countMax = 9 - let setOnLndOutside1 - while (count < countMax && setOnLndOutside1 !== true) { - if (count > 0) await sleep(500) - count++ - - setOnLndOutside1 = await setChannelFees({ - lnd: lndOutside1, - // @ts-ignore-next-line no-implicit-any error - channel, - base: 0, - rate: 5000, - }) - } - expect(count).toBeGreaterThan(0) - expect(count).toBeLessThan(countMax) - expect(setOnLndOutside1).toBe(true) - - let policies - let errMsg: string | undefined = "FullChannelDetailsNotFound" - count = 0 - countMax = 8 - // Try to getChannel for up to 2 secs (250ms x 8) - while (count < countMax && errMsg === "FullChannelDetailsNotFound") { - count++ - await sleep(250) - try { - /* eslint @typescript-eslint/ban-ts-comment: "off" */ - // @ts-ignore-next-line no-implicit-any error - ;({ policies } = await getChannel({ id: channel.id, lnd: lndOutside1 })) - errMsg = undefined - } catch (err) { - if (Array.isArray(err)) errMsg = err[1] - } - } - expect(count).toBeGreaterThan(0) - expect(count).toBeLessThan(countMax) - expect(errMsg).not.toBe("FullChannelDetailsNotFound") - expect(policies && policies.length).toBeGreaterThan(0) - - // @ts-ignore-next-line no-implicit-any error - const { base_fee_mtokens, fee_rate } = policies[0] - expect(base_fee_mtokens).toBe("0") - expect(fee_rate).toEqual(5000) - }) -}) diff --git a/core/api/test/legacy-integration/services/dealer/hedge-price.spec.ts b/core/api/test/legacy-integration/services/dealer/hedge-price.spec.ts index 3fdacfb27f..b067c832df 100644 --- a/core/api/test/legacy-integration/services/dealer/hedge-price.spec.ts +++ b/core/api/test/legacy-integration/services/dealer/hedge-price.spec.ts @@ -10,10 +10,26 @@ import { paymentAmountFromNumber, WalletCurrency, } from "@/domain/shared" +import { getFunderWalletId } from "@/services/ledger/caching" import { baseLogger } from "@/services/logger" import { AccountsRepository, WalletsRepository } from "@/services/mongoose" -import { createAccount, fundWallet, getBalanceHelper } from "test/helpers" +import { + bitcoindClient, + bitcoindOutside, + createAccount, + createMandatoryUsers, + fundLnd, + fundWallet, + fundWalletIdFromOnchain, + getBalanceHelper, + lnd1, + lndOutside1, + loadBitcoindWallet, + mineAndConfirm, + openChannelTesting, + resetLegacyIntegrationLnds, +} from "test/helpers" class ZeroAmountForUsdRecipientError extends Error {} @@ -42,6 +58,54 @@ type AccountAndWallets = { newAccount: Account } +beforeAll(async () => { + await createMandatoryUsers() + await loadBitcoindWallet("outside") + await resetLegacyIntegrationLnds() + await bootstrapLndNodes() +}) + +afterAll(async () => { + await bitcoindClient.unloadWallet({ walletName: "outside" }) +}) + +const bootstrapLndNodes = async () => { + // Fund outside wallet to fund lnd nodes + const numOfBlocks = 10 + const bitcoindAddress = await bitcoindOutside.getNewAddress() + await mineAndConfirm({ + walletClient: bitcoindOutside, + numOfBlocks, + address: bitcoindAddress, + }) + + // Fund lndOutside1 node, open lndOutside1 -> lnd1 channel + const amountInBitcoin = 1 + await fundLnd(lndOutside1, amountInBitcoin) + + const lnd1Socket = `lnd1:9735` + await openChannelTesting({ + lnd: lndOutside1, + lndPartner: lnd1, + socket: lnd1Socket, + }) + + // Fund lnd1 node, open lnd1 -> lndOutside1 channel + const funderWalletId = await getFunderWalletId() + await fundWalletIdFromOnchain({ + walletId: funderWalletId, + amountInBitcoin, + lnd: lnd1, + }) + + const lndOutside1socket = `lnd-outside-1:9735` + await openChannelTesting({ + lnd: lnd1, + lndPartner: lndOutside1, + socket: lndOutside1socket, + }) +} + const btcAmountFromUsdNumber = async ( centsAmount: number | bigint, ): Promise => { diff --git a/core/api/test/legacy-integration/services/lnd/utils.spec.ts b/core/api/test/legacy-integration/services/lnd/utils.spec.ts index effc95de49..dc01ce71e9 100644 --- a/core/api/test/legacy-integration/services/lnd/utils.spec.ts +++ b/core/api/test/legacy-integration/services/lnd/utils.spec.ts @@ -80,7 +80,10 @@ describe("lndUtils", () => { } }) - it("sets routing fee correctly", async () => { + it.skip("sets routing fee correctly", async () => { + // Skipped because this test is already broken. lndOutside1 and lndOutside2 + // are directly connected and routing fees are 0. + const { request } = await createInvoice({ lnd: lndOutside2, tokens: 10000 }) const initBalance = await ledgerAdmin.getBankOwnerBalance()