tests: make integration test more stable (#1488)
* wait new blk right before send tx
* larger timeout_commit for priority test
* larger timeout_commit for mempool related test
* mv chain id test to cluster used test
* keep cluster in module scope
* sync gomod2nix
* adjust timeout_commit
* rm prune all in indexer config
* add missing min_gas_multiplier
* wait 1 more blk in upgrade
* only keep 2 validators
* add retry for grpc_eth_call
* wait 1 block before stop
* fix lint
* disable recheck
* bump up upgrade
* sync gomod2nix
* Apply suggestions from code review
* Apply suggestions from code review
* append node log
* fix lint
* expect less gas after ecd76396eb
* allow retry continue on empty rsp
* update gomod2nix
* fix flake
* mod tidy
* keep grpc only test
* tests(integration): enable recheck tx mode
* update gomod2nix
Co-authored-by: Federico Kunze Küllmer <31522760+fedekunze@users.noreply.github.com>
Co-authored-by: Freddy Caceres <facs95@gmail.com>
Co-authored-by: Tom <tomasguerraalda@hotmail.com>
This commit is contained in:
parent
1dfee9f283
commit
29caa1916d
@ -60,8 +60,8 @@ schema = 3
|
|||||||
version = "v0.22.1"
|
version = "v0.22.1"
|
||||||
hash = "sha256-hBU+roIELcmbW2Gz7eGZzL9qNA1bakq5wNxqCgs4TKc="
|
hash = "sha256-hBU+roIELcmbW2Gz7eGZzL9qNA1bakq5wNxqCgs4TKc="
|
||||||
[mod."github.com/btcsuite/btcd/btcec/v2"]
|
[mod."github.com/btcsuite/btcd/btcec/v2"]
|
||||||
version = "v2.2.0"
|
version = "v2.3.2"
|
||||||
hash = "sha256-cwoIqi0SiAaGEBtuQKip9OVirKIeJw5fUoWo7x/xfOc="
|
hash = "sha256-natWs+yIAuD1UI07iZtjPilroQLfXizFn3lNOiOT83U="
|
||||||
[mod."github.com/btcsuite/btcd/chaincfg/chainhash"]
|
[mod."github.com/btcsuite/btcd/chaincfg/chainhash"]
|
||||||
version = "v1.0.1"
|
version = "v1.0.1"
|
||||||
hash = "sha256-vix0j/KGNvoKjhlKgVeSLY6un2FHeIEoZWMC4z3yvZ4="
|
hash = "sha256-vix0j/KGNvoKjhlKgVeSLY6un2FHeIEoZWMC4z3yvZ4="
|
||||||
@ -91,14 +91,14 @@ schema = 3
|
|||||||
hash = "sha256-mFKxFHp7RaE1L5NdtH9H9px2Cy6I5uOZVnFOgE8Nrew="
|
hash = "sha256-mFKxFHp7RaE1L5NdtH9H9px2Cy6I5uOZVnFOgE8Nrew="
|
||||||
replaced = "github.com/cosmos/cosmos-sdk/ics23/go"
|
replaced = "github.com/cosmos/cosmos-sdk/ics23/go"
|
||||||
[mod."github.com/cosmos/btcutil"]
|
[mod."github.com/cosmos/btcutil"]
|
||||||
version = "v1.0.4"
|
version = "v1.0.5"
|
||||||
hash = "sha256-JvcBXBdjdmnaW/nyf/tw/uaOAGn1b78yxrtl2/Rs3kA="
|
hash = "sha256-t572Sr5iiHcuMKLMWa2i+LBAt192oa+G1oA371tG/eI="
|
||||||
[mod."github.com/cosmos/cosmos-proto"]
|
[mod."github.com/cosmos/cosmos-proto"]
|
||||||
version = "v1.0.0-beta.1"
|
version = "v1.0.0-beta.1"
|
||||||
hash = "sha256-oATkuj+fM5eBn+ywO+w/tL0AFSIEkx0J3Yz+VhVe0QA="
|
hash = "sha256-oATkuj+fM5eBn+ywO+w/tL0AFSIEkx0J3Yz+VhVe0QA="
|
||||||
[mod."github.com/cosmos/cosmos-sdk"]
|
[mod."github.com/cosmos/cosmos-sdk"]
|
||||||
version = "v0.46.6"
|
version = "v0.46.7"
|
||||||
hash = "sha256-H1VZxZUWXhpXiY3A9smLp09MEGpXmh+XvX6YUiXPcpQ="
|
hash = "sha256-54DCF8lrnA1oUmBJlbUlWXOP5UbenRInUROn5P5I9qI="
|
||||||
[mod."github.com/cosmos/go-bip39"]
|
[mod."github.com/cosmos/go-bip39"]
|
||||||
version = "v1.0.0"
|
version = "v1.0.0"
|
||||||
hash = "sha256-Qm2aC2vaS8tjtMUbHmlBSagOSqbduEEDwc51qvQaBmA="
|
hash = "sha256-Qm2aC2vaS8tjtMUbHmlBSagOSqbduEEDwc51qvQaBmA="
|
||||||
@ -112,14 +112,11 @@ schema = 3
|
|||||||
version = "v0.19.4"
|
version = "v0.19.4"
|
||||||
hash = "sha256-EmpRZ48pjPFq/fIHneut9Vyo5QJATfb3ZO7KzWnqs9g="
|
hash = "sha256-EmpRZ48pjPFq/fIHneut9Vyo5QJATfb3ZO7KzWnqs9g="
|
||||||
[mod."github.com/cosmos/ibc-go/v5"]
|
[mod."github.com/cosmos/ibc-go/v5"]
|
||||||
version = "v5.1.0"
|
version = "v5.2.0"
|
||||||
hash = "sha256-9ZwGw6XqYkBtj+vTQ2IodNb7VcGesTFnVsxjd+G1I6Q="
|
hash = "sha256-Gfqhdz9ZKEgb7LCkHiXCwYZYUYluQ+vMew/GkssfVj8="
|
||||||
[mod."github.com/cosmos/ledger-cosmos-go"]
|
[mod."github.com/cosmos/ledger-cosmos-go"]
|
||||||
version = "v0.11.1"
|
version = "v0.12.1"
|
||||||
hash = "sha256-yli+VvVtZmHo2LPvCY6lYVUfcCDn3sBLDL+a8KIlqDA="
|
hash = "sha256-9+nr+/r4MyiogddS0JcXOuriPqXP4nxln8ts+mYQRcg="
|
||||||
[mod."github.com/cosmos/ledger-go"]
|
|
||||||
version = "v0.9.2"
|
|
||||||
hash = "sha256-0YI+0A6wFBjiebBwzWOQjkgXkTakCrf7Gjg2xEaQdoM="
|
|
||||||
[mod."github.com/creachadair/taskgroup"]
|
[mod."github.com/creachadair/taskgroup"]
|
||||||
version = "v0.3.2"
|
version = "v0.3.2"
|
||||||
hash = "sha256-Y261IO/d9xjV0UScqHvo31broxvnKn4IQQC9Mu6jNkE="
|
hash = "sha256-Y261IO/d9xjV0UScqHvo31broxvnKn4IQQC9Mu6jNkE="
|
||||||
@ -362,11 +359,11 @@ schema = 3
|
|||||||
version = "v0.0.5"
|
version = "v0.0.5"
|
||||||
hash = "sha256-/5i70IkH/qSW5KjGzv8aQNKh9tHoz98tqtL0K2DMFn4="
|
hash = "sha256-/5i70IkH/qSW5KjGzv8aQNKh9tHoz98tqtL0K2DMFn4="
|
||||||
[mod."github.com/onsi/ginkgo/v2"]
|
[mod."github.com/onsi/ginkgo/v2"]
|
||||||
version = "v2.5.1"
|
version = "v2.6.1"
|
||||||
hash = "sha256-VB29+H9k7l6il63oXJvsjamSUhsw/e99iI/BeTCderA="
|
hash = "sha256-OEiWYKCGPCaqL3vzSrHquHGm+Q8URT2anpanAVK5hRo="
|
||||||
[mod."github.com/onsi/gomega"]
|
[mod."github.com/onsi/gomega"]
|
||||||
version = "v1.24.1"
|
version = "v1.24.2"
|
||||||
hash = "sha256-REfxQTDRcO23GnmJfOW8/MmPJf9oE2grVvvGiC1eSbo="
|
hash = "sha256-iascSzzBT1Uv/XybezSblIwwrq78BU4a9BVB5MvK6MM="
|
||||||
[mod."github.com/pelletier/go-toml"]
|
[mod."github.com/pelletier/go-toml"]
|
||||||
version = "v1.9.5"
|
version = "v1.9.5"
|
||||||
hash = "sha256-RJ9K1BTId0Mled7S66iGgxHkZ5JKEIsrrNaEfM8aImc="
|
hash = "sha256-RJ9K1BTId0Mled7S66iGgxHkZ5JKEIsrrNaEfM8aImc="
|
||||||
@ -464,8 +461,8 @@ schema = 3
|
|||||||
version = "v0.16.0"
|
version = "v0.16.0"
|
||||||
hash = "sha256-JW4zO/0vMzf1dXLePOqaMtiLUZgNbuIseh9GV+jQlf0="
|
hash = "sha256-JW4zO/0vMzf1dXLePOqaMtiLUZgNbuIseh9GV+jQlf0="
|
||||||
[mod."github.com/tendermint/tendermint"]
|
[mod."github.com/tendermint/tendermint"]
|
||||||
version = "v0.34.23"
|
version = "v0.34.24"
|
||||||
hash = "sha256-eir0vr8lQOG+FTPo+ZUeDidAIACfyUq2ie3XRE8rIa4="
|
hash = "sha256-3HFTv4XgN535RDaJ5OwUS+fnJHgkmLTwU7CNU2ilxEQ="
|
||||||
[mod."github.com/tendermint/tm-db"]
|
[mod."github.com/tendermint/tm-db"]
|
||||||
version = "v0.6.7"
|
version = "v0.6.7"
|
||||||
hash = "sha256-hl/3RrBrpkk2zA6dmrNlIYKs1/GfqegSscDSkA5Pjlo="
|
hash = "sha256-hl/3RrBrpkk2zA6dmrNlIYKs1/GfqegSscDSkA5Pjlo="
|
||||||
@ -482,8 +479,11 @@ schema = 3
|
|||||||
version = "v0.5.8"
|
version = "v0.5.8"
|
||||||
hash = "sha256-bfG3dssBUn+mSOAuKL+a/DTGGLUA+eASgLoGv/Gkqs0="
|
hash = "sha256-bfG3dssBUn+mSOAuKL+a/DTGGLUA+eASgLoGv/Gkqs0="
|
||||||
[mod."github.com/zondax/hid"]
|
[mod."github.com/zondax/hid"]
|
||||||
version = "v0.9.1-0.20220302062450-5552068d2266"
|
version = "v0.9.1"
|
||||||
hash = "sha256-IZea8SHuLQxlltm1avieRVI054TWZg2jEoplodvNtwk="
|
hash = "sha256-hSVmN/f/lQHFhF60o6ej78ELC0MMoqQgqIX2hHjdTXg="
|
||||||
|
[mod."github.com/zondax/ledger-go"]
|
||||||
|
version = "v0.14.0"
|
||||||
|
hash = "sha256-RozTPSNs4RerZ4DQMBcGmvREjoRtH1G69xjhccYjIOk="
|
||||||
[mod."go.etcd.io/bbolt"]
|
[mod."go.etcd.io/bbolt"]
|
||||||
version = "v1.3.6"
|
version = "v1.3.6"
|
||||||
hash = "sha256-DenVAmyN22xUiivk6fdJp4C9ZnUJXCMDUf8E0goRRV4="
|
hash = "sha256-DenVAmyN22xUiivk6fdJp4C9ZnUJXCMDUf8E0goRRV4="
|
||||||
@ -497,8 +497,8 @@ schema = 3
|
|||||||
version = "v0.0.0-20220722155223-a9213eeb770e"
|
version = "v0.0.0-20220722155223-a9213eeb770e"
|
||||||
hash = "sha256-kNgzydWRpjm0sZl4uXEs3LX5L0xjJtJRAFf/CTlYUN4="
|
hash = "sha256-kNgzydWRpjm0sZl4uXEs3LX5L0xjJtJRAFf/CTlYUN4="
|
||||||
[mod."golang.org/x/net"]
|
[mod."golang.org/x/net"]
|
||||||
version = "v0.2.0"
|
version = "v0.4.0"
|
||||||
hash = "sha256-0MqnHDdLkkau6k7hlWD9MzIoAFROvxulyT+KzZkSXOs="
|
hash = "sha256-7IwGZh/xg4mQz88cJio2Ov5d3jGRXKj1itlAja/EAbQ="
|
||||||
[mod."golang.org/x/oauth2"]
|
[mod."golang.org/x/oauth2"]
|
||||||
version = "v0.0.0-20221014153046-6fdb5e3db783"
|
version = "v0.0.0-20221014153046-6fdb5e3db783"
|
||||||
hash = "sha256-IoygidVNqyAZmN+3macDeIefK8hhJToygpcqlwehdYQ="
|
hash = "sha256-IoygidVNqyAZmN+3macDeIefK8hhJToygpcqlwehdYQ="
|
||||||
@ -506,11 +506,11 @@ schema = 3
|
|||||||
version = "v0.1.0"
|
version = "v0.1.0"
|
||||||
hash = "sha256-Hygjq9euZ0qz6TvHYQwOZEjNiTbTh1nSLRAWZ6KFGR8="
|
hash = "sha256-Hygjq9euZ0qz6TvHYQwOZEjNiTbTh1nSLRAWZ6KFGR8="
|
||||||
[mod."golang.org/x/sys"]
|
[mod."golang.org/x/sys"]
|
||||||
version = "v0.2.0"
|
version = "v0.3.0"
|
||||||
hash = "sha256-N6yfQH7R2gfcvyWTQZbxWuSNyVy6hAxiab2WFzgAykI="
|
hash = "sha256-TIHhfYbZ99sCU1ZMikxwomXH5AEtD/lA1VMMW+UAhbU="
|
||||||
[mod."golang.org/x/term"]
|
[mod."golang.org/x/term"]
|
||||||
version = "v0.2.0"
|
version = "v0.3.0"
|
||||||
hash = "sha256-azcllZ0o/9TurqX9udaJ0o9yxqSoI0/bSJsvQQLYIQc="
|
hash = "sha256-NKv2o8wz8DB/2W2h/muGEIHb+S06mBXZxhG254RpQ5s="
|
||||||
[mod."golang.org/x/text"]
|
[mod."golang.org/x/text"]
|
||||||
version = "v0.5.0"
|
version = "v0.5.0"
|
||||||
hash = "sha256-ztH+xQyM/clOcQl+y/UEPcfNKbc3xApMbEPDDZ9up0o="
|
hash = "sha256-ztH+xQyM/clOcQl+y/UEPcfNKbc3xApMbEPDDZ9up0o="
|
||||||
|
@ -2,13 +2,14 @@ local config = import 'default.jsonnet';
|
|||||||
|
|
||||||
config {
|
config {
|
||||||
'ethermint_9000-1'+: {
|
'ethermint_9000-1'+: {
|
||||||
|
'app-config'+: {
|
||||||
|
'minimum-gas-prices': '100000000000aphoton',
|
||||||
|
},
|
||||||
genesis+: {
|
genesis+: {
|
||||||
app_state+: {
|
app_state+: {
|
||||||
feemarket+: {
|
feemarket+: {
|
||||||
params+: {
|
params+: {
|
||||||
no_base_fee: false,
|
|
||||||
base_fee:: super.base_fee,
|
base_fee:: super.base_fee,
|
||||||
initial_base_fee: super.base_fee,
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -4,10 +4,6 @@
|
|||||||
cmd: 'ethermintd',
|
cmd: 'ethermintd',
|
||||||
'start-flags': '--trace',
|
'start-flags': '--trace',
|
||||||
config: {
|
config: {
|
||||||
consensus: {
|
|
||||||
// larger timeout for more stable mempool tests
|
|
||||||
timeout_commit: '2s',
|
|
||||||
},
|
|
||||||
mempool: {
|
mempool: {
|
||||||
// use v1 mempool to enable tx prioritization
|
// use v1 mempool to enable tx prioritization
|
||||||
version: 'v1',
|
version: 'v1',
|
||||||
|
@ -8,13 +8,18 @@ config {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
'app-config'+: {
|
'app-config'+: {
|
||||||
pruning: 'everything',
|
|
||||||
'state-sync'+: {
|
|
||||||
'snapshot-interval': 0,
|
|
||||||
},
|
|
||||||
'json-rpc'+: {
|
'json-rpc'+: {
|
||||||
'enable-indexer': true,
|
'enable-indexer': true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
genesis+: {
|
||||||
|
app_state+: {
|
||||||
|
feemarket+: {
|
||||||
|
params+: {
|
||||||
|
min_gas_multiplier: '0',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
11
tests/integration_tests/configs/long_timeout_commit.jsonnet
Normal file
11
tests/integration_tests/configs/long_timeout_commit.jsonnet
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
local default = import 'default.jsonnet';
|
||||||
|
|
||||||
|
default {
|
||||||
|
'ethermint_9000-1'+: {
|
||||||
|
config+: {
|
||||||
|
consensus+: {
|
||||||
|
timeout_commit: '5s',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
@ -8,5 +8,14 @@ config {
|
|||||||
'snapshot-interval': 0,
|
'snapshot-interval': 0,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
genesis+: {
|
||||||
|
app_state+: {
|
||||||
|
feemarket+: {
|
||||||
|
params+: {
|
||||||
|
min_gas_multiplier: '0',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@ local config = import 'default.jsonnet';
|
|||||||
|
|
||||||
config {
|
config {
|
||||||
'ethermint_9000-1'+: {
|
'ethermint_9000-1'+: {
|
||||||
validators: super.validators + [{
|
validators: super.validators[0:1] + [{
|
||||||
name: 'fullnode',
|
name: 'fullnode',
|
||||||
}],
|
}],
|
||||||
},
|
},
|
||||||
|
@ -4,9 +4,9 @@ let
|
|||||||
released = pkgs.buildGo118Module rec {
|
released = pkgs.buildGo118Module rec {
|
||||||
name = "ethermintd";
|
name = "ethermintd";
|
||||||
# the commit before https://github.com/evmos/ethermint/pull/943
|
# the commit before https://github.com/evmos/ethermint/pull/943
|
||||||
src = fetchEthermint "f21592ebfe74da7590eb42ed926dae970b2a9a3f";
|
src = fetchEthermint "8866ae0ffd67a104e9d1cf4e50fba8391dda6c45";
|
||||||
subPackages = [ "cmd/ethermintd" ];
|
subPackages = [ "cmd/ethermintd" ];
|
||||||
vendorSha256 = "sha256-ABm5t6R/u2S6pThGrgdsqe8n3fH5tIWw7a57kxJPbYw=";
|
vendorSha256 = "sha256-oDtMamNlwe/393fZd+RNtRy6ipWpusbco8Xg1ZuKWYw=";
|
||||||
doCheck = false;
|
doCheck = false;
|
||||||
};
|
};
|
||||||
current = pkgs.callPackage ../../../. { };
|
current = pkgs.callPackage ../../../. { };
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
from pathlib import Path
|
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
from .network import setup_custom_ethermint, setup_ethermint, setup_geth
|
from .network import setup_ethermint, setup_geth
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="session")
|
@pytest.fixture(scope="session")
|
||||||
@ -11,42 +9,12 @@ def ethermint(tmp_path_factory):
|
|||||||
yield from setup_ethermint(path, 26650)
|
yield from setup_ethermint(path, 26650)
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="session")
|
|
||||||
def ethermint_indexer(tmp_path_factory):
|
|
||||||
path = tmp_path_factory.mktemp("indexer")
|
|
||||||
yield from setup_custom_ethermint(
|
|
||||||
path, 26660, Path(__file__).parent / "configs/enable-indexer.jsonnet"
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope="session")
|
@pytest.fixture(scope="session")
|
||||||
def geth(tmp_path_factory):
|
def geth(tmp_path_factory):
|
||||||
path = tmp_path_factory.mktemp("geth")
|
path = tmp_path_factory.mktemp("geth")
|
||||||
yield from setup_geth(path, 8545)
|
yield from setup_geth(path, 8545)
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(
|
|
||||||
scope="session", params=["ethermint", "geth", "ethermint-ws", "enable-indexer"]
|
|
||||||
)
|
|
||||||
def cluster(request, ethermint, ethermint_indexer, geth):
|
|
||||||
"""
|
|
||||||
run on both ethermint and geth
|
|
||||||
"""
|
|
||||||
provider = request.param
|
|
||||||
if provider == "ethermint":
|
|
||||||
yield ethermint
|
|
||||||
elif provider == "geth":
|
|
||||||
yield geth
|
|
||||||
elif provider == "ethermint-ws":
|
|
||||||
ethermint_ws = ethermint.copy()
|
|
||||||
ethermint_ws.use_websocket()
|
|
||||||
yield ethermint_ws
|
|
||||||
elif provider == "enable-indexer":
|
|
||||||
yield ethermint_indexer
|
|
||||||
else:
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(
|
@pytest.fixture(
|
||||||
scope="session", params=["ethermint", "ethermint-ws"]
|
scope="session", params=["ethermint", "ethermint-ws"]
|
||||||
)
|
)
|
||||||
|
@ -6,6 +6,7 @@ from dateutil.parser import isoparse
|
|||||||
from pystarport.utils import build_cli_args_safe, interact
|
from pystarport.utils import build_cli_args_safe, interact
|
||||||
|
|
||||||
DEFAULT_GAS_PRICE = "5000000000000aphoton"
|
DEFAULT_GAS_PRICE = "5000000000000aphoton"
|
||||||
|
DEFAULT_GAS = "250000"
|
||||||
|
|
||||||
|
|
||||||
class ChainCommand:
|
class ChainCommand:
|
||||||
@ -636,16 +637,19 @@ class CosmosCLI:
|
|||||||
)
|
)
|
||||||
|
|
||||||
def gov_propose(self, proposer, kind, proposal, **kwargs):
|
def gov_propose(self, proposer, kind, proposal, **kwargs):
|
||||||
|
method = "submit-legacy-proposal"
|
||||||
kwargs.setdefault("gas_prices", DEFAULT_GAS_PRICE)
|
kwargs.setdefault("gas_prices", DEFAULT_GAS_PRICE)
|
||||||
|
kwargs.setdefault("gas", DEFAULT_GAS)
|
||||||
if kind == "software-upgrade":
|
if kind == "software-upgrade":
|
||||||
return json.loads(
|
return json.loads(
|
||||||
self.raw(
|
self.raw(
|
||||||
"tx",
|
"tx",
|
||||||
"gov",
|
"gov",
|
||||||
"submit-proposal",
|
method,
|
||||||
kind,
|
kind,
|
||||||
proposal["name"],
|
proposal["name"],
|
||||||
"-y",
|
"-y",
|
||||||
|
"--no-validate",
|
||||||
from_=proposer,
|
from_=proposer,
|
||||||
# content
|
# content
|
||||||
title=proposal.get("title"),
|
title=proposal.get("title"),
|
||||||
@ -664,7 +668,7 @@ class CosmosCLI:
|
|||||||
self.raw(
|
self.raw(
|
||||||
"tx",
|
"tx",
|
||||||
"gov",
|
"gov",
|
||||||
"submit-proposal",
|
method,
|
||||||
kind,
|
kind,
|
||||||
"-y",
|
"-y",
|
||||||
from_=proposer,
|
from_=proposer,
|
||||||
@ -685,7 +689,7 @@ class CosmosCLI:
|
|||||||
self.raw(
|
self.raw(
|
||||||
"tx",
|
"tx",
|
||||||
"gov",
|
"gov",
|
||||||
"submit-proposal",
|
method,
|
||||||
kind,
|
kind,
|
||||||
fp.name,
|
fp.name,
|
||||||
"-y",
|
"-y",
|
||||||
|
File diff suppressed because one or more lines are too long
@ -68,8 +68,12 @@ class Geth:
|
|||||||
self.w3 = w3
|
self.w3 = w3
|
||||||
|
|
||||||
|
|
||||||
def setup_ethermint(path, base_port):
|
def setup_ethermint(path, base_port, long_timeout_commit=False):
|
||||||
cfg = Path(__file__).parent / "configs/default.jsonnet"
|
cfg = Path(__file__).parent / (
|
||||||
|
"configs/default.jsonnet"
|
||||||
|
if long_timeout_commit
|
||||||
|
else "configs/long_timeout_commit.jsonnet"
|
||||||
|
)
|
||||||
yield from setup_custom_ethermint(path, base_port, cfg)
|
yield from setup_custom_ethermint(path, base_port, cfg)
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,3 +0,0 @@
|
|||||||
def test_basic(cluster):
|
|
||||||
w3 = cluster.w3
|
|
||||||
assert w3.eth.chain_id == 9000
|
|
@ -1,8 +1,11 @@
|
|||||||
|
from pathlib import Path
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
from eth_abi import abi
|
from eth_abi import abi
|
||||||
from hexbytes import HexBytes
|
from hexbytes import HexBytes
|
||||||
from web3 import Web3
|
from web3 import Web3
|
||||||
|
|
||||||
|
from .network import setup_custom_ethermint, setup_ethermint
|
||||||
from .utils import (
|
from .utils import (
|
||||||
ADDRS,
|
ADDRS,
|
||||||
CONTRACTS,
|
CONTRACTS,
|
||||||
@ -12,6 +15,48 @@ from .utils import (
|
|||||||
w3_wait_for_new_blocks,
|
w3_wait_for_new_blocks,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="module")
|
||||||
|
def custom_ethermint(tmp_path_factory):
|
||||||
|
path = tmp_path_factory.mktemp("filters")
|
||||||
|
yield from setup_ethermint(path, 26200, long_timeout_commit=True)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="module")
|
||||||
|
def ethermint_indexer(tmp_path_factory):
|
||||||
|
path = tmp_path_factory.mktemp("indexer")
|
||||||
|
yield from setup_custom_ethermint(
|
||||||
|
path, 26660, Path(__file__).parent / "configs/enable-indexer.jsonnet"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(
|
||||||
|
scope="module", params=["ethermint", "geth", "ethermint-ws", "enable-indexer"]
|
||||||
|
)
|
||||||
|
def cluster(request, custom_ethermint, ethermint_indexer, geth):
|
||||||
|
"""
|
||||||
|
run on both ethermint and geth
|
||||||
|
"""
|
||||||
|
provider = request.param
|
||||||
|
if provider == "ethermint":
|
||||||
|
yield custom_ethermint
|
||||||
|
elif provider == "geth":
|
||||||
|
yield geth
|
||||||
|
elif provider == "ethermint-ws":
|
||||||
|
ethermint_ws = custom_ethermint.copy()
|
||||||
|
ethermint_ws.use_websocket()
|
||||||
|
yield ethermint_ws
|
||||||
|
elif provider == "enable-indexer":
|
||||||
|
yield ethermint_indexer
|
||||||
|
else:
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
|
||||||
|
def test_basic(cluster):
|
||||||
|
w3 = cluster.w3
|
||||||
|
assert w3.eth.chain_id == 9000
|
||||||
|
|
||||||
|
|
||||||
# Smart contract names
|
# Smart contract names
|
||||||
GREETER_CONTRACT = "Greeter"
|
GREETER_CONTRACT = "Greeter"
|
||||||
ERC20_CONTRACT = "TestERC20A"
|
ERC20_CONTRACT = "TestERC20A"
|
||||||
@ -58,6 +103,7 @@ def test_pending_transaction_filter(cluster):
|
|||||||
# without tx
|
# without tx
|
||||||
assert flt.get_new_entries() == [] # GetFilterChanges
|
assert flt.get_new_entries() == [] # GetFilterChanges
|
||||||
|
|
||||||
|
w3_wait_for_new_blocks(w3, 1, sleep=0.1)
|
||||||
# with tx
|
# with tx
|
||||||
txhash = send_successful_transaction(w3)
|
txhash = send_successful_transaction(w3)
|
||||||
assert txhash in flt.get_new_entries()
|
assert txhash in flt.get_new_entries()
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import base64
|
import base64
|
||||||
import json
|
import json
|
||||||
import subprocess
|
import subprocess
|
||||||
|
import time
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
@ -13,6 +14,7 @@ from .utils import (
|
|||||||
decode_bech32,
|
decode_bech32,
|
||||||
deploy_contract,
|
deploy_contract,
|
||||||
supervisorctl,
|
supervisorctl,
|
||||||
|
wait_for_block,
|
||||||
wait_for_port,
|
wait_for_port,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -45,9 +47,6 @@ def grpc_eth_call(port: int, args: dict, chain_id=None, proposer_address=None):
|
|||||||
).json()
|
).json()
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.skip(
|
|
||||||
reason="undeterministic test - https://github.com/evmos/ethermint/issues/1530"
|
|
||||||
)
|
|
||||||
def test_grpc_mode(custom_ethermint):
|
def test_grpc_mode(custom_ethermint):
|
||||||
"""
|
"""
|
||||||
- restart a fullnode in grpc-only mode
|
- restart a fullnode in grpc-only mode
|
||||||
@ -61,33 +60,43 @@ def test_grpc_mode(custom_ethermint):
|
|||||||
"to": contract.address,
|
"to": contract.address,
|
||||||
"data": contract.encodeABI(fn_name="currentChainID"),
|
"data": contract.encodeABI(fn_name="currentChainID"),
|
||||||
}
|
}
|
||||||
api_port = ports.api_port(custom_ethermint.base_port(2))
|
api_port = ports.api_port(custom_ethermint.base_port(1))
|
||||||
# in normal mode, grpc query works even if we don't pass chain_id explicitly
|
# in normal mode, grpc query works even if we don't pass chain_id explicitly
|
||||||
|
success = False
|
||||||
|
max_retry = 3
|
||||||
|
sleep = 1
|
||||||
|
for i in range(max_retry):
|
||||||
rsp = grpc_eth_call(api_port, msg)
|
rsp = grpc_eth_call(api_port, msg)
|
||||||
print(rsp)
|
ret = rsp["ret"]
|
||||||
assert "code" not in rsp, str(rsp)
|
valid = ret is not None
|
||||||
assert 9000 == int.from_bytes(base64.b64decode(rsp["ret"].encode()), "big")
|
if valid and 9000 == int.from_bytes(base64.b64decode(ret.encode()), "big"):
|
||||||
|
success = True
|
||||||
|
break
|
||||||
|
time.sleep(sleep)
|
||||||
|
assert success
|
||||||
|
# wait 1 more block for both nodes to avoid node stopped before tnx get included
|
||||||
|
for i in range(2):
|
||||||
|
wait_for_block(custom_ethermint.cosmos_cli(i), 1)
|
||||||
supervisorctl(
|
supervisorctl(
|
||||||
custom_ethermint.base_dir / "../tasks.ini", "stop", "ethermint_9000-1-node2"
|
custom_ethermint.base_dir / "../tasks.ini", "stop", "ethermint_9000-1-node1"
|
||||||
)
|
)
|
||||||
|
|
||||||
# run grpc-only mode directly with existing chain state
|
# run grpc-only mode directly with existing chain state
|
||||||
with (custom_ethermint.base_dir / "node2.log").open("w") as logfile:
|
with (custom_ethermint.base_dir / "node1.log").open("a") as logfile:
|
||||||
proc = subprocess.Popen(
|
proc = subprocess.Popen(
|
||||||
[
|
[
|
||||||
"ethermintd",
|
"ethermintd",
|
||||||
"start",
|
"start",
|
||||||
"--grpc-only",
|
"--grpc-only",
|
||||||
"--home",
|
"--home",
|
||||||
custom_ethermint.base_dir / "node2",
|
custom_ethermint.base_dir / "node1",
|
||||||
],
|
],
|
||||||
stdout=logfile,
|
stdout=logfile,
|
||||||
stderr=subprocess.STDOUT,
|
stderr=subprocess.STDOUT,
|
||||||
)
|
)
|
||||||
try:
|
try:
|
||||||
# wait for grpc and rest api ports
|
# wait for grpc and rest api ports
|
||||||
grpc_port = ports.grpc_port(custom_ethermint.base_port(2))
|
grpc_port = ports.grpc_port(custom_ethermint.base_port(1))
|
||||||
wait_for_port(grpc_port)
|
wait_for_port(grpc_port)
|
||||||
wait_for_port(api_port)
|
wait_for_port(api_port)
|
||||||
|
|
||||||
@ -102,9 +111,8 @@ def test_grpc_mode(custom_ethermint):
|
|||||||
assert "validator does not exist" in rsp["message"]
|
assert "validator does not exist" in rsp["message"]
|
||||||
|
|
||||||
# pass the first validator's consensus address to grpc query
|
# pass the first validator's consensus address to grpc query
|
||||||
cons_addr = decode_bech32(
|
addr = custom_ethermint.cosmos_cli(0).consensus_address()
|
||||||
custom_ethermint.cosmos_cli(0).consensus_address()
|
cons_addr = decode_bech32(addr)
|
||||||
)
|
|
||||||
|
|
||||||
# should work with both chain_id and proposer_address set
|
# should work with both chain_id and proposer_address set
|
||||||
rsp = grpc_eth_call(
|
rsp = grpc_eth_call(
|
||||||
|
@ -1,11 +1,19 @@
|
|||||||
import sys
|
import sys
|
||||||
|
|
||||||
from .network import Ethermint
|
import pytest
|
||||||
|
|
||||||
|
from .network import setup_ethermint
|
||||||
from .utils import ADDRS, KEYS, eth_to_bech32, sign_transaction, wait_for_new_blocks
|
from .utils import ADDRS, KEYS, eth_to_bech32, sign_transaction, wait_for_new_blocks
|
||||||
|
|
||||||
PRIORITY_REDUCTION = 1000000
|
PRIORITY_REDUCTION = 1000000
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(scope="module")
|
||||||
|
def custom_ethermint(tmp_path_factory):
|
||||||
|
path = tmp_path_factory.mktemp("priority")
|
||||||
|
yield from setup_ethermint(path, 26800, long_timeout_commit=True)
|
||||||
|
|
||||||
|
|
||||||
def effective_gas_price(tx, base_fee):
|
def effective_gas_price(tx, base_fee):
|
||||||
if "maxFeePerGas" in tx:
|
if "maxFeePerGas" in tx:
|
||||||
# dynamic fee tx
|
# dynamic fee tx
|
||||||
@ -27,7 +35,7 @@ def tx_priority(tx, base_fee):
|
|||||||
return (tx["gasPrice"] - base_fee) // PRIORITY_REDUCTION
|
return (tx["gasPrice"] - base_fee) // PRIORITY_REDUCTION
|
||||||
|
|
||||||
|
|
||||||
def test_priority(ethermint: Ethermint):
|
def test_priority(ethermint):
|
||||||
"""
|
"""
|
||||||
test priorities of different tx types
|
test priorities of different tx types
|
||||||
|
|
||||||
@ -112,7 +120,7 @@ def test_priority(ethermint: Ethermint):
|
|||||||
assert all(i1 > i2 for i1, i2 in zip(tx_indexes, tx_indexes[1:]))
|
assert all(i1 > i2 for i1, i2 in zip(tx_indexes, tx_indexes[1:]))
|
||||||
|
|
||||||
|
|
||||||
def test_native_tx_priority(ethermint: Ethermint):
|
def test_native_tx_priority(ethermint):
|
||||||
cli = ethermint.cosmos_cli()
|
cli = ethermint.cosmos_cli()
|
||||||
base_fee = cli.query_base_fee()
|
base_fee = cli.query_base_fee()
|
||||||
print("base_fee", base_fee)
|
print("base_fee", base_fee)
|
||||||
|
@ -103,7 +103,7 @@ def test_pruned_node(pruned):
|
|||||||
exp_tx = AttributeDict(
|
exp_tx = AttributeDict(
|
||||||
{
|
{
|
||||||
"from": "0x57f96e6B86CdeFdB3d412547816a82E3E0EbF9D2",
|
"from": "0x57f96e6B86CdeFdB3d412547816a82E3E0EbF9D2",
|
||||||
"gas": 51542,
|
"gas": 51406,
|
||||||
"input": (
|
"input": (
|
||||||
"0xa9059cbb000000000000000000000000378c50d9264c63f3f92b806d4ee56e"
|
"0xa9059cbb000000000000000000000000378c50d9264c63f3f92b806d4ee56e"
|
||||||
"9d86ffb3ec000000000000000000000000000000000000000000000000000000"
|
"9d86ffb3ec000000000000000000000000000000000000000000000000000000"
|
||||||
|
@ -10,7 +10,7 @@ from .network import setup_custom_ethermint
|
|||||||
from .utils import supervisorctl, wait_for_block, wait_for_port
|
from .utils import supervisorctl, wait_for_block, wait_for_port
|
||||||
|
|
||||||
|
|
||||||
def update_node2_cmd(path, cmd, i):
|
def update_node_cmd(path, cmd, i):
|
||||||
ini_path = path / SUPERVISOR_CONFIG_FILE
|
ini_path = path / SUPERVISOR_CONFIG_FILE
|
||||||
ini = configparser.RawConfigParser()
|
ini = configparser.RawConfigParser()
|
||||||
ini.read(ini_path)
|
ini.read(ini_path)
|
||||||
@ -29,7 +29,7 @@ def update_node2_cmd(path, cmd, i):
|
|||||||
def post_init(broken_binary):
|
def post_init(broken_binary):
|
||||||
def inner(path, base_port, config):
|
def inner(path, base_port, config):
|
||||||
chain_id = "ethermint_9000-1"
|
chain_id = "ethermint_9000-1"
|
||||||
update_node2_cmd(path / chain_id, broken_binary, 2)
|
update_node_cmd(path / chain_id, broken_binary, 1)
|
||||||
|
|
||||||
return inner
|
return inner
|
||||||
|
|
||||||
@ -66,33 +66,33 @@ def test_rollback(custom_ethermint):
|
|||||||
- use rollback command to rollback the db.
|
- use rollback command to rollback the db.
|
||||||
- switch to correct binary should make the node syncing again.
|
- switch to correct binary should make the node syncing again.
|
||||||
"""
|
"""
|
||||||
wait_for_port(ports.rpc_port(custom_ethermint.base_port(2)))
|
target_port = ports.rpc_port(custom_ethermint.base_port(1))
|
||||||
|
wait_for_port(target_port)
|
||||||
|
|
||||||
print("wait for node2 to sync the first 10 blocks")
|
print("wait for node1 to sync the first 10 blocks")
|
||||||
cli2 = custom_ethermint.cosmos_cli(2)
|
cli1 = custom_ethermint.cosmos_cli(1)
|
||||||
wait_for_block(cli2, 10)
|
wait_for_block(cli1, 10)
|
||||||
|
|
||||||
print("wait for a few more blocks on the healthy nodes")
|
print("wait for a few more blocks on the healthy nodes")
|
||||||
cli = custom_ethermint.cosmos_cli(0)
|
cli0 = custom_ethermint.cosmos_cli(0)
|
||||||
wait_for_block(cli, 13)
|
wait_for_block(cli0, 13)
|
||||||
|
|
||||||
# (app hash mismatch happens after the 10th block, detected in the 11th block)
|
# (app hash mismatch happens after the 10th block, detected in the 11th block)
|
||||||
print("check node2 get stuck at block 10")
|
print("check node1 get stuck at block 10")
|
||||||
assert cli2.block_height() == 10
|
assert cli1.block_height() == 10
|
||||||
|
|
||||||
print("stop node2")
|
print("stop node1")
|
||||||
supervisorctl(
|
supervisorctl(
|
||||||
custom_ethermint.base_dir / "../tasks.ini", "stop", "ethermint_9000-1-node2"
|
custom_ethermint.base_dir / "../tasks.ini", "stop", "ethermint_9000-1-node1"
|
||||||
)
|
)
|
||||||
|
|
||||||
print("do rollback on node2")
|
print("do rollback on node1")
|
||||||
cli2.rollback()
|
cli1.rollback()
|
||||||
|
|
||||||
print("switch to normal binary")
|
print("switch to normal binary")
|
||||||
update_node2_cmd(custom_ethermint.base_dir, "ethermintd", 2)
|
update_node_cmd(custom_ethermint.base_dir, "ethermintd", 1)
|
||||||
supervisorctl(custom_ethermint.base_dir / "../tasks.ini", "update")
|
supervisorctl(custom_ethermint.base_dir / "../tasks.ini", "update")
|
||||||
wait_for_port(ports.rpc_port(custom_ethermint.base_port(2)))
|
wait_for_port(target_port)
|
||||||
|
|
||||||
print("check node2 sync again")
|
print("check node1 sync again")
|
||||||
cli2 = custom_ethermint.cosmos_cli(2)
|
wait_for_block(cli1, 15)
|
||||||
wait_for_block(cli2, 15)
|
|
||||||
|
@ -92,9 +92,6 @@ def test_cosmovisor_upgrade(custom_ethermint: Ethermint):
|
|||||||
- check that queries on legacy blocks still works after upgrade.
|
- check that queries on legacy blocks still works after upgrade.
|
||||||
"""
|
"""
|
||||||
cli = custom_ethermint.cosmos_cli()
|
cli = custom_ethermint.cosmos_cli()
|
||||||
height = cli.block_height()
|
|
||||||
target_height = height + 10
|
|
||||||
print("upgrade height", target_height)
|
|
||||||
|
|
||||||
w3 = custom_ethermint.w3
|
w3 = custom_ethermint.w3
|
||||||
contract, _ = deploy_contract(w3, CONTRACTS["TestERC20A"])
|
contract, _ = deploy_contract(w3, CONTRACTS["TestERC20A"])
|
||||||
@ -104,6 +101,9 @@ def test_cosmovisor_upgrade(custom_ethermint: Ethermint):
|
|||||||
old_erc20_balance = contract.caller.balanceOf(ADDRS["validator"])
|
old_erc20_balance = contract.caller.balanceOf(ADDRS["validator"])
|
||||||
print("old values", old_height, old_balance, old_base_fee)
|
print("old values", old_height, old_balance, old_base_fee)
|
||||||
|
|
||||||
|
target_height = w3.eth.block_number + 10
|
||||||
|
print("upgrade height", target_height)
|
||||||
|
|
||||||
plan_name = "integration-test-upgrade"
|
plan_name = "integration-test-upgrade"
|
||||||
rsp = cli.gov_propose(
|
rsp = cli.gov_propose(
|
||||||
"community",
|
"community",
|
||||||
@ -120,7 +120,6 @@ def test_cosmovisor_upgrade(custom_ethermint: Ethermint):
|
|||||||
|
|
||||||
# get proposal_id
|
# get proposal_id
|
||||||
ev = parse_events(rsp["logs"])["submit_proposal"]
|
ev = parse_events(rsp["logs"])["submit_proposal"]
|
||||||
assert ev["proposal_type"] == "SoftwareUpgrade", rsp
|
|
||||||
proposal_id = ev["proposal_id"]
|
proposal_id = ev["proposal_id"]
|
||||||
|
|
||||||
rsp = cli.gov_vote("validator", proposal_id, "yes")
|
rsp = cli.gov_vote("validator", proposal_id, "yes")
|
||||||
|
@ -74,13 +74,12 @@ def w3_wait_for_new_blocks(w3, n, sleep=0.5):
|
|||||||
break
|
break
|
||||||
|
|
||||||
|
|
||||||
def wait_for_new_blocks(cli, n):
|
def wait_for_new_blocks(cli, n, sleep=0.5):
|
||||||
begin_height = int((cli.status())["SyncInfo"]["latest_block_height"])
|
cur_height = begin_height = int((cli.status())["SyncInfo"]["latest_block_height"])
|
||||||
while True:
|
while cur_height - begin_height < n:
|
||||||
time.sleep(0.5)
|
time.sleep(sleep)
|
||||||
cur_height = int((cli.status())["SyncInfo"]["latest_block_height"])
|
cur_height = int((cli.status())["SyncInfo"]["latest_block_height"])
|
||||||
if cur_height - begin_height >= n:
|
return cur_height
|
||||||
break
|
|
||||||
|
|
||||||
|
|
||||||
def wait_for_block(cli, height, timeout=240):
|
def wait_for_block(cli, height, timeout=240):
|
||||||
|
Loading…
Reference in New Issue
Block a user