mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-18 11:05:19 +00:00
fix(x/precisebank): Avoid blocked addr error on SendCoinsFromAccountToModule (#2012)
This commit is contained in:
parent
8023be0067
commit
65d091d458
@ -179,10 +179,17 @@ func (k Keeper) sendExtendedCoins(
|
|||||||
// Always send carry from reserve before receiving borrow from sender to
|
// Always send carry from reserve before receiving borrow from sender to
|
||||||
// ensure reserve always has sufficient balance starting from 0.
|
// ensure reserve always has sufficient balance starting from 0.
|
||||||
if !senderNeedsBorrow && recipientNeedsCarry {
|
if !senderNeedsBorrow && recipientNeedsCarry {
|
||||||
|
reserveAddr := k.ak.GetModuleAddress(types.ModuleName)
|
||||||
|
|
||||||
|
// We use SendCoins instead of SendCoinsFromModuleToAccount to avoid
|
||||||
|
// the blocked addrs check. Blocked accounts should not be checked in
|
||||||
|
// a SendCoins operation. Only SendCoinsFromModuleToAccount should check
|
||||||
|
// blocked addrs which is done by the parent SendCoinsFromModuleToAccount
|
||||||
|
// method.
|
||||||
carryCoin := sdk.NewCoin(types.IntegerCoinDenom, sdk.NewInt(1))
|
carryCoin := sdk.NewCoin(types.IntegerCoinDenom, sdk.NewInt(1))
|
||||||
if err := k.bk.SendCoinsFromModuleToAccount(
|
if err := k.bk.SendCoins(
|
||||||
ctx,
|
ctx,
|
||||||
types.ModuleName,
|
reserveAddr,
|
||||||
to, // recipient carrying
|
to, // recipient carrying
|
||||||
sdk.NewCoins(carryCoin),
|
sdk.NewCoins(carryCoin),
|
||||||
); err != nil {
|
); err != nil {
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
||||||
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
|
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
|
||||||
minttypes "github.com/cosmos/cosmos-sdk/x/mint/types"
|
minttypes "github.com/cosmos/cosmos-sdk/x/mint/types"
|
||||||
"github.com/kava-labs/kava/app"
|
"github.com/kava-labs/kava/app"
|
||||||
@ -622,6 +623,65 @@ func (suite *sendIntegrationTestSuite) TestSendCoinsFromAccountToModule() {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (suite *sendIntegrationTestSuite) TestSendCoinsFromAccountToModule_BlockedRecipientCarry() {
|
||||||
|
// Carrying to module account balance. This tests that SendCoinsFromAccountToModule
|
||||||
|
// does not fail when sending to a blocked module account.
|
||||||
|
|
||||||
|
sender := sdk.AccAddress([]byte{1})
|
||||||
|
|
||||||
|
sendAmt := cs(c(types.ExtendedCoinDenom, 1000))
|
||||||
|
sendAmt2 := cs(ci(types.ExtendedCoinDenom, types.ConversionFactor().SubRaw(10)))
|
||||||
|
|
||||||
|
suite.MintToAccount(sender, sendAmt.Add(sendAmt2...))
|
||||||
|
|
||||||
|
err := suite.Keeper.SendCoinsFromAccountToModule(
|
||||||
|
suite.Ctx,
|
||||||
|
sender,
|
||||||
|
authtypes.FeeCollectorName,
|
||||||
|
sendAmt,
|
||||||
|
)
|
||||||
|
suite.Require().NoError(err)
|
||||||
|
|
||||||
|
// Trigger carry for fee_collector module account
|
||||||
|
err = suite.Keeper.SendCoinsFromAccountToModule(
|
||||||
|
suite.Ctx,
|
||||||
|
sender,
|
||||||
|
authtypes.FeeCollectorName,
|
||||||
|
sendAmt2,
|
||||||
|
)
|
||||||
|
suite.Require().NoError(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (suite *sendIntegrationTestSuite) TestSendCoins_BlockedRecipientCarry() {
|
||||||
|
// Same test as TestSendCoinsFromModuleToAccount_Blocked, but with SendCoins
|
||||||
|
// which also should not fail when sending to a blocked module account.
|
||||||
|
sender := sdk.AccAddress([]byte{1})
|
||||||
|
|
||||||
|
sendAmt := cs(c(types.ExtendedCoinDenom, 1000))
|
||||||
|
sendAmt2 := cs(ci(types.ExtendedCoinDenom, types.ConversionFactor().SubRaw(10)))
|
||||||
|
|
||||||
|
suite.MintToAccount(sender, sendAmt.Add(sendAmt2...))
|
||||||
|
|
||||||
|
recipient := suite.App.GetAccountKeeper().GetModuleAddress(authtypes.FeeCollectorName)
|
||||||
|
|
||||||
|
err := suite.Keeper.SendCoins(
|
||||||
|
suite.Ctx,
|
||||||
|
sender,
|
||||||
|
recipient,
|
||||||
|
sendAmt,
|
||||||
|
)
|
||||||
|
suite.Require().NoError(err)
|
||||||
|
|
||||||
|
// Trigger carry for fee_collector module account
|
||||||
|
err = suite.Keeper.SendCoins(
|
||||||
|
suite.Ctx,
|
||||||
|
sender,
|
||||||
|
recipient,
|
||||||
|
sendAmt2,
|
||||||
|
)
|
||||||
|
suite.Require().NoError(err)
|
||||||
|
}
|
||||||
|
|
||||||
func (suite *sendIntegrationTestSuite) TestSendCoinsFromModuleToAccount() {
|
func (suite *sendIntegrationTestSuite) TestSendCoinsFromModuleToAccount() {
|
||||||
// Ensure sender correctly matches the specified module account. Opposite
|
// Ensure sender correctly matches the specified module account. Opposite
|
||||||
// of SendCoinsFromAccountToModule, so we are only checking the correct
|
// of SendCoinsFromAccountToModule, so we are only checking the correct
|
||||||
|
Loading…
Reference in New Issue
Block a user