mirror of
https://github.com/0glabs/0g-chain.git
synced 2024-12-26 00:05:18 +00:00
Test users cannot borrow from reserves (#869)
* add ValidateBorrow test * remove accidentally duplicated test
This commit is contained in:
parent
d561529502
commit
162602f390
@ -420,3 +420,138 @@ func (suite *KeeperTestSuite) TestBorrow() {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (suite *KeeperTestSuite) TestValidateBorrow() {
|
||||||
|
|
||||||
|
blockDuration := time.Second * 3600 * 24 // long blocks to accumulate larger interest
|
||||||
|
|
||||||
|
_, addrs := app.GeneratePrivKeyAddressPairs(5)
|
||||||
|
borrower := addrs[0]
|
||||||
|
initialBorrowerBalance := sdk.NewCoins(
|
||||||
|
sdk.NewCoin("ukava", sdk.NewInt(1000*KAVA_CF)),
|
||||||
|
sdk.NewCoin("usdx", sdk.NewInt(1000*KAVA_CF)),
|
||||||
|
)
|
||||||
|
|
||||||
|
model := types.NewInterestRateModel(sdk.MustNewDecFromStr("1.0"), sdk.MustNewDecFromStr("2"), sdk.MustNewDecFromStr("0.8"), sdk.MustNewDecFromStr("10"))
|
||||||
|
|
||||||
|
// Initialize test app and set context
|
||||||
|
tApp := app.NewTestApp()
|
||||||
|
ctx := tApp.NewContext(true, abci.Header{Height: 1, Time: tmtime.Now()})
|
||||||
|
|
||||||
|
// Auth module genesis state
|
||||||
|
authGS := app.NewAuthGenState(
|
||||||
|
[]sdk.AccAddress{borrower},
|
||||||
|
[]sdk.Coins{initialBorrowerBalance})
|
||||||
|
|
||||||
|
// Hard module genesis state
|
||||||
|
hardGS := types.NewGenesisState(
|
||||||
|
types.NewParams(
|
||||||
|
types.MoneyMarkets{
|
||||||
|
types.NewMoneyMarket("usdx",
|
||||||
|
types.NewBorrowLimit(false, sdk.NewDec(100000000*USDX_CF), sdk.MustNewDecFromStr("1")), // Borrow Limit
|
||||||
|
"usdx:usd", // Market ID
|
||||||
|
sdk.NewInt(USDX_CF), // Conversion Factor
|
||||||
|
model, // Interest Rate Model
|
||||||
|
sdk.MustNewDecFromStr("1.0"), // Reserve Factor (high)
|
||||||
|
sdk.MustNewDecFromStr("0.05")), // Keeper Reward Percent
|
||||||
|
types.NewMoneyMarket("ukava",
|
||||||
|
types.NewBorrowLimit(false, sdk.NewDec(100000000*KAVA_CF), sdk.MustNewDecFromStr("0.8")), // Borrow Limit
|
||||||
|
"kava:usd", // Market ID
|
||||||
|
sdk.NewInt(KAVA_CF), // Conversion Factor
|
||||||
|
model, // Interest Rate Model
|
||||||
|
sdk.MustNewDecFromStr("1.0"), // Reserve Factor (high)
|
||||||
|
sdk.MustNewDecFromStr("0.05")), // Keeper Reward Percent
|
||||||
|
},
|
||||||
|
sdk.NewDec(10),
|
||||||
|
),
|
||||||
|
types.DefaultAccumulationTimes,
|
||||||
|
types.DefaultDeposits,
|
||||||
|
types.DefaultBorrows,
|
||||||
|
types.DefaultTotalSupplied,
|
||||||
|
types.DefaultTotalBorrowed,
|
||||||
|
types.DefaultTotalReserves,
|
||||||
|
)
|
||||||
|
|
||||||
|
// Pricefeed module genesis state
|
||||||
|
pricefeedGS := pricefeed.GenesisState{
|
||||||
|
Params: pricefeed.Params{
|
||||||
|
Markets: []pricefeed.Market{
|
||||||
|
{MarketID: "usdx:usd", BaseAsset: "usdx", QuoteAsset: "usd", Oracles: []sdk.AccAddress{}, Active: true},
|
||||||
|
{MarketID: "kava:usd", BaseAsset: "kava", QuoteAsset: "usd", Oracles: []sdk.AccAddress{}, Active: true},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
PostedPrices: []pricefeed.PostedPrice{
|
||||||
|
{
|
||||||
|
MarketID: "usdx:usd",
|
||||||
|
OracleAddress: sdk.AccAddress{},
|
||||||
|
Price: sdk.MustNewDecFromStr("1.00"),
|
||||||
|
Expiry: time.Now().Add(1 * time.Hour),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
MarketID: "kava:usd",
|
||||||
|
OracleAddress: sdk.AccAddress{},
|
||||||
|
Price: sdk.MustNewDecFromStr("2.00"),
|
||||||
|
Expiry: time.Now().Add(1 * time.Hour),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
// Initialize test application
|
||||||
|
tApp.InitializeFromGenesisStates(
|
||||||
|
authGS,
|
||||||
|
app.GenesisState{pricefeed.ModuleName: pricefeed.ModuleCdc.MustMarshalJSON(pricefeedGS)},
|
||||||
|
app.GenesisState{types.ModuleName: types.ModuleCdc.MustMarshalJSON(hardGS)},
|
||||||
|
)
|
||||||
|
|
||||||
|
keeper := tApp.GetHardKeeper()
|
||||||
|
suite.app = tApp
|
||||||
|
suite.ctx = ctx
|
||||||
|
suite.keeper = keeper
|
||||||
|
|
||||||
|
var err error
|
||||||
|
|
||||||
|
// Run BeginBlocker once to transition MoneyMarkets
|
||||||
|
hard.BeginBlocker(suite.ctx, suite.keeper)
|
||||||
|
|
||||||
|
// Setup borrower with some collateral to borrow against, and some reserve in the protocol.
|
||||||
|
depositCoins := sdk.NewCoins(
|
||||||
|
sdk.NewCoin("ukava", sdk.NewInt(100*KAVA_CF)),
|
||||||
|
sdk.NewCoin("usdx", sdk.NewInt(100*USDX_CF)),
|
||||||
|
)
|
||||||
|
err = suite.keeper.Deposit(suite.ctx, borrower, depositCoins)
|
||||||
|
suite.Require().NoError(err)
|
||||||
|
|
||||||
|
initialBorrowCoins := sdk.NewCoins(sdk.NewCoin("ukava", sdk.NewInt(70*KAVA_CF)))
|
||||||
|
err = suite.keeper.Borrow(suite.ctx, borrower, initialBorrowCoins)
|
||||||
|
suite.Require().NoError(err)
|
||||||
|
|
||||||
|
runAtTime := suite.ctx.BlockTime().Add(blockDuration)
|
||||||
|
suite.ctx = suite.ctx.WithBlockTime(runAtTime)
|
||||||
|
hard.BeginBlocker(suite.ctx, suite.keeper)
|
||||||
|
|
||||||
|
repayCoins := sdk.NewCoins(sdk.NewCoin("ukava", sdk.NewInt(100*KAVA_CF))) // repay everything including accumulated interest
|
||||||
|
err = suite.keeper.Repay(suite.ctx, borrower, borrower, repayCoins)
|
||||||
|
suite.Require().NoError(err)
|
||||||
|
|
||||||
|
// Get the total borrowable amount from the protocol, taking into account the reserves.
|
||||||
|
modAccBalance := suite.getModuleAccountAtCtx(types.ModuleAccountName, suite.ctx).GetCoins()
|
||||||
|
reserves, found := suite.keeper.GetTotalReserves(suite.ctx)
|
||||||
|
suite.Require().True(found)
|
||||||
|
availableToBorrow := modAccBalance.Sub(reserves)
|
||||||
|
|
||||||
|
// Test borrowing one over the available amount (try to borrow from the reserves)
|
||||||
|
err = suite.keeper.Borrow(
|
||||||
|
suite.ctx,
|
||||||
|
borrower,
|
||||||
|
sdk.NewCoins(sdk.NewCoin("ukava", availableToBorrow.AmountOf("ukava").Add(sdk.OneInt()))),
|
||||||
|
)
|
||||||
|
suite.Require().Error(err)
|
||||||
|
|
||||||
|
// Test borrowing exactly the limit
|
||||||
|
err = suite.keeper.Borrow(
|
||||||
|
suite.ctx,
|
||||||
|
borrower,
|
||||||
|
sdk.NewCoins(sdk.NewCoin("ukava", availableToBorrow.AmountOf("ukava"))),
|
||||||
|
)
|
||||||
|
suite.Require().NoError(err)
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user