mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-01 11:15:17 +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>
110 lines
3.1 KiB
Go
110 lines
3.1 KiB
Go
package testutil
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/cosmos/cosmos-sdk/client"
|
|
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
"github.com/cosmos/cosmos-sdk/types/tx/signing"
|
|
"github.com/cosmos/cosmos-sdk/x/auth/migrations/legacytx"
|
|
authtx "github.com/cosmos/cosmos-sdk/x/auth/tx"
|
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
"github.com/evmos/ethermint/ethereum/eip712"
|
|
emtypes "github.com/evmos/ethermint/types"
|
|
evmtypes "github.com/evmos/ethermint/x/evm/types"
|
|
)
|
|
|
|
// NewEip712TxBuilder is a helper method for creating an EIP712 signed tx
|
|
// A tx like this is what a user signing cosmos messages with Metamask would broadcast.
|
|
func (suite *E2eTestSuite) NewEip712TxBuilder(
|
|
acc *SigningAccount, chain *Chain, gas uint64, gasAmount sdk.Coins, msgs []sdk.Msg, memo string,
|
|
) client.TxBuilder {
|
|
// get account details
|
|
var accDetails authtypes.AccountI
|
|
a, err := chain.Auth.Account(context.Background(), &authtypes.QueryAccountRequest{
|
|
Address: acc.SdkAddress.String(),
|
|
})
|
|
suite.NoError(err)
|
|
err = chain.EncodingConfig.InterfaceRegistry.UnpackAny(a.Account, &accDetails)
|
|
suite.NoError(err)
|
|
|
|
// get nonce & acc number
|
|
nonce := accDetails.GetSequence()
|
|
accNumber := accDetails.GetAccountNumber()
|
|
|
|
// get chain id
|
|
pc, err := emtypes.ParseChainID(chain.ChainID)
|
|
suite.NoError(err)
|
|
ethChainId := pc.Uint64()
|
|
|
|
evmParams, err := chain.Evm.Params(context.Background(), &evmtypes.QueryParamsRequest{})
|
|
suite.NoError(err)
|
|
|
|
fee := legacytx.NewStdFee(gas, gasAmount)
|
|
|
|
// build EIP712 tx
|
|
// -- untyped data
|
|
untypedData := eip712.ConstructUntypedEIP712Data(
|
|
chain.ChainID,
|
|
accNumber,
|
|
nonce,
|
|
0, // no timeout
|
|
fee,
|
|
msgs,
|
|
memo,
|
|
nil,
|
|
)
|
|
// -- typed data
|
|
typedData, err := eip712.WrapTxToTypedData(ethChainId, msgs, untypedData, &eip712.FeeDelegationOptions{
|
|
FeePayer: acc.SdkAddress,
|
|
}, evmParams.Params)
|
|
suite.NoError(err)
|
|
|
|
// -- raw data hash!
|
|
data, err := eip712.ComputeTypedDataHash(typedData)
|
|
suite.NoError(err)
|
|
|
|
// -- sign the hash
|
|
signature, pubKey, err := acc.SignRawEvmData(data)
|
|
suite.NoError(err)
|
|
signature[crypto.RecoveryIDOffset] += 27 // Transform V from 0/1 to 27/28 according to the yellow paper
|
|
|
|
// add ExtensionOptionsWeb3Tx extension
|
|
var option *codectypes.Any
|
|
option, err = codectypes.NewAnyWithValue(&emtypes.ExtensionOptionsWeb3Tx{
|
|
FeePayer: acc.SdkAddress.String(),
|
|
TypedDataChainID: ethChainId,
|
|
FeePayerSig: signature,
|
|
})
|
|
suite.NoError(err)
|
|
|
|
// create cosmos sdk tx builder
|
|
txBuilder := chain.EncodingConfig.TxConfig.NewTxBuilder()
|
|
builder, ok := txBuilder.(authtx.ExtensionOptionsTxBuilder)
|
|
suite.True(ok)
|
|
|
|
builder.SetExtensionOptions(option)
|
|
builder.SetFeeAmount(fee.Amount)
|
|
builder.SetGasLimit(fee.Gas)
|
|
|
|
sigsV2 := signing.SignatureV2{
|
|
PubKey: pubKey,
|
|
Data: &signing.SingleSignatureData{
|
|
SignMode: signing.SignMode_SIGN_MODE_LEGACY_AMINO_JSON,
|
|
},
|
|
Sequence: nonce,
|
|
}
|
|
|
|
err = builder.SetSignatures(sigsV2)
|
|
suite.Require().NoError(err)
|
|
|
|
err = builder.SetMsgs(msgs...)
|
|
suite.Require().NoError(err)
|
|
|
|
builder.SetMemo(memo)
|
|
|
|
return builder
|
|
}
|