From 876951d4553c1a4876f06b753e7a533a20baa5a8 Mon Sep 17 00:00:00 2001 From: StephenHeaps <5314553+StephenHeaps@users.noreply.github.com> Date: Wed, 10 Jan 2024 15:02:34 -0500 Subject: [PATCH] Fix #8603: Jupiter v4 to v6 migration & BraveCore bump to v1.63.107 (#8633) * Update `SwapTokenStore` & `SwapTokenStoreTests` for Jupiter v6 changes. * Update BraveCore to v1.63.107 --- .../Crypto/Stores/SwapTokenStore.swift | 26 ++++------- .../SwapTokenStoreTests.swift | 46 +++++++++++-------- 2 files changed, 36 insertions(+), 36 deletions(-) diff --git a/Sources/BraveWallet/Crypto/Stores/SwapTokenStore.swift b/Sources/BraveWallet/Crypto/Stores/SwapTokenStore.swift index c9d869850b5..2b865effb23 100644 --- a/Sources/BraveWallet/Crypto/Stores/SwapTokenStore.swift +++ b/Sources/BraveWallet/Crypto/Stores/SwapTokenStore.swift @@ -687,20 +687,19 @@ public class SwapTokenStore: ObservableObject, WalletObserverStore { _ response: BraveWallet.JupiterQuote, swapQuoteParams: BraveWallet.SwapQuoteParams ) async { - guard let route = response.routes.first else { return } self.jupiterQuote = response let formatter = WeiFormatter(decimalFormatStyle: .balance) if let selectedToToken { - buyAmount = formatter.decimalString(for: "\(route.otherAmountThreshold)", radix: .decimal, decimals: Int(selectedToToken.decimals)) ?? "" + buyAmount = formatter.decimalString(for: response.outAmount, radix: .decimal, decimals: Int(selectedToToken.decimals)) ?? "" } // No exchange rate is returned by Jupiter API, so we estimate it from the quote. if let selectedFromToken, - let newFromAmount = formatter.decimalString(for: "\(route.inAmount)", radix: .decimal, decimals: Int(selectedFromToken.decimals)), + let newFromAmount = formatter.decimalString(for: response.inAmount, radix: .decimal, decimals: Int(selectedFromToken.decimals)), let newFromAmountWrapped = BDouble(newFromAmount), let selectedToToken, - let newToAmount = formatter.decimalString(for: "\(route.otherAmountThreshold)", radix: .decimal, decimals: Int(selectedToToken.decimals)), + let newToAmount = formatter.decimalString(for: response.outAmount, radix: .decimal, decimals: Int(selectedToToken.decimals)), let newToAmountWrapped = BDouble(newToAmount), newFromAmountWrapped != 0 { let rate = newToAmountWrapped / newFromAmountWrapped @@ -742,25 +741,20 @@ public class SwapTokenStore: ObservableObject, WalletObserverStore { @MainActor private func createSolSwapTransaction() async -> Bool { guard let jupiterQuote, - let route = jupiterQuote.routes.first, - let accountInfo = self.accountInfo, - let selectedToToken, - let selectedFromToken else { + let accountInfo = self.accountInfo else { return false } self.isMakingTx = true defer { self.isMakingTx = false } let network = await rpcService.network(.sol, origin: nil) - let jupiterSwapParams: BraveWallet.JupiterTransactionParams = .init( + let jupiterTransactionParams: BraveWallet.JupiterTransactionParams = .init( + quote: jupiterQuote, chainId: network.chainId, - route: route, - userPublicKey: accountInfo.address, - inputMint: selectedFromToken.contractAddress(in: network), - outputMint: selectedToToken.contractAddress(in: network) + userPublicKey: accountInfo.address ) - let (swapTransactionsUnion, errorResponseUnion, _) = await swapService.transaction(.init(jupiterTransactionParams: jupiterSwapParams)) - guard let swapTransactions = swapTransactionsUnion?.jupiterTransaction else { + let (swapTransactionUnion, errorResponseUnion, _) = await swapService.transaction(.init(jupiterTransactionParams: jupiterTransactionParams)) + guard let jupiterTransaction = swapTransactionUnion?.jupiterTransaction else { // check balance first because error can cause by insufficient balance if let sellTokenBalance = self.selectedFromTokenBalance, let sellAmountValue = BDouble(self.sellAmount.normalizedDecimals), @@ -777,7 +771,7 @@ public class SwapTokenStore: ObservableObject, WalletObserverStore { return false } let (solTxData, status, _) = await solTxManagerProxy.makeTxData( - fromBase64EncodedTransaction: swapTransactions, + fromBase64EncodedTransaction: jupiterTransaction, txType: .solanaSwap, send: .init( maxRetries: .init(maxRetries: 2), diff --git a/Tests/BraveWalletTests/SwapTokenStoreTests.swift b/Tests/BraveWalletTests/SwapTokenStoreTests.swift index 15e36569990..8c7fb8c1d83 100644 --- a/Tests/BraveWalletTests/SwapTokenStoreTests.swift +++ b/Tests/BraveWalletTests/SwapTokenStoreTests.swift @@ -440,19 +440,22 @@ class SwapStoreTests: XCTestCase { network: .mockSolana, coin: .sol ) - swapService._quote = { jupiterQuoteParams, completion in + swapService._quote = { swapQuoteParams, completion in // verify 0.005 is converted to 0.5 - XCTAssertEqual(jupiterQuoteParams.slippagePercentage, "0.5") - let route: BraveWallet.JupiterRoute = .init( - inAmount: 10000000, // 0.01 SOL (9 decimals) - outAmount: 2500000, // 2.5 SPD (6 decimals) - amount: 2500000, // 2.5 SPD (6 decimals) - otherAmountThreshold: 2500000, // 2.5 SPD (6 decimals) + XCTAssertEqual(swapQuoteParams.slippagePercentage, "0.5") + let jupiterQuote: BraveWallet.JupiterQuote = .init( + inputMint: BraveWallet.BlockchainToken.mockSolToken.contractAddress, + inAmount: "10000000", // 0.01 SOL (9 decimals) + outputMint: BraveWallet.BlockchainToken.mockSpdToken.contractAddress, + outAmount: "2500000", // 2.5 SPD (6 decimals) + otherAmountThreshold: "2500000", // 2.5 SPD (6 decimals) swapMode: "", - priceImpactPct: 0, - slippageBps: 50, // 0.5% - marketInfos: []) - completion(.init(jupiterQuote: .init(routes: [route])), nil, "") + slippageBps: "50", // 0.5% + platformFee: nil, + priceImpactPct: "0", + routePlan: [] + ) + completion(.init(jupiterQuote: jupiterQuote), nil, "") } swapService._braveFee = { params, completion in let feeResponse = BraveWallet.BraveSwapFeeResponse( @@ -697,15 +700,18 @@ class SwapStoreTests: XCTestCase { /// Test creating a sol swap transaction @MainActor func testSwapSolSwapTransaction() async { - let route: BraveWallet.JupiterRoute = .init( - inAmount: 3000000000, - outAmount: 2500000, // 2.5 SPD (6 decimals) - amount: 2500000, // 2.5 SPD (6 decimals) - otherAmountThreshold: 2500000, // 2.5 SPD (6 decimals) + let jupiterQuote: BraveWallet.JupiterQuote = .init( + inputMint: BraveWallet.BlockchainToken.mockSolToken.contractAddress, + inAmount: "3000000000", + outputMint: BraveWallet.BlockchainToken.mockSpdToken.contractAddress, + outAmount: "2500000", // 2.5 SPD (6 decimals) + otherAmountThreshold: "2500000", // 2.5 SPD (6 decimals) swapMode: "", - priceImpactPct: 0, - slippageBps: 50, // 0.5% - marketInfos: []) + slippageBps: "50", // 0.5% + platformFee: nil, + priceImpactPct: "0", + routePlan: [] + ) let (keyringService, blockchainRegistry, rpcService, swapService, txService, walletService, ethTxManagerProxy, solTxManagerProxy, mockAssetManager) = setupServices( network: .mockSolana, coin: .sol @@ -738,7 +744,7 @@ class SwapStoreTests: XCTestCase { selectedFromToken: .mockSolToken, selectedToToken: .mockSpdToken, sellAmount: "0.01", - jupiterQuote: .init(routes: [route]) + jupiterQuote: jupiterQuote ) store.state = .swap