From d7ec961cf46c29805147509d93ca1e69a5e06ba8 Mon Sep 17 00:00:00 2001 From: tyleroooo Date: Tue, 15 Oct 2024 18:06:59 -0400 Subject: [PATCH] fix: dust fix introduced bug when account isn't provided (#711) --- build.gradle.kts | 2 +- .../vault/VaultDepositWithdrawForm.kt | 21 +++++++-- .../functional/vault/VaultFormTests.kt | 43 +++++++++++++++++++ v4_abacus.podspec | 2 +- 4 files changed, 63 insertions(+), 5 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index 2809f2342..677a91213 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -52,7 +52,7 @@ allprojects { } group = "exchange.dydx.abacus" -version = "1.12.26" +version = "1.12.27" repositories { google() diff --git a/src/commonMain/kotlin/exchange.dydx.abacus/functional/vault/VaultDepositWithdrawForm.kt b/src/commonMain/kotlin/exchange.dydx.abacus/functional/vault/VaultDepositWithdrawForm.kt index 901465672..a4defabe7 100644 --- a/src/commonMain/kotlin/exchange.dydx.abacus/functional/vault/VaultDepositWithdrawForm.kt +++ b/src/commonMain/kotlin/exchange.dydx.abacus/functional/vault/VaultDepositWithdrawForm.kt @@ -268,9 +268,24 @@ object VaultDepositWithdrawFormValidator { val errors = mutableListOf() var submissionData: VaultDepositWithdrawSubmissionData? = null - // Calculate post-operation values and slippage - val sharesToAttemptWithdraw = calculateSharesToWithdraw(vaultAccount, formData.amount ?: 0.0) - val amount = sharesToAttemptWithdraw * (vaultAccount?.shareValue ?: 0.0) + val sharesToAttemptWithdraw = if (formData.action == VaultFormAction.WITHDRAW && + vaultAccount != null && + (vaultAccount.shareValue ?: 0.0) > 0.0 && + formData.amount != null + ) { + calculateSharesToWithdraw(vaultAccount, formData.amount) + } else { + null + } + + val amount = when (formData.action) { + VaultFormAction.DEPOSIT -> formData.amount ?: 0.0 + VaultFormAction.WITHDRAW -> if (sharesToAttemptWithdraw != null) { + sharesToAttemptWithdraw * (vaultAccount?.shareValue ?: 0.0) + } else { + formData.amount ?: 0.0 + } + } val withdrawnAmountIncludingSlippage = slippageResponse?.expectedQuoteQuantums?.let { it / 1_000_000.0 } val postOpVaultBalance = when (formData.action) { diff --git a/src/commonTest/kotlin/exchange.dydx.abacus/functional/vault/VaultFormTests.kt b/src/commonTest/kotlin/exchange.dydx.abacus/functional/vault/VaultFormTests.kt index 4577094e5..93ed1829e 100644 --- a/src/commonTest/kotlin/exchange.dydx.abacus/functional/vault/VaultFormTests.kt +++ b/src/commonTest/kotlin/exchange.dydx.abacus/functional/vault/VaultFormTests.kt @@ -360,6 +360,49 @@ class VaultFormTests { ) } + @Test + fun testDepositWithNoAccount() { + val result = VaultDepositWithdrawFormValidator.validateVaultForm( + formData = VaultFormData( + action = VaultFormAction.DEPOSIT, + amount = 100.0, + acknowledgedSlippage = true, + inConfirmationStep = true, + ), + accountData = VaultFormAccountData( + marginUsage = 0.5, + freeCollateral = 1000.0, + canViewAccount = true, + ), + // null vault account is expected on first deposit + vaultAccount = null, + slippageResponse = null, + ) + + assertEquals( + VaultFormValidationResult( + errors = listOf().toIList(), + submissionData = VaultDepositWithdrawSubmissionData( + deposit = VaultDepositData( + subaccountFrom = "0", + amount = 100.0, + ), + withdraw = null, + ), + summaryData = VaultFormSummaryData( + needSlippageAck = false, + marginUsage = 0.5263157894736843, + freeCollateral = 900.0, + vaultBalance = 100.0, + withdrawableVaultBalance = 100.0, + estimatedSlippage = 0.0, + estimatedAmountReceived = null, + ), + ), + result, + ) + } + @Test fun testLowWithdraw() { val result = VaultDepositWithdrawFormValidator.validateVaultForm( diff --git a/v4_abacus.podspec b/v4_abacus.podspec index 1651704e4..630ed5e73 100644 --- a/v4_abacus.podspec +++ b/v4_abacus.podspec @@ -1,6 +1,6 @@ Pod::Spec.new do |spec| spec.name = 'v4_abacus' - spec.version = '1.12.25' + spec.version = '1.12.27' spec.homepage = 'https://github.com/dydxprotocol/v4-abacus' spec.source = { :http=> ''} spec.authors = ''