mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-01 11:15:17 +00:00
614d4e40fe
* Update cometbft, cosmos, ethermint, and ibc-go * Replace github.com/tendermint/tendermint by github.com/cometbft/cometbft * Replace github.com/tendermint/tm-db by github.com/cometbft/cometbft-db * Replace gogo/protobuf with cosmos/gogoproto & simapp replacement * Replace cosmos-sdk/simapp/helpers with cosmos-sdk/testutil/sims * Remove no longer used simulations * Replace ibchost with ibcexported See https://github.com/cosmos/ibc-go/blob/v7.2.2/docs/migrations/v6-to-v7.md#ibc-module-constants * Add new consensus params keeper * Add consensus keeper to blockers * Fix keeper and module issues in app.go * Add IsSendEnabledCoins and update SetParams interface changes * Fix protobuf build for cosmos 47 (#1800) * fix cp errors by using -f; fix lint by only linting our proto dir; and use proofs.proto directly from ics23 for ibc-go v7 * run proto-all; commit updated third party deps and swagger changes * regenerate proto files * use correct gocosmos build plugin for buf * re-gen all protobuf files to update paths for new gocosmos plugin * update protoc and buf to latest versions * fix staking keeper issues in app.go * update tally handler for gov changes * chain id fix and flag fixes * update deps for cometbft 47.7 upgrade * remove all module legacy queriers * update stakingKeeper to pointer * Replace ModuleCdc from govv1beta1 to govcodec * remove simulations * abci.LastCommitInfo → abci.CommitInfo * Remove unused code in keys.go * simapp.MakeTestEncodingConfig -> moduletestutil.MakeTestEncodingConfi * Fix chain id issues in tests * Fix remaining unit test issues * Update changelog for upgrade * Fix e2e tests using updated kvtool * Update protonet to v47 compatible genesis * Bump cometbft-db to v0.9.1-kava.1 * Update kvtool * Remove extra changelog * Fix merged rocksdb issues * go mod cleanup * Bump cometbft-db to v9 and go to 1.21 * Bump rocksdb version to v8.10.0 * Update kvtool to latest version * Update gin to v1.9.0 * Use ibctm.ModuleName in app_test * Fallback to genesis chain id instead of client toml * Remove all simulations * Fix cdp migrations issue with v47 * Update dependencies to correct tags --------- Co-authored-by: Nick DeLuca <nickdeluca08@gmail.com>
120 lines
4.0 KiB
Go
120 lines
4.0 KiB
Go
package keeper_test
|
|
|
|
import (
|
|
"time"
|
|
|
|
sdkmath "cosmossdk.io/math"
|
|
"github.com/cosmos/cosmos-sdk/codec"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
|
|
|
"github.com/cometbft/cometbft/crypto"
|
|
tmtime "github.com/cometbft/cometbft/types/time"
|
|
|
|
"github.com/kava-labs/kava/app"
|
|
"github.com/kava-labs/kava/x/bep3/types"
|
|
)
|
|
|
|
const (
|
|
TestSenderOtherChain = "bnb1uky3me9ggqypmrsvxk7ur6hqkzq7zmv4ed4ng7"
|
|
TestRecipientOtherChain = "bnb1urfermcg92dwq36572cx4xg84wpk3lfpksr5g7"
|
|
TestDeputy = "kava1xy7hrjy9r0algz9w3gzm8u6mrpq97kwta747gj"
|
|
)
|
|
|
|
var (
|
|
DenomMap = map[int]string{0: "btc", 1: "eth", 2: "bnb", 3: "xrp", 4: "dai"}
|
|
TestUser1 = sdk.AccAddress(crypto.AddressHash([]byte("KavaTestUser1")))
|
|
TestUser2 = sdk.AccAddress(crypto.AddressHash([]byte("KavaTestUser2")))
|
|
)
|
|
|
|
func c(denom string, amount int64) sdk.Coin { return sdk.NewInt64Coin(denom, amount) }
|
|
func cs(coins ...sdk.Coin) sdk.Coins { return sdk.NewCoins(coins...) }
|
|
func ts(minOffset int) int64 { return tmtime.Now().Add(time.Duration(minOffset) * time.Minute).Unix() }
|
|
|
|
func NewAuthGenStateFromAccs(cdc codec.JSONCodec, accounts ...authtypes.GenesisAccount) app.GenesisState {
|
|
authGenesis := authtypes.NewGenesisState(authtypes.DefaultParams(), accounts)
|
|
return app.GenesisState{authtypes.ModuleName: cdc.MustMarshalJSON(authGenesis)}
|
|
}
|
|
|
|
func NewBep3GenStateMulti(cdc codec.JSONCodec, deputyAddress sdk.AccAddress) app.GenesisState {
|
|
bep3Genesis := types.GenesisState{
|
|
Params: types.Params{
|
|
AssetParams: types.AssetParams{
|
|
{
|
|
Denom: "bnb",
|
|
CoinID: 714,
|
|
SupplyLimit: types.SupplyLimit{
|
|
Limit: sdkmath.NewInt(350000000000000),
|
|
TimeLimited: false,
|
|
TimeBasedLimit: sdk.ZeroInt(),
|
|
TimePeriod: time.Hour,
|
|
},
|
|
Active: true,
|
|
DeputyAddress: deputyAddress,
|
|
FixedFee: sdkmath.NewInt(1000),
|
|
MinSwapAmount: sdk.OneInt(),
|
|
MaxSwapAmount: sdkmath.NewInt(1000000000000),
|
|
MinBlockLock: types.DefaultMinBlockLock,
|
|
MaxBlockLock: types.DefaultMaxBlockLock,
|
|
},
|
|
{
|
|
Denom: "inc",
|
|
CoinID: 9999,
|
|
SupplyLimit: types.SupplyLimit{
|
|
Limit: sdkmath.NewInt(100000000000000),
|
|
TimeLimited: true,
|
|
TimeBasedLimit: sdkmath.NewInt(50000000000),
|
|
TimePeriod: time.Hour,
|
|
},
|
|
Active: false,
|
|
DeputyAddress: deputyAddress,
|
|
FixedFee: sdkmath.NewInt(1000),
|
|
MinSwapAmount: sdk.OneInt(),
|
|
MaxSwapAmount: sdkmath.NewInt(100000000000),
|
|
MinBlockLock: types.DefaultMinBlockLock,
|
|
MaxBlockLock: types.DefaultMaxBlockLock,
|
|
},
|
|
},
|
|
},
|
|
Supplies: types.AssetSupplies{
|
|
types.NewAssetSupply(
|
|
sdk.NewCoin("bnb", sdk.ZeroInt()),
|
|
sdk.NewCoin("bnb", sdk.ZeroInt()),
|
|
sdk.NewCoin("bnb", sdk.ZeroInt()),
|
|
sdk.NewCoin("bnb", sdk.ZeroInt()),
|
|
time.Duration(0),
|
|
),
|
|
types.NewAssetSupply(
|
|
sdk.NewCoin("inc", sdk.ZeroInt()),
|
|
sdk.NewCoin("inc", sdk.ZeroInt()),
|
|
sdk.NewCoin("inc", sdk.ZeroInt()),
|
|
sdk.NewCoin("inc", sdk.ZeroInt()),
|
|
time.Duration(0),
|
|
),
|
|
},
|
|
PreviousBlockTime: types.DefaultPreviousBlockTime,
|
|
}
|
|
return app.GenesisState{types.ModuleName: cdc.MustMarshalJSON(&bep3Genesis)}
|
|
}
|
|
|
|
func atomicSwaps(ctx sdk.Context, count int) types.AtomicSwaps {
|
|
var swaps types.AtomicSwaps
|
|
for i := 0; i < count; i++ {
|
|
swap := atomicSwap(ctx, i)
|
|
swaps = append(swaps, swap)
|
|
}
|
|
return swaps
|
|
}
|
|
|
|
func atomicSwap(ctx sdk.Context, index int) types.AtomicSwap {
|
|
expireOffset := uint64(200) // Default expire height + offet to match timestamp
|
|
timestamp := ts(index) // One minute apart
|
|
randomNumber, _ := types.GenerateSecureRandomNumber()
|
|
randomNumberHash := types.CalculateRandomHash(randomNumber[:], timestamp)
|
|
|
|
return types.NewAtomicSwap(cs(c("bnb", 50000)), randomNumberHash,
|
|
uint64(ctx.BlockHeight())+expireOffset, timestamp, TestUser1, TestUser2,
|
|
TestSenderOtherChain, TestRecipientOtherChain, 0, types.SWAP_STATUS_OPEN, true,
|
|
types.SWAP_DIRECTION_INCOMING)
|
|
}
|