From f0e30a28cae07d48e04ff24cf73bae520cbdfe25 Mon Sep 17 00:00:00 2001 From: Unstoppable Date: Tue, 1 Aug 2023 09:17:26 +0000 Subject: [PATCH] fix-37: issue 1 less share to account for potential rounding error --- contracts/margin-dex/Vault.vy | 3 ++- tests/vault/test_liquidity.py | 28 ++++++++++----------- tests/vault/test_liquidity_safety_module.py | 25 +++++++++--------- 3 files changed, 29 insertions(+), 27 deletions(-) diff --git a/contracts/margin-dex/Vault.vy b/contracts/margin-dex/Vault.vy index c56bf79..92ddf0b 100644 --- a/contracts/margin-dex/Vault.vy +++ b/contracts/margin-dex/Vault.vy @@ -816,7 +816,8 @@ def _account_for_provide_liquidity( _token: address, _amount: uint256, _is_safety_module: bool ): self._update_debt(_token) - shares: uint256 = self._amount_to_lp_shares(_token, _amount, _is_safety_module) + # issue 1 less share to account for potential rounding errors later + shares: uint256 = self._amount_to_lp_shares(_token, _amount, _is_safety_module) - 1 if _is_safety_module: self.safety_module_lp_total_shares[_token] += shares self.safety_module_lp_shares[_token][msg.sender] += shares diff --git a/tests/vault/test_liquidity.py b/tests/vault/test_liquidity.py index 7328fed..93197eb 100644 --- a/tests/vault/test_liquidity.py +++ b/tests/vault/test_liquidity.py @@ -32,7 +32,7 @@ def test_first_provide_liquidity_records_user_shares(vault, usdc, owner): after = vault.base_lp_shares(usdc, owner) - assert after == before + amount * 10**18 + assert after == before + amount * 10**18 - 1 def test_first_provide_liquidity_records_total_shares(vault, usdc, owner): @@ -43,7 +43,7 @@ def test_first_provide_liquidity_records_total_shares(vault, usdc, owner): after = vault.base_lp_total_shares(usdc) - assert after == before + amount * 10**18 + assert after == before + amount * 10**18 - 1 def test_multiple_provide_record_shares_correctly(vault, usdc, owner, alice): @@ -53,16 +53,16 @@ def test_multiple_provide_record_shares_correctly(vault, usdc, owner, alice): amount = 100 * 10**6 vault.provide_liquidity(usdc, amount, BASE_LP) - assert vault.base_lp_total_shares(usdc) == before_total_shares + amount * 10**18 - assert vault.base_lp_shares(usdc, owner) == before_owner_shares + amount * 10**18 + assert vault.base_lp_total_shares(usdc) == before_total_shares + amount * 10**18 - 1 + assert vault.base_lp_shares(usdc, owner) == before_owner_shares + amount * 10**18 - 1 with boa.env.prank(alice): amount_2 = 30 * 10**6 vault.provide_liquidity(usdc, amount_2, BASE_LP) - assert vault.base_lp_total_shares(usdc) == before_total_shares + (amount + amount_2) * 10**18 - assert vault.base_lp_shares(usdc, owner) == before_owner_shares + amount * 10**18 - assert vault.base_lp_shares(usdc, alice) == before_alice_shares + amount_2 * 10**18 + assert vault.base_lp_total_shares(usdc) == before_total_shares + (amount + amount_2) * 10**18 - 1 - 1 + assert vault.base_lp_shares(usdc, owner) == before_owner_shares + amount * 10**18 - 1 + assert vault.base_lp_shares(usdc, alice) == before_alice_shares + amount_2 * 10**18 - 1 def test_shares_to_amount_are_calculated_correctly(vault, usdc): @@ -172,8 +172,8 @@ def test_cannot_withdraw_more_than_you_own(vault, usdc, owner, alice): alice_shares = vault.base_lp_shares(usdc, alice) alice_amount = vault.lp_shares_to_amount(usdc, alice_shares, BASE_LP) - assert alice_amount == amount - assert alice_shares == amount * 10**18 + assert alice_amount == amount - 1 + assert alice_shares == amount * 10**18 - 1 with boa.env.prank(alice): with boa.reverts("cannot withdraw more than you own"): @@ -204,13 +204,13 @@ def test_withdraw_liquidity_transfers_tokens(vault, usdc, owner): vault_balance_before = usdc.balanceOf(vault) assert vault_balance_before >= amount - vault.withdraw_liquidity(usdc, amount, BASE_LP) + vault.withdraw_liquidity(usdc, amount - 1, BASE_LP) owner_balance_after = usdc.balanceOf(owner) vault_balance_after = usdc.balanceOf(vault) - assert vault_balance_after == vault_balance_before - amount - assert owner_balance_after == owner_balance_before + amount + assert vault_balance_after == vault_balance_before - amount + 1 + assert owner_balance_after == owner_balance_before + amount - 1 def test_available_liquidty_is_calculated_correctly(vault, usdc): @@ -274,6 +274,6 @@ def test_init_total_by_distributing_trading_fee_works(vault, usdc, owner): after = vault.base_lp_shares(usdc, owner) - assert after == before + amount * 10**18 + assert after == before + amount * 10**18 - 1 - assert vault.lp_shares_to_amount(usdc, after, BASE_LP) == 100 * 10**6 + 400000 + assert vault.lp_shares_to_amount(usdc, after, BASE_LP) == 100 * 10**6 + 400000 - 1 diff --git a/tests/vault/test_liquidity_safety_module.py b/tests/vault/test_liquidity_safety_module.py index c57e041..4f5e475 100644 --- a/tests/vault/test_liquidity_safety_module.py +++ b/tests/vault/test_liquidity_safety_module.py @@ -32,7 +32,7 @@ def test_first_provide_liquidity_records_user_shares(vault, usdc, owner): after = vault.safety_module_lp_shares(usdc, owner) - assert after == amount * 10**18 + assert after == amount * 10**18 - 1 def test_first_provide_liquidity_records_total_shares(vault, usdc, owner): before = vault.safety_module_lp_total_shares(usdc) @@ -43,7 +43,7 @@ def test_first_provide_liquidity_records_total_shares(vault, usdc, owner): after = vault.safety_module_lp_total_shares(usdc) - assert after == amount * 10**18 + assert after == amount * 10**18 - 1 def test_multiple_provide_record_shares_correctly(vault, usdc, owner, alice): before = vault.safety_module_lp_total_shares(usdc) @@ -51,16 +51,16 @@ def test_multiple_provide_record_shares_correctly(vault, usdc, owner, alice): amount = 100 * 10**6 vault.provide_liquidity(usdc, amount, SAFETY_MODULE) - assert vault.safety_module_lp_total_shares(usdc) == amount * 10**18 - assert vault.safety_module_lp_shares(usdc, owner) == amount * 10**18 + assert vault.safety_module_lp_total_shares(usdc) == amount * 10**18 - 1 + assert vault.safety_module_lp_shares(usdc, owner) == amount * 10**18 - 1 with boa.env.prank(alice): amount_2 = 30 * 10**6 vault.provide_liquidity(usdc, amount_2, SAFETY_MODULE) - assert vault.safety_module_lp_total_shares(usdc) == (amount + amount_2) * 10**18 - assert vault.safety_module_lp_shares(usdc, owner) == amount * 10**18 - assert vault.safety_module_lp_shares(usdc, alice) == amount_2 * 10**18 + assert vault.safety_module_lp_total_shares(usdc) == (amount + amount_2) * 10**18 - 1 - 1 + assert vault.safety_module_lp_shares(usdc, owner) == amount * 10**18 - 1 + assert vault.safety_module_lp_shares(usdc, alice) == amount_2 * 10**18 - 1 def test_shares_to_amount_are_calculated_correctly(vault, usdc): @@ -152,8 +152,8 @@ def test_cannot_withdraw_more_than_you_own(vault, usdc, owner, alice): with boa.env.prank(alice): vault.provide_liquidity(usdc, amount, SAFETY_MODULE) - assert vault.safety_module_lp_total_amount(usdc) == 2 * amount - assert vault.safety_module_lp_total_shares(usdc) == 2 * amount * 10**18 + assert vault.safety_module_lp_total_amount(usdc) == 2 * amount + assert vault.safety_module_lp_total_shares(usdc) == 2 * amount * 10**18 - 1 - 1 with boa.reverts("cannot withdraw more than you own"): vault.withdraw_liquidity(usdc, amount+1, SAFETY_MODULE) @@ -174,6 +174,7 @@ def test_provide_liquidity_transfers_tokens(vault, usdc, owner): assert owner_balance_after == owner_balance_before - amount assert vault_balance_after == vault_balance_before + amount + def test_withdraw_liquidity_transfers_tokens(vault, usdc, owner): amount = 100 * 10**6 vault.provide_liquidity(usdc, amount, SAFETY_MODULE) @@ -182,13 +183,13 @@ def test_withdraw_liquidity_transfers_tokens(vault, usdc, owner): vault_balance_before = usdc.balanceOf(vault) assert vault_balance_before >= amount - vault.withdraw_liquidity(usdc, amount, SAFETY_MODULE) + vault.withdraw_liquidity(usdc, amount-1, SAFETY_MODULE) owner_balance_after = usdc.balanceOf(owner) vault_balance_after = usdc.balanceOf(vault) - assert vault_balance_after == vault_balance_before - amount - assert owner_balance_after == owner_balance_before + amount + assert vault_balance_after == vault_balance_before - amount + 1 + assert owner_balance_after == owner_balance_before + amount - 1 def test_available_liquidty_is_calculated_correctly(vault, usdc):