mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-13 08:45:18 +00:00
don't sync borrow on deposit - it's redundant (#876)
This commit is contained in:
parent
72bfee6523
commit
21cf7685df
@ -23,19 +23,14 @@ func (k Keeper) Deposit(ctx sdk.Context, depositor sdk.AccAddress, coins sdk.Coi
|
||||
}
|
||||
}
|
||||
|
||||
// Call incentive hooks
|
||||
// Call incentive hook
|
||||
existingDeposit, hasExistingDeposit := k.GetDeposit(ctx, depositor)
|
||||
if hasExistingDeposit {
|
||||
k.BeforeDepositModified(ctx, existingDeposit)
|
||||
}
|
||||
existingBorrow, hasExistingBorrow := k.GetBorrow(ctx, depositor)
|
||||
if hasExistingBorrow {
|
||||
k.BeforeBorrowModified(ctx, existingBorrow)
|
||||
}
|
||||
|
||||
// Sync any outstanding interest
|
||||
k.SyncSupplyInterest(ctx, depositor)
|
||||
k.SyncBorrowInterest(ctx, depositor)
|
||||
|
||||
err := k.ValidateDeposit(ctx, coins)
|
||||
if err != nil {
|
||||
|
@ -1389,20 +1389,12 @@ func (suite *KeeperTestSuite) TestSupplyInterest() {
|
||||
userPercentOfTotalSupplied := userSupplyCoinAmount.ToDec().Quo(supplyCoinPriorAmount.ToDec())
|
||||
userExpectedSupplyInterestCoin := sdk.NewCoin(coinDenom, userPercentOfTotalSupplied.MulInt(expectedSupplyInterest).TruncateInt())
|
||||
|
||||
// Calculate percentage of borrow interest profits owed to user
|
||||
userBorrowBefore, _ := suite.keeper.GetBorrow(snapshotCtx, tc.args.user)
|
||||
userBorrowCoinAmount := userBorrowBefore.Amount.AmountOf(coinDenom)
|
||||
userPercentOfTotalBorrowed := userBorrowCoinAmount.ToDec().Quo(borrowCoinPriorAmount.ToDec())
|
||||
userExpectedBorrowInterestCoin := sdk.NewCoin(coinDenom, userPercentOfTotalBorrowed.MulInt(expectedBorrowInterest).TruncateInt())
|
||||
expectedBorrowCoinsAfter := userBorrowBefore.Amount.Add(userExpectedBorrowInterestCoin)
|
||||
|
||||
// Supplying syncs user's owed supply and borrow interest
|
||||
err = suite.keeper.Deposit(snapshotCtx, tc.args.user, sdk.NewCoins(snapshot.supplyCoin))
|
||||
suite.Require().NoError(err)
|
||||
|
||||
// Fetch user's new borrow and supply balance post-interaction
|
||||
userSupplyAfter, _ := suite.keeper.GetDeposit(snapshotCtx, tc.args.user)
|
||||
userBorrowAfter, _ := suite.keeper.GetBorrow(snapshotCtx, tc.args.user)
|
||||
|
||||
// Confirm that user's supply index for the denom has increased as expected
|
||||
var userSupplyAfterIndexFactor sdk.Dec
|
||||
@ -1416,18 +1408,6 @@ func (suite *KeeperTestSuite) TestSupplyInterest() {
|
||||
// Check user's supplied amount increased by supply interest owed + the newly supplied coins
|
||||
expectedSupplyCoinsAfter := userSupplyBefore.Amount.Add(snapshot.supplyCoin).Add(userExpectedSupplyInterestCoin)
|
||||
suite.Require().Equal(expectedSupplyCoinsAfter, userSupplyAfter.Amount)
|
||||
|
||||
// Confirm that user's borrow index for the denom has increased as expected
|
||||
var userBorrowAfterIndexFactor sdk.Dec
|
||||
for _, indexFactor := range userBorrowAfter.Index {
|
||||
if indexFactor.Denom == coinDenom {
|
||||
userBorrowAfterIndexFactor = indexFactor.Value
|
||||
}
|
||||
}
|
||||
suite.Require().Equal(userBorrowAfterIndexFactor, currBorrowIndexPrior)
|
||||
|
||||
// Check user's borrowed amount increased by borrow interest owed
|
||||
suite.Require().Equal(expectedBorrowCoinsAfter, userBorrowAfter.Amount)
|
||||
}
|
||||
prevCtx = snapshotCtx
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user