mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-15 01:35:21 +00:00
243 lines
7.2 KiB
Go
243 lines
7.2 KiB
Go
|
package bep3_test
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||
|
"github.com/stretchr/testify/suite"
|
||
|
abci "github.com/tendermint/tendermint/abci/types"
|
||
|
cmn "github.com/tendermint/tendermint/libs/common"
|
||
|
tmtime "github.com/tendermint/tendermint/types/time"
|
||
|
|
||
|
"github.com/kava-labs/kava/app"
|
||
|
"github.com/kava-labs/kava/x/bep3"
|
||
|
)
|
||
|
|
||
|
type ABCITestSuite struct {
|
||
|
suite.Suite
|
||
|
keeper bep3.Keeper
|
||
|
app app.TestApp
|
||
|
ctx sdk.Context
|
||
|
addrs []sdk.AccAddress
|
||
|
swapIDs []cmn.HexBytes
|
||
|
randomNumbers []cmn.HexBytes
|
||
|
}
|
||
|
|
||
|
func (suite *ABCITestSuite) SetupTest() {
|
||
|
tApp := app.NewTestApp()
|
||
|
ctx := tApp.NewContext(true, abci.Header{Height: 1, Time: tmtime.Now()})
|
||
|
|
||
|
// Set up auth GenesisState
|
||
|
_, addrs := app.GeneratePrivKeyAddressPairs(11)
|
||
|
coins := []sdk.Coins{}
|
||
|
for j := 0; j < 11; j++ {
|
||
|
coins = append(coins, cs(c("bnb", 10000000000), c("ukava", 10000000000)))
|
||
|
}
|
||
|
authGS := app.NewAuthGenState(addrs, coins)
|
||
|
// Initialize test app
|
||
|
tApp.InitializeFromGenesisStates(authGS, NewBep3GenStateMulti(addrs[0]))
|
||
|
|
||
|
suite.ctx = ctx
|
||
|
suite.app = tApp
|
||
|
suite.addrs = addrs
|
||
|
suite.ResetKeeper()
|
||
|
}
|
||
|
|
||
|
func (suite *ABCITestSuite) ResetKeeper() {
|
||
|
suite.keeper = suite.app.GetBep3Keeper()
|
||
|
|
||
|
var swapIDs []cmn.HexBytes
|
||
|
var randomNumbers []cmn.HexBytes
|
||
|
for i := 0; i < 10; i++ {
|
||
|
// Set up atomic swap variables
|
||
|
expireHeight := int64(360)
|
||
|
amount := cs(c("bnb", int64(100)))
|
||
|
timestamp := ts(i)
|
||
|
randomNumber, _ := bep3.GenerateSecureRandomNumber()
|
||
|
randomNumberHash := bep3.CalculateRandomHash(randomNumber.Bytes(), timestamp)
|
||
|
|
||
|
// Create atomic swap and check err to confirm creation
|
||
|
err := suite.keeper.CreateAtomicSwap(suite.ctx, randomNumberHash, timestamp, expireHeight,
|
||
|
suite.addrs[0], suite.addrs[i], TestSenderOtherChain, TestRecipientOtherChain,
|
||
|
amount, amount.String(), true)
|
||
|
suite.Nil(err)
|
||
|
|
||
|
// Store swap's calculated ID and secret random number
|
||
|
swapID := bep3.CalculateSwapID(randomNumberHash, suite.addrs[0], TestSenderOtherChain)
|
||
|
swapIDs = append(swapIDs, swapID)
|
||
|
randomNumbers = append(randomNumbers, randomNumber.Bytes())
|
||
|
}
|
||
|
suite.swapIDs = swapIDs
|
||
|
suite.randomNumbers = randomNumbers
|
||
|
}
|
||
|
|
||
|
func (suite *ABCITestSuite) TestBeginBlocker_UpdateExpiredAtomicSwaps() {
|
||
|
testCases := []struct {
|
||
|
name string
|
||
|
firstCtx sdk.Context
|
||
|
secondCtx sdk.Context
|
||
|
expectedStatus bep3.SwapStatus
|
||
|
expectInStorage bool
|
||
|
}{
|
||
|
{
|
||
|
name: "normal",
|
||
|
firstCtx: suite.ctx,
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + 10),
|
||
|
expectedStatus: bep3.Open,
|
||
|
expectInStorage: true,
|
||
|
},
|
||
|
{
|
||
|
name: "after expiration",
|
||
|
firstCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + 400),
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + 410),
|
||
|
expectedStatus: bep3.Expired,
|
||
|
expectInStorage: true,
|
||
|
},
|
||
|
{
|
||
|
name: "after completion",
|
||
|
firstCtx: suite.ctx,
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + 10),
|
||
|
expectedStatus: bep3.Completed,
|
||
|
expectInStorage: true,
|
||
|
},
|
||
|
{
|
||
|
name: "after deletion",
|
||
|
firstCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + 400),
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + 400 + bep3.DefaultLongtermStorageDuration),
|
||
|
expectedStatus: bep3.NULL,
|
||
|
expectInStorage: false,
|
||
|
},
|
||
|
}
|
||
|
|
||
|
for _, tc := range testCases {
|
||
|
// Reset keeper and run the initial begin blocker
|
||
|
suite.ResetKeeper()
|
||
|
suite.Run(tc.name, func() {
|
||
|
bep3.BeginBlocker(tc.firstCtx, suite.keeper)
|
||
|
|
||
|
switch tc.expectedStatus {
|
||
|
case bep3.Completed:
|
||
|
for i, swapID := range suite.swapIDs {
|
||
|
err := suite.keeper.ClaimAtomicSwap(tc.firstCtx, suite.addrs[5], swapID, suite.randomNumbers[i])
|
||
|
suite.Nil(err)
|
||
|
}
|
||
|
case bep3.NULL:
|
||
|
for _, swapID := range suite.swapIDs {
|
||
|
err := suite.keeper.RefundAtomicSwap(tc.firstCtx, suite.addrs[5], swapID)
|
||
|
suite.Nil(err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Run the second begin blocker
|
||
|
bep3.BeginBlocker(tc.secondCtx, suite.keeper)
|
||
|
|
||
|
// Check each swap's availibility and status
|
||
|
for _, swapID := range suite.swapIDs {
|
||
|
storedSwap, found := suite.keeper.GetAtomicSwap(tc.secondCtx, swapID)
|
||
|
if tc.expectInStorage {
|
||
|
suite.True(found)
|
||
|
} else {
|
||
|
suite.False(found)
|
||
|
}
|
||
|
suite.Equal(tc.expectedStatus, storedSwap.Status)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (suite *ABCITestSuite) TestBeginBlocker_DeleteClosedAtomicSwapsFromLongtermStorage() {
|
||
|
type Action int
|
||
|
const (
|
||
|
NULL Action = 0x00
|
||
|
Refund Action = 0x01
|
||
|
Claim Action = 0x02
|
||
|
)
|
||
|
|
||
|
testCases := []struct {
|
||
|
name string
|
||
|
firstCtx sdk.Context
|
||
|
action Action
|
||
|
secondCtx sdk.Context
|
||
|
expectInStorage bool
|
||
|
}{
|
||
|
{
|
||
|
name: "no action with long storage duration",
|
||
|
firstCtx: suite.ctx,
|
||
|
action: NULL,
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + bep3.DefaultLongtermStorageDuration),
|
||
|
expectInStorage: true,
|
||
|
},
|
||
|
{
|
||
|
name: "claim with short storage duration",
|
||
|
firstCtx: suite.ctx,
|
||
|
action: Claim,
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + 5000),
|
||
|
expectInStorage: true,
|
||
|
},
|
||
|
{
|
||
|
name: "claim with long storage duration",
|
||
|
firstCtx: suite.ctx,
|
||
|
action: Claim,
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + bep3.DefaultLongtermStorageDuration),
|
||
|
expectInStorage: false,
|
||
|
},
|
||
|
{
|
||
|
name: "refund with short storage duration",
|
||
|
firstCtx: suite.ctx,
|
||
|
action: Refund,
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + 5000),
|
||
|
expectInStorage: true,
|
||
|
},
|
||
|
{
|
||
|
name: "refund with long storage duration",
|
||
|
firstCtx: suite.ctx,
|
||
|
action: Refund,
|
||
|
secondCtx: suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + bep3.DefaultLongtermStorageDuration),
|
||
|
expectInStorage: false,
|
||
|
},
|
||
|
}
|
||
|
|
||
|
for _, tc := range testCases {
|
||
|
// Reset keeper and run the initial begin blocker
|
||
|
suite.ResetKeeper()
|
||
|
suite.Run(tc.name, func() {
|
||
|
bep3.BeginBlocker(tc.firstCtx, suite.keeper)
|
||
|
|
||
|
switch tc.action {
|
||
|
case Claim:
|
||
|
for i, swapID := range suite.swapIDs {
|
||
|
err := suite.keeper.ClaimAtomicSwap(tc.firstCtx, suite.addrs[5], swapID, suite.randomNumbers[i])
|
||
|
suite.Nil(err)
|
||
|
}
|
||
|
case Refund:
|
||
|
for _, swapID := range suite.swapIDs {
|
||
|
swap, _ := suite.keeper.GetAtomicSwap(tc.firstCtx, swapID)
|
||
|
refundCtx := suite.ctx.WithBlockHeight(suite.ctx.BlockHeight() + swap.ExpireHeight)
|
||
|
bep3.BeginBlocker(refundCtx, suite.keeper)
|
||
|
err := suite.keeper.RefundAtomicSwap(refundCtx, suite.addrs[5], swapID)
|
||
|
suite.Nil(err)
|
||
|
// Add expire height to second ctx block height
|
||
|
tc.secondCtx = tc.secondCtx.WithBlockHeight(tc.secondCtx.BlockHeight() + swap.ExpireHeight)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Run the second begin blocker
|
||
|
bep3.BeginBlocker(tc.secondCtx, suite.keeper)
|
||
|
|
||
|
// Check each swap's availibility and status
|
||
|
for _, swapID := range suite.swapIDs {
|
||
|
_, found := suite.keeper.GetAtomicSwap(tc.secondCtx, swapID)
|
||
|
if tc.expectInStorage {
|
||
|
suite.True(found)
|
||
|
} else {
|
||
|
suite.False(found)
|
||
|
}
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestABCITestSuite(t *testing.T) {
|
||
|
suite.Run(t, new(ABCITestSuite))
|
||
|
}
|