mirror of
https://github.com/0glabs/0g-chain.git
synced 2024-12-27 00:35:18 +00:00
6998196461
* Initial e2e setup * Fix inflation disable tests * Add upgrade handler * Add param tests for after upgrade * Replace deprecated grpc creds * Remove upgrade for e2e test * Update upgrade handler to set x/community params * Remove params check in upgrade * Update tests for switchover time and params check * wip inflation * Add attribute to disable inflation event * Add before/after switchover mint and dist checks * Add missing attribute to disable inflation test check * Check mint events are 0 * Check total supply doesn't change * Check inflation and events before switchover * Check staking reward payouts from x/community * move events funcs to util * Add keyring to chain, fetch keys from kvtool and test withdrawal * Remove duplicate KavaHomePath * Update subtest names to specify before/after switchover Co-authored-by: Draco <draco@dracoli.com> * Use blocktime for InflationStop event DisableTime * Test 5 blocks for staking rewards payout * Remove logging and unused lines * Check val claimed balance with queried * Enable and update consolidation tests * Update test for modified EventTypeInflationStop time attr * Test x/distribution community tax * Fix test names * Update e2e tests for better live network test support (#1749) * Update e2e tests to support mirrornet * Skip claim rewards on live network, require no errors for existing tests * Update readme with upgrade height * Update .env example with usdt contract address * Restore .env file to original local e2e * Log community params when set * Make AttributeKeyInflationDisableTime more precise * Add mainnet and testnet community params (#1753) * Re-enable ibc tests * Remove duplicate types.EventTypeInflationStop emit * feat: set validator minimum commissions to at least 5% in upgrade handler (#1761) * Update validator min commission in upgrade * Add min commission upgrade test * Update changelog * Set validator MaxRate, call BeforeValidatorModified hook * Check max commission and update time in tests * Update e2e test for max rate * Test val update time * Use SdkBlock instead of Block * Remove upgrade related handlers and tests Preserve any module and test util changes * Update e2e x/community params proposal test to work without upgrade handler --------- Co-authored-by: Draco <draco@dracoli.com>
95 lines
2.5 KiB
Go
95 lines
2.5 KiB
Go
package runner
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
|
|
"github.com/ethereum/go-ethereum/ethclient"
|
|
rpchttpclient "github.com/tendermint/tendermint/rpc/client/http"
|
|
"google.golang.org/grpc"
|
|
|
|
"github.com/kava-labs/kava/tests/util"
|
|
)
|
|
|
|
var (
|
|
ErrChainAlreadyExists = errors.New("chain already exists")
|
|
)
|
|
|
|
// ChainDetails wraps information about the properties & endpoints of a chain.
|
|
type ChainDetails struct {
|
|
RpcUrl string
|
|
GrpcUrl string
|
|
EvmRpcUrl string
|
|
|
|
ChainId string
|
|
StakingDenom string
|
|
}
|
|
|
|
// EvmClient dials the underlying EVM RPC url and returns an ethclient.
|
|
func (c ChainDetails) EvmClient() (*ethclient.Client, error) {
|
|
return ethclient.Dial(c.EvmRpcUrl)
|
|
}
|
|
|
|
// GrpcConn creates a new connection to the underlying Grpc url.
|
|
func (c ChainDetails) GrpcConn() (*grpc.ClientConn, error) {
|
|
return util.NewGrpcConnection(c.GrpcUrl)
|
|
}
|
|
|
|
// RpcConn creates a new connection to the underlying Rpc url.
|
|
func (c ChainDetails) RpcConn() (*rpchttpclient.HTTP, error) {
|
|
return rpchttpclient.New(c.RpcUrl, "/websocket")
|
|
}
|
|
|
|
// Chains wraps a map of name -> details about how to connect to a chain.
|
|
// It prevents registering multiple chains with the same name & encapsulates
|
|
// panicking if attempting to access a chain that does not exist.
|
|
type Chains struct {
|
|
byName map[string]*ChainDetails
|
|
}
|
|
|
|
// NewChains creates an empty Chains map.
|
|
func NewChains() Chains {
|
|
return Chains{byName: make(map[string]*ChainDetails, 0)}
|
|
}
|
|
|
|
// MustGetChain returns the chain of a given name,
|
|
// or panics if a chain with that name has not been registered.
|
|
func (c Chains) MustGetChain(name string) *ChainDetails {
|
|
chain, found := c.byName[name]
|
|
if !found {
|
|
panic(fmt.Sprintf("no chain with name %s found", name))
|
|
}
|
|
return chain
|
|
}
|
|
|
|
// Register adds a chain to the map.
|
|
// It returns an error if a ChainDetails with that name has already been registered.
|
|
func (c *Chains) Register(name string, chain *ChainDetails) error {
|
|
if _, found := c.byName[name]; found {
|
|
return ErrChainAlreadyExists
|
|
}
|
|
c.byName[name] = chain
|
|
return nil
|
|
}
|
|
|
|
// the Chain details are all hardcoded because they are currently fixed by kvtool.
|
|
// someday they may be accepted as configurable parameters.
|
|
var (
|
|
kvtoolKavaChain = ChainDetails{
|
|
RpcUrl: "http://localhost:26657",
|
|
GrpcUrl: "http://localhost:9090",
|
|
EvmRpcUrl: "http://localhost:8545",
|
|
|
|
ChainId: "kavalocalnet_8888-1",
|
|
StakingDenom: "ukava",
|
|
}
|
|
kvtoolIbcChain = ChainDetails{
|
|
RpcUrl: "http://localhost:26658",
|
|
GrpcUrl: "http://localhost:9092",
|
|
EvmRpcUrl: "http://localhost:8547",
|
|
|
|
ChainId: "kavalocalnet_8889-2",
|
|
StakingDenom: "uatom",
|
|
}
|
|
)
|