chore: bump TM to v0.35.0 release candidate (#10210)
Integrate Tendermint v0.35.0, including changes to build and test plumbing necessary to make everything build. This change does not update any SDK APIs to make use of new features. Co-authored-by: marbar3778 <marbar3778@yahoo.com> Co-authored-by: tycho garen <garen@tychoish.com> Co-authored-by: M. J. Fromberger <michael.j.fromberger@gmail.com> Co-authored-by: Amaury <1293565+amaurym@users.noreply.github.com> Co-authored-by: Callum Waters <cmwaters19@gmail.com>
This commit is contained in:
parent
3f368577ed
commit
af8ad3d20d
|
@ -243,7 +243,7 @@ jobs:
|
||||||
go.sum
|
go.sum
|
||||||
- name: start localnet
|
- name: start localnet
|
||||||
run: |
|
run: |
|
||||||
make clean build-simd-linux localnet-start
|
make clean localnet-start
|
||||||
if: env.GIT_DIFF
|
if: env.GIT_DIFF
|
||||||
- name: test liveness
|
- name: test liveness
|
||||||
run: |
|
run: |
|
||||||
|
|
|
@ -11,6 +11,7 @@ linters:
|
||||||
- depguard
|
- depguard
|
||||||
- dogsled
|
- dogsled
|
||||||
# - errcheck
|
# - errcheck
|
||||||
|
- exportloopref
|
||||||
- goconst
|
- goconst
|
||||||
- gocritic
|
- gocritic
|
||||||
- gofmt
|
- gofmt
|
||||||
|
@ -21,19 +22,17 @@ linters:
|
||||||
- ineffassign
|
- ineffassign
|
||||||
- misspell
|
- misspell
|
||||||
- nakedret
|
- nakedret
|
||||||
|
- nolintlint
|
||||||
- prealloc
|
- prealloc
|
||||||
- revive
|
- revive
|
||||||
- exportloopref
|
|
||||||
- staticcheck
|
- staticcheck
|
||||||
- structcheck
|
- structcheck
|
||||||
- stylecheck
|
- stylecheck
|
||||||
- typecheck
|
- typecheck
|
||||||
- unconvert
|
- unconvert
|
||||||
- unused
|
|
||||||
- unparam
|
- unparam
|
||||||
- misspell
|
- unused
|
||||||
# - wsl
|
# - wsl
|
||||||
- nolintlint
|
|
||||||
|
|
||||||
issues:
|
issues:
|
||||||
exclude-rules:
|
exclude-rules:
|
||||||
|
|
|
@ -54,6 +54,7 @@ Ref: https://keepachangelog.com/en/1.0.0/
|
||||||
|
|
||||||
### Improvements
|
### Improvements
|
||||||
|
|
||||||
|
* (deps) [\#10210](https://github.com/cosmos/cosmos-sdk/pull/10210) Bump Tendermint to [v0.35.0](https://github.com/tendermint/tendermint/releases/tag/v0.35.0).
|
||||||
* [\#10486](https://github.com/cosmos/cosmos-sdk/pull/10486) store/cachekv's `Store.Write` conservatively looks up keys, but also uses the [map clearing idiom](https://bencher.orijtech.com/perfclinic/mapclearing/) to reduce the RAM usage, CPU time usage, and garbage collection pressure from clearing maps, instead of allocating new maps.
|
* [\#10486](https://github.com/cosmos/cosmos-sdk/pull/10486) store/cachekv's `Store.Write` conservatively looks up keys, but also uses the [map clearing idiom](https://bencher.orijtech.com/perfclinic/mapclearing/) to reduce the RAM usage, CPU time usage, and garbage collection pressure from clearing maps, instead of allocating new maps.
|
||||||
|
|
||||||
### API Breaking Changes
|
### API Breaking Changes
|
||||||
|
|
37
Makefile
37
Makefile
|
@ -2,9 +2,9 @@
|
||||||
|
|
||||||
PACKAGES_NOSIMULATION=$(shell go list ./... | grep -v '/simulation')
|
PACKAGES_NOSIMULATION=$(shell go list ./... | grep -v '/simulation')
|
||||||
PACKAGES_SIMTEST=$(shell go list ./... | grep '/simulation')
|
PACKAGES_SIMTEST=$(shell go list ./... | grep '/simulation')
|
||||||
VERSION := $(shell echo $(shell git describe --always --match "v*") | sed 's/^v//')
|
export VERSION := $(shell echo $(shell git describe --always --match "v*") | sed 's/^v//')
|
||||||
TMVERSION := $(shell go list -m github.com/tendermint/tendermint | sed 's:.* ::')
|
export TMVERSION := $(shell go list -m github.com/tendermint/tendermint | sed 's:.* ::')
|
||||||
COMMIT := $(shell git log -1 --format='%H')
|
export COMMIT := $(shell git log -1 --format='%H')
|
||||||
LEDGER_ENABLED ?= true
|
LEDGER_ENABLED ?= true
|
||||||
BINDIR ?= $(GOPATH)/bin
|
BINDIR ?= $(GOPATH)/bin
|
||||||
BUILDDIR ?= $(CURDIR)/build
|
BUILDDIR ?= $(CURDIR)/build
|
||||||
|
@ -117,33 +117,10 @@ $(BUILD_TARGETS): go.sum $(BUILDDIR)/
|
||||||
$(BUILDDIR)/:
|
$(BUILDDIR)/:
|
||||||
mkdir -p $(BUILDDIR)/
|
mkdir -p $(BUILDDIR)/
|
||||||
|
|
||||||
build-simd-all: go.sum
|
|
||||||
$(DOCKER) rm latest-build || true
|
|
||||||
$(DOCKER) run --volume=$(CURDIR):/sources:ro \
|
|
||||||
--env TARGET_PLATFORMS='linux/amd64 darwin/amd64 linux/arm64 windows/amd64' \
|
|
||||||
--env APP=simd \
|
|
||||||
--env VERSION=$(VERSION) \
|
|
||||||
--env COMMIT=$(COMMIT) \
|
|
||||||
--env LEDGER_ENABLED=$(LEDGER_ENABLED) \
|
|
||||||
--name latest-build tendermintdev/rbuilder:latest
|
|
||||||
$(DOCKER) cp -a latest-build:/home/builder/artifacts/ $(CURDIR)/
|
|
||||||
|
|
||||||
build-simd-linux: go.sum $(BUILDDIR)/
|
|
||||||
$(DOCKER) rm latest-build || true
|
|
||||||
$(DOCKER) run --volume=$(CURDIR):/sources:ro \
|
|
||||||
--env TARGET_PLATFORMS='linux/amd64' \
|
|
||||||
--env APP=simd \
|
|
||||||
--env VERSION=$(VERSION) \
|
|
||||||
--env COMMIT=$(COMMIT) \
|
|
||||||
--env LEDGER_ENABLED=false \
|
|
||||||
--name latest-build tendermintdev/rbuilder:latest
|
|
||||||
$(DOCKER) cp -a latest-build:/home/builder/artifacts/ $(CURDIR)/
|
|
||||||
cp artifacts/simd-*-linux-amd64 $(BUILDDIR)/simd
|
|
||||||
|
|
||||||
cosmovisor:
|
cosmovisor:
|
||||||
$(MAKE) -C cosmovisor cosmovisor
|
$(MAKE) -C cosmovisor cosmovisor
|
||||||
|
|
||||||
.PHONY: build build-linux build-simd-all build-simd-linux cosmovisor
|
.PHONY: build build-linux cosmovisor
|
||||||
|
|
||||||
mockgen_cmd=go run github.com/golang/mock/mockgen
|
mockgen_cmd=go run github.com/golang/mock/mockgen
|
||||||
|
|
||||||
|
@ -349,8 +326,8 @@ golangci_lint_cmd=golangci-lint
|
||||||
lint: lint-go
|
lint: lint-go
|
||||||
@if docker ps -a --format '{{.Names}}' | grep -Eq "^${containerMarkdownLint}$$"; then docker start -a $(containerMarkdownLint); else docker run --name $(containerMarkdownLint) -i -v "$(CURDIR):/work" $(markdownLintImage); fi
|
@if docker ps -a --format '{{.Names}}' | grep -Eq "^${containerMarkdownLint}$$"; then docker start -a $(containerMarkdownLint); else docker run --name $(containerMarkdownLint) -i -v "$(CURDIR):/work" $(markdownLintImage); fi
|
||||||
|
|
||||||
lint-fix:
|
lint-fix: install-golangci-lint
|
||||||
$(golangci_lint_cmd) run --fix --out-format=tab --issues-exit-code=0
|
golangci-lint run --fix --out-format=tab --issues-exit-code=0
|
||||||
@if docker ps -a --format '{{.Names}}' | grep -Eq "^${containerMarkdownLintFix}$$"; then docker start -a $(containerMarkdownLintFix); else docker run --name $(containerMarkdownLintFix) -i -v "$(CURDIR):/work" $(markdownLintImage) . --fix; fi
|
@if docker ps -a --format '{{.Names}}' | grep -Eq "^${containerMarkdownLintFix}$$"; then docker start -a $(containerMarkdownLintFix); else docker run --name $(containerMarkdownLintFix) -i -v "$(CURDIR):/work" $(markdownLintImage) . --fix; fi
|
||||||
|
|
||||||
lint-go:
|
lint-go:
|
||||||
|
@ -496,7 +473,7 @@ proto-update-deps:
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
# Run a 4-node testnet locally via docker compose
|
# Run a 4-node testnet locally via docker compose
|
||||||
localnet-start: build-linux localnet-stop
|
localnet-start: localnet-stop
|
||||||
$(if $(shell $(DOCKER) inspect -f '{{ .Id }}' cosmossdk/simd-env 2>/dev/null),$(info found image cosmossdk/simd-env),$(MAKE) -C contrib/images simd-env)
|
$(if $(shell $(DOCKER) inspect -f '{{ .Id }}' cosmossdk/simd-env 2>/dev/null),$(info found image cosmossdk/simd-env),$(MAKE) -C contrib/images simd-env)
|
||||||
$(DOCKER) run --rm -v $(CURDIR)/localnet:/data cosmossdk/simd-env \
|
$(DOCKER) run --rm -v $(CURDIR)/localnet:/data cosmossdk/simd-env \
|
||||||
testnet init-files --v 4 -o /data --starting-ip-address 192.168.10.2 --keyring-backend=test
|
testnet init-files --v 4 -o /data --starting-ip-address 192.168.10.2 --keyring-backend=test
|
||||||
|
|
|
@ -116,12 +116,6 @@ func (app *BaseApp) Info(req abci.RequestInfo) abci.ResponseInfo {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// SetOption implements the ABCI interface.
|
|
||||||
func (app *BaseApp) SetOption(req abci.RequestSetOption) (res abci.ResponseSetOption) {
|
|
||||||
// TODO: Implement!
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// FilterPeerByAddrPort filters peers by address/port.
|
// FilterPeerByAddrPort filters peers by address/port.
|
||||||
func (app *BaseApp) FilterPeerByAddrPort(info string) abci.ResponseQuery {
|
func (app *BaseApp) FilterPeerByAddrPort(info string) abci.ResponseQuery {
|
||||||
if app.addrPeerFilter != nil {
|
if app.addrPeerFilter != nil {
|
||||||
|
|
|
@ -106,7 +106,7 @@ func TestGetBlockRentionHeight(t *testing.T) {
|
||||||
|
|
||||||
tc.bapp.SetParamStore(¶mStore{db: dbm.NewMemDB()})
|
tc.bapp.SetParamStore(¶mStore{db: dbm.NewMemDB()})
|
||||||
tc.bapp.InitChain(abci.RequestInitChain{
|
tc.bapp.InitChain(abci.RequestInitChain{
|
||||||
ConsensusParams: &abci.ConsensusParams{
|
ConsensusParams: &tmprototypes.ConsensusParams{
|
||||||
Evidence: &tmprototypes.EvidenceParams{
|
Evidence: &tmprototypes.EvidenceParams{
|
||||||
MaxAgeNumBlocks: tc.maxAgeBlocks,
|
MaxAgeNumBlocks: tc.maxAgeBlocks,
|
||||||
},
|
},
|
||||||
|
|
|
@ -376,15 +376,15 @@ func (app *BaseApp) setDeliverState(header tmproto.Header) {
|
||||||
|
|
||||||
// GetConsensusParams returns the current consensus parameters from the BaseApp's
|
// GetConsensusParams returns the current consensus parameters from the BaseApp's
|
||||||
// ParamStore. If the BaseApp has no ParamStore defined, nil is returned.
|
// ParamStore. If the BaseApp has no ParamStore defined, nil is returned.
|
||||||
func (app *BaseApp) GetConsensusParams(ctx sdk.Context) *abci.ConsensusParams {
|
func (app *BaseApp) GetConsensusParams(ctx sdk.Context) *tmproto.ConsensusParams {
|
||||||
if app.paramStore == nil {
|
if app.paramStore == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
cp := new(abci.ConsensusParams)
|
cp := new(tmproto.ConsensusParams)
|
||||||
|
|
||||||
if app.paramStore.Has(ctx, ParamStoreKeyBlockParams) {
|
if app.paramStore.Has(ctx, ParamStoreKeyBlockParams) {
|
||||||
var bp abci.BlockParams
|
var bp tmproto.BlockParams
|
||||||
|
|
||||||
app.paramStore.Get(ctx, ParamStoreKeyBlockParams, &bp)
|
app.paramStore.Get(ctx, ParamStoreKeyBlockParams, &bp)
|
||||||
cp.Block = &bp
|
cp.Block = &bp
|
||||||
|
@ -408,7 +408,7 @@ func (app *BaseApp) GetConsensusParams(ctx sdk.Context) *abci.ConsensusParams {
|
||||||
}
|
}
|
||||||
|
|
||||||
// StoreConsensusParams sets the consensus parameters to the baseapp's param store.
|
// StoreConsensusParams sets the consensus parameters to the baseapp's param store.
|
||||||
func (app *BaseApp) StoreConsensusParams(ctx sdk.Context, cp *abci.ConsensusParams) {
|
func (app *BaseApp) StoreConsensusParams(ctx sdk.Context, cp *tmproto.ConsensusParams) {
|
||||||
if app.paramStore == nil {
|
if app.paramStore == nil {
|
||||||
panic("cannot store consensus params with no params store set")
|
panic("cannot store consensus params with no params store set")
|
||||||
}
|
}
|
||||||
|
|
|
@ -80,7 +80,8 @@ func (ps *paramStore) Get(_ sdk.Context, key []byte, ptr interface{}) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func defaultLogger() log.Logger {
|
func defaultLogger() log.Logger {
|
||||||
return log.NewTMLogger(log.NewSyncWriter(os.Stdout)).With("module", "sdk/app")
|
logger, _ := log.NewDefaultLogger("plain", "info", false)
|
||||||
|
return logger.With("module", "sdk/app")
|
||||||
}
|
}
|
||||||
|
|
||||||
func newBaseApp(name string, options ...func(*baseapp.BaseApp)) *baseapp.BaseApp {
|
func newBaseApp(name string, options ...func(*baseapp.BaseApp)) *baseapp.BaseApp {
|
||||||
|
@ -1431,8 +1432,8 @@ func TestMaxBlockGasLimits(t *testing.T) {
|
||||||
app := setupBaseApp(t, txHandlerOpt)
|
app := setupBaseApp(t, txHandlerOpt)
|
||||||
|
|
||||||
app.InitChain(abci.RequestInitChain{
|
app.InitChain(abci.RequestInitChain{
|
||||||
ConsensusParams: &abci.ConsensusParams{
|
ConsensusParams: &tmproto.ConsensusParams{
|
||||||
Block: &abci.BlockParams{
|
Block: &tmproto.BlockParams{
|
||||||
MaxGas: 100,
|
MaxGas: 100,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -1611,8 +1612,8 @@ func TestGasConsumptionBadTx(t *testing.T) {
|
||||||
app := setupBaseApp(t, txHandlerOpt)
|
app := setupBaseApp(t, txHandlerOpt)
|
||||||
|
|
||||||
app.InitChain(abci.RequestInitChain{
|
app.InitChain(abci.RequestInitChain{
|
||||||
ConsensusParams: &abci.ConsensusParams{
|
ConsensusParams: &tmproto.ConsensusParams{
|
||||||
Block: &abci.BlockParams{
|
Block: &tmproto.BlockParams{
|
||||||
MaxGas: 9,
|
MaxGas: 9,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -1776,16 +1777,16 @@ func TestGetMaximumBlockGas(t *testing.T) {
|
||||||
app.InitChain(abci.RequestInitChain{})
|
app.InitChain(abci.RequestInitChain{})
|
||||||
ctx := app.NewContext(true, tmproto.Header{})
|
ctx := app.NewContext(true, tmproto.Header{})
|
||||||
|
|
||||||
app.StoreConsensusParams(ctx, &abci.ConsensusParams{Block: &abci.BlockParams{MaxGas: 0}})
|
app.StoreConsensusParams(ctx, &tmproto.ConsensusParams{Block: &tmproto.BlockParams{MaxGas: 0}})
|
||||||
require.Equal(t, uint64(0), app.GetMaximumBlockGas(ctx))
|
require.Equal(t, uint64(0), app.GetMaximumBlockGas(ctx))
|
||||||
|
|
||||||
app.StoreConsensusParams(ctx, &abci.ConsensusParams{Block: &abci.BlockParams{MaxGas: -1}})
|
app.StoreConsensusParams(ctx, &tmproto.ConsensusParams{Block: &tmproto.BlockParams{MaxGas: -1}})
|
||||||
require.Equal(t, uint64(0), app.GetMaximumBlockGas(ctx))
|
require.Equal(t, uint64(0), app.GetMaximumBlockGas(ctx))
|
||||||
|
|
||||||
app.StoreConsensusParams(ctx, &abci.ConsensusParams{Block: &abci.BlockParams{MaxGas: 5000000}})
|
app.StoreConsensusParams(ctx, &tmproto.ConsensusParams{Block: &tmproto.BlockParams{MaxGas: 5000000}})
|
||||||
require.Equal(t, uint64(5000000), app.GetMaximumBlockGas(ctx))
|
require.Equal(t, uint64(5000000), app.GetMaximumBlockGas(ctx))
|
||||||
|
|
||||||
app.StoreConsensusParams(ctx, &abci.ConsensusParams{Block: &abci.BlockParams{MaxGas: -5000000}})
|
app.StoreConsensusParams(ctx, &tmproto.ConsensusParams{Block: &tmproto.BlockParams{MaxGas: -5000000}})
|
||||||
require.Panics(t, func() { app.GetMaximumBlockGas(ctx) })
|
require.Panics(t, func() { app.GetMaximumBlockGas(ctx) })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2014,8 +2015,8 @@ func TestBaseApp_EndBlock(t *testing.T) {
|
||||||
name := t.Name()
|
name := t.Name()
|
||||||
logger := defaultLogger()
|
logger := defaultLogger()
|
||||||
|
|
||||||
cp := &abci.ConsensusParams{
|
cp := &tmproto.ConsensusParams{
|
||||||
Block: &abci.BlockParams{
|
Block: &tmproto.BlockParams{
|
||||||
MaxGas: 5000000,
|
MaxGas: 5000000,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,6 @@ package baseapp_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"os"
|
|
||||||
"sync"
|
"sync"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
@ -55,7 +54,8 @@ func TestRegisterQueryServiceTwice(t *testing.T) {
|
||||||
// Setup baseapp.
|
// Setup baseapp.
|
||||||
db := dbm.NewMemDB()
|
db := dbm.NewMemDB()
|
||||||
encCfg := simapp.MakeTestEncodingConfig()
|
encCfg := simapp.MakeTestEncodingConfig()
|
||||||
app := baseapp.NewBaseApp("test", log.NewTMLogger(log.NewSyncWriter(os.Stdout)), db, encCfg.TxConfig.TxDecoder())
|
logger, _ := log.NewDefaultLogger("plain", "info", false)
|
||||||
|
app := baseapp.NewBaseApp("test", logger, db, encCfg.TxConfig.TxDecoder())
|
||||||
app.SetInterfaceRegistry(encCfg.InterfaceRegistry)
|
app.SetInterfaceRegistry(encCfg.InterfaceRegistry)
|
||||||
testdata.RegisterInterfaces(encCfg.InterfaceRegistry)
|
testdata.RegisterInterfaces(encCfg.InterfaceRegistry)
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,6 @@ import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
|
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
@ -31,7 +30,7 @@ type ParamStore interface {
|
||||||
// ValidateBlockParams defines a stateless validation on BlockParams. This function
|
// ValidateBlockParams defines a stateless validation on BlockParams. This function
|
||||||
// is called whenever the parameters are updated or stored.
|
// is called whenever the parameters are updated or stored.
|
||||||
func ValidateBlockParams(i interface{}) error {
|
func ValidateBlockParams(i interface{}) error {
|
||||||
v, ok := i.(abci.BlockParams)
|
v, ok := i.(tmproto.BlockParams)
|
||||||
if !ok {
|
if !ok {
|
||||||
return fmt.Errorf("invalid parameter type: %T", i)
|
return fmt.Errorf("invalid parameter type: %T", i)
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,6 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/baseapp"
|
"github.com/cosmos/cosmos-sdk/baseapp"
|
||||||
|
@ -16,11 +15,11 @@ func TestValidateBlockParams(t *testing.T) {
|
||||||
expectErr bool
|
expectErr bool
|
||||||
}{
|
}{
|
||||||
{nil, true},
|
{nil, true},
|
||||||
{&abci.BlockParams{}, true},
|
{&tmproto.BlockParams{}, true},
|
||||||
{abci.BlockParams{}, true},
|
{tmproto.BlockParams{}, true},
|
||||||
{abci.BlockParams{MaxBytes: -1, MaxGas: -1}, true},
|
{tmproto.BlockParams{MaxBytes: -1, MaxGas: -1}, true},
|
||||||
{abci.BlockParams{MaxBytes: 2000000, MaxGas: -5}, true},
|
{tmproto.BlockParams{MaxBytes: 2000000, MaxGas: -5}, true},
|
||||||
{abci.BlockParams{MaxBytes: 2000000, MaxGas: 300000}, false},
|
{tmproto.BlockParams{MaxBytes: 2000000, MaxGas: 300000}, false},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range testCases {
|
for _, tc := range testCases {
|
||||||
|
|
|
@ -5,7 +5,6 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/tendermint/tendermint/mempool"
|
|
||||||
tmtypes "github.com/tendermint/tendermint/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
"google.golang.org/grpc/codes"
|
"google.golang.org/grpc/codes"
|
||||||
"google.golang.org/grpc/status"
|
"google.golang.org/grpc/status"
|
||||||
|
@ -55,7 +54,7 @@ func CheckTendermintError(err error, tx tmtypes.Tx) *sdk.TxResponse {
|
||||||
txHash := fmt.Sprintf("%X", tx.Hash())
|
txHash := fmt.Sprintf("%X", tx.Hash())
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
case strings.Contains(errStr, strings.ToLower(mempool.ErrTxInCache.Error())):
|
case strings.Contains(errStr, strings.ToLower(tmtypes.ErrTxInCache.Error())):
|
||||||
return &sdk.TxResponse{
|
return &sdk.TxResponse{
|
||||||
Code: sdkerrors.ErrTxInMempoolCache.ABCICode(),
|
Code: sdkerrors.ErrTxInMempoolCache.ABCICode(),
|
||||||
Codespace: sdkerrors.ErrTxInMempoolCache.Codespace(),
|
Codespace: sdkerrors.ErrTxInMempoolCache.Codespace(),
|
||||||
|
|
|
@ -7,9 +7,8 @@ import (
|
||||||
|
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
"github.com/tendermint/tendermint/crypto/tmhash"
|
"github.com/tendermint/tendermint/crypto/tmhash"
|
||||||
"github.com/tendermint/tendermint/mempool"
|
|
||||||
"github.com/tendermint/tendermint/rpc/client/mock"
|
"github.com/tendermint/tendermint/rpc/client/mock"
|
||||||
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
"github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
tmtypes "github.com/tendermint/tendermint/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client/flags"
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
||||||
|
@ -21,15 +20,15 @@ type MockClient struct {
|
||||||
err error
|
err error
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c MockClient) BroadcastTxCommit(ctx context.Context, tx tmtypes.Tx) (*ctypes.ResultBroadcastTxCommit, error) {
|
func (c MockClient) BroadcastTxCommit(ctx context.Context, tx tmtypes.Tx) (*coretypes.ResultBroadcastTxCommit, error) {
|
||||||
return nil, c.err
|
return nil, c.err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c MockClient) BroadcastTxAsync(ctx context.Context, tx tmtypes.Tx) (*ctypes.ResultBroadcastTx, error) {
|
func (c MockClient) BroadcastTxAsync(ctx context.Context, tx tmtypes.Tx) (*coretypes.ResultBroadcastTx, error) {
|
||||||
return nil, c.err
|
return nil, c.err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c MockClient) BroadcastTxSync(ctx context.Context, tx tmtypes.Tx) (*ctypes.ResultBroadcastTx, error) {
|
func (c MockClient) BroadcastTxSync(ctx context.Context, tx tmtypes.Tx) (*coretypes.ResultBroadcastTx, error) {
|
||||||
return nil, c.err
|
return nil, c.err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,9 +42,9 @@ func CreateContextWithErrorAndMode(err error, mode string) Context {
|
||||||
// Test the correct code is returned when
|
// Test the correct code is returned when
|
||||||
func TestBroadcastError(t *testing.T) {
|
func TestBroadcastError(t *testing.T) {
|
||||||
errors := map[error]uint32{
|
errors := map[error]uint32{
|
||||||
mempool.ErrTxInCache: sdkerrors.ErrTxInMempoolCache.ABCICode(),
|
tmtypes.ErrTxInCache: sdkerrors.ErrTxInMempoolCache.ABCICode(),
|
||||||
mempool.ErrTxTooLarge{}: sdkerrors.ErrTxTooLarge.ABCICode(),
|
tmtypes.ErrTxTooLarge{}: sdkerrors.ErrTxTooLarge.ABCICode(),
|
||||||
mempool.ErrMempoolIsFull{}: sdkerrors.ErrMempoolIsFull.ABCICode(),
|
tmtypes.ErrMempoolIsFull{}: sdkerrors.ErrMempoolIsFull.ABCICode(),
|
||||||
}
|
}
|
||||||
|
|
||||||
modes := []string{
|
modes := []string{
|
||||||
|
|
|
@ -3,12 +3,11 @@ package tmservice
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
|
"github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
)
|
)
|
||||||
|
|
||||||
func getBlock(ctx context.Context, clientCtx client.Context, height *int64) (*ctypes.ResultBlock, error) {
|
func getBlock(ctx context.Context, clientCtx client.Context, height *int64) (*coretypes.ResultBlock, error) {
|
||||||
// get the node
|
// get the node
|
||||||
node, err := clientCtx.GetNode()
|
node, err := clientCtx.GetNode()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -636,8 +636,8 @@ var xxx_messageInfo_GetNodeInfoRequest proto.InternalMessageInfo
|
||||||
|
|
||||||
// GetNodeInfoResponse is the response type for the Query/GetNodeInfo RPC method.
|
// GetNodeInfoResponse is the response type for the Query/GetNodeInfo RPC method.
|
||||||
type GetNodeInfoResponse struct {
|
type GetNodeInfoResponse struct {
|
||||||
DefaultNodeInfo *p2p.DefaultNodeInfo `protobuf:"bytes,1,opt,name=default_node_info,json=defaultNodeInfo,proto3" json:"default_node_info,omitempty"`
|
NodeInfo *p2p.NodeInfo `protobuf:"bytes,1,opt,name=node_info,json=nodeInfo,proto3" json:"node_info,omitempty"`
|
||||||
ApplicationVersion *VersionInfo `protobuf:"bytes,2,opt,name=application_version,json=applicationVersion,proto3" json:"application_version,omitempty"`
|
ApplicationVersion *VersionInfo `protobuf:"bytes,2,opt,name=application_version,json=applicationVersion,proto3" json:"application_version,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *GetNodeInfoResponse) Reset() { *m = GetNodeInfoResponse{} }
|
func (m *GetNodeInfoResponse) Reset() { *m = GetNodeInfoResponse{} }
|
||||||
|
@ -673,9 +673,9 @@ func (m *GetNodeInfoResponse) XXX_DiscardUnknown() {
|
||||||
|
|
||||||
var xxx_messageInfo_GetNodeInfoResponse proto.InternalMessageInfo
|
var xxx_messageInfo_GetNodeInfoResponse proto.InternalMessageInfo
|
||||||
|
|
||||||
func (m *GetNodeInfoResponse) GetDefaultNodeInfo() *p2p.DefaultNodeInfo {
|
func (m *GetNodeInfoResponse) GetNodeInfo() *p2p.NodeInfo {
|
||||||
if m != nil {
|
if m != nil {
|
||||||
return m.DefaultNodeInfo
|
return m.NodeInfo
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -876,77 +876,76 @@ func init() {
|
||||||
}
|
}
|
||||||
|
|
||||||
var fileDescriptor_40c93fb3ef485c5d = []byte{
|
var fileDescriptor_40c93fb3ef485c5d = []byte{
|
||||||
// 1106 bytes of a gzipped FileDescriptorProto
|
// 1096 bytes of a gzipped FileDescriptorProto
|
||||||
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xd4, 0x56, 0x4d, 0x6f, 0x1b, 0x45,
|
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xd4, 0x56, 0x4f, 0x6f, 0x1b, 0xc5,
|
||||||
0x18, 0xee, 0xda, 0x6d, 0x9c, 0xbc, 0x46, 0x90, 0x4c, 0x42, 0xe3, 0xac, 0x52, 0x37, 0xf8, 0xd0,
|
0x1b, 0xce, 0xda, 0x6d, 0x1c, 0xbf, 0xfe, 0xe9, 0xa7, 0x74, 0x12, 0x9a, 0xcd, 0x2a, 0x35, 0xc1,
|
||||||
0x26, 0x84, 0xec, 0xca, 0x6e, 0x9b, 0xf6, 0x50, 0x8a, 0x1a, 0x02, 0x69, 0xd4, 0x52, 0x45, 0x1b,
|
0x87, 0x36, 0x21, 0x64, 0x57, 0x76, 0x9b, 0xb4, 0x87, 0x52, 0xd4, 0x50, 0x48, 0x23, 0x4a, 0x15,
|
||||||
0xc4, 0x01, 0x21, 0xad, 0xc6, 0xde, 0xc9, 0x66, 0x14, 0x7b, 0x67, 0xba, 0x33, 0x1b, 0x64, 0xa1,
|
0x6d, 0x10, 0x07, 0x84, 0xb4, 0x5a, 0x7b, 0x27, 0x9b, 0x91, 0xed, 0x9d, 0xe9, 0xce, 0xd8, 0xc8,
|
||||||
0x0a, 0xc4, 0x89, 0x23, 0x12, 0x7f, 0x81, 0x03, 0xdc, 0x11, 0xc7, 0x8a, 0x23, 0xc7, 0xaa, 0x48,
|
0x42, 0x15, 0x88, 0x13, 0x47, 0x24, 0xbe, 0x02, 0x07, 0xe0, 0x8c, 0x38, 0xf6, 0xcc, 0xb1, 0x2a,
|
||||||
0xa8, 0xe2, 0x84, 0x12, 0x7e, 0x08, 0xda, 0x99, 0x59, 0x67, 0xb7, 0x49, 0x6a, 0x27, 0x07, 0x24,
|
0x12, 0xaa, 0x38, 0xa1, 0x84, 0x0f, 0x82, 0x76, 0x66, 0xd6, 0xde, 0x6d, 0x92, 0xda, 0xce, 0x01,
|
||||||
0x4e, 0xbb, 0xf3, 0x7e, 0xcd, 0xf3, 0x3c, 0xf3, 0xce, 0x07, 0xbc, 0xdb, 0x61, 0xa2, 0xc7, 0x84,
|
0x89, 0xd3, 0xce, 0xbc, 0xff, 0xe6, 0x79, 0x9e, 0x99, 0x79, 0x77, 0xe0, 0xed, 0x16, 0xe5, 0x5d,
|
||||||
0xdb, 0xc6, 0x82, 0xb8, 0x92, 0x44, 0x01, 0x89, 0x7b, 0x34, 0x92, 0xee, 0x7e, 0xb3, 0x4d, 0x24,
|
0xca, 0x9d, 0xa6, 0xcf, 0xb1, 0x23, 0x70, 0x14, 0xe0, 0xb8, 0x4b, 0x22, 0xe1, 0xf4, 0xeb, 0x4d,
|
||||||
0x6e, 0xba, 0x4f, 0x12, 0x12, 0xf7, 0x1d, 0x1e, 0x33, 0xc9, 0x50, 0x5d, 0xc7, 0x3a, 0x69, 0xac,
|
0x2c, 0xfc, 0xba, 0xf3, 0xa4, 0x87, 0xe3, 0x81, 0xcd, 0x62, 0x2a, 0x28, 0xaa, 0xaa, 0x58, 0x3b,
|
||||||
0x73, 0x14, 0xeb, 0x98, 0x58, 0x7b, 0x26, 0x64, 0x21, 0x53, 0xa1, 0x6e, 0xfa, 0xa7, 0xb3, 0xec,
|
0x89, 0xb5, 0x47, 0xb1, 0xb6, 0x8e, 0xb5, 0x16, 0x43, 0x1a, 0x52, 0x19, 0xea, 0x24, 0x23, 0x95,
|
||||||
0xb9, 0x90, 0xb1, 0xb0, 0x4b, 0x5c, 0x35, 0x6a, 0x27, 0x3b, 0x2e, 0x8e, 0x4c, 0x41, 0x7b, 0xde,
|
0x65, 0x2d, 0x87, 0x94, 0x86, 0x1d, 0xec, 0xc8, 0x59, 0xb3, 0x77, 0xe8, 0xf8, 0x91, 0x2e, 0x68,
|
||||||
0xb8, 0x30, 0xa7, 0x2e, 0x8e, 0x22, 0x26, 0xb1, 0xa4, 0x2c, 0x12, 0xc6, 0x6b, 0xe7, 0xe0, 0xf0,
|
0xad, 0x68, 0x97, 0xcf, 0x88, 0xe3, 0x47, 0x11, 0x15, 0xbe, 0x20, 0x34, 0xe2, 0xda, 0x6b, 0x65,
|
||||||
0x16, 0x77, 0x65, 0x9f, 0x93, 0xcc, 0x37, 0x9f, 0xf3, 0x29, 0xbb, 0xdb, 0xee, 0xb2, 0xce, 0xde,
|
0xe0, 0xb0, 0x06, 0x73, 0xc4, 0x80, 0xe1, 0xd4, 0xb7, 0x92, 0xf1, 0x49, 0xbb, 0xd3, 0xec, 0xd0,
|
||||||
0xa9, 0xde, 0x7c, 0x6e, 0x81, 0xb2, 0xe2, 0x37, 0x60, 0xcb, 0x71, 0x48, 0x23, 0x05, 0x22, 0x03,
|
0x56, 0xfb, 0x5c, 0x6f, 0x36, 0x37, 0x47, 0x59, 0xf2, 0x1b, 0xb2, 0x65, 0x7e, 0x48, 0x22, 0x09,
|
||||||
0xaf, 0x63, 0x7d, 0xcd, 0xca, 0xf0, 0x57, 0x83, 0xc6, 0x37, 0x16, 0xd4, 0x37, 0x88, 0xfc, 0x0c,
|
0x22, 0x05, 0xaf, 0x62, 0x3d, 0xc5, 0x4a, 0xf3, 0x97, 0x93, 0xda, 0xd7, 0x06, 0x54, 0x77, 0xb1,
|
||||||
0x77, 0x69, 0x80, 0x25, 0x8b, 0xb7, 0x89, 0x5c, 0xeb, 0x3f, 0x20, 0x34, 0xdc, 0x95, 0x1e, 0x79,
|
0xf8, 0xd4, 0xef, 0x90, 0xc0, 0x17, 0x34, 0x3e, 0xc0, 0x62, 0x67, 0xf0, 0x10, 0x93, 0xf0, 0x48,
|
||||||
0x92, 0x10, 0x21, 0xd1, 0x65, 0x18, 0xdb, 0x55, 0x86, 0x9a, 0xb5, 0x60, 0x2d, 0x96, 0x3d, 0x33,
|
0xb8, 0xf8, 0x49, 0x0f, 0x73, 0x81, 0xae, 0xc2, 0xec, 0x91, 0x34, 0x98, 0xc6, 0xaa, 0xb1, 0x56,
|
||||||
0x42, 0x1f, 0x03, 0x1c, 0xcd, 0x54, 0x2b, 0x2d, 0x58, 0x8b, 0xd5, 0xd6, 0x35, 0x27, 0xaf, 0xae,
|
0x74, 0xf5, 0x0c, 0x7d, 0x08, 0x30, 0x5a, 0xc9, 0x2c, 0xac, 0x1a, 0x6b, 0x95, 0xc6, 0x75, 0x3b,
|
||||||
0x96, 0xdd, 0xc0, 0x72, 0xb6, 0x70, 0x48, 0x4c, 0x4d, 0x2f, 0x97, 0xd9, 0x78, 0x69, 0xc1, 0xd5,
|
0xab, 0xae, 0x92, 0x5d, 0xc3, 0xb2, 0xf7, 0xfd, 0x10, 0xeb, 0x9a, 0x6e, 0x26, 0xb3, 0xf6, 0xd2,
|
||||||
0x53, 0x21, 0x08, 0xce, 0x22, 0x41, 0xd0, 0x3b, 0xf0, 0x86, 0x92, 0xc6, 0x2f, 0x20, 0xa9, 0x2a,
|
0x80, 0x37, 0xcf, 0x85, 0xc0, 0x19, 0x8d, 0x38, 0x46, 0x6f, 0xc1, 0xff, 0xa4, 0x34, 0x5e, 0x0e,
|
||||||
0x9b, 0x0e, 0x45, 0x9b, 0x00, 0xfb, 0x59, 0x09, 0x51, 0x2b, 0x2d, 0x94, 0x17, 0xab, 0xad, 0x25,
|
0x49, 0x45, 0xda, 0x54, 0x28, 0xda, 0x03, 0xe8, 0xa7, 0x25, 0xb8, 0x59, 0x58, 0x2d, 0xae, 0x55,
|
||||||
0xe7, 0xf5, 0x8b, 0xed, 0x0c, 0x26, 0xf5, 0x72, 0xc9, 0x68, 0xa3, 0xc0, 0xac, 0xac, 0x98, 0x5d,
|
0x1a, 0xeb, 0xf6, 0xeb, 0x37, 0xdb, 0x1e, 0x2e, 0xea, 0x66, 0x92, 0xd1, 0x6e, 0x8e, 0x59, 0x51,
|
||||||
0x1f, 0xca, 0x4c, 0x43, 0x2d, 0x50, 0xdb, 0x81, 0xf9, 0x0d, 0x22, 0x1f, 0x61, 0x49, 0x44, 0x81,
|
0x32, 0xbb, 0x31, 0x96, 0x99, 0x82, 0x9a, 0xa3, 0x76, 0x08, 0x2b, 0xbb, 0x58, 0x3c, 0xf2, 0x05,
|
||||||
0x5f, 0x26, 0x6d, 0x51, 0x42, 0xeb, 0xdc, 0x12, 0xfe, 0x69, 0xc1, 0x95, 0x53, 0x26, 0xfa, 0x7f,
|
0xe6, 0x39, 0x7e, 0xa9, 0xb4, 0x79, 0x09, 0x8d, 0x0b, 0x4b, 0xf8, 0x87, 0x01, 0xd7, 0xce, 0x59,
|
||||||
0x0b, 0xf8, 0xcc, 0x82, 0x89, 0xc1, 0x14, 0xa8, 0x05, 0x15, 0x1c, 0x04, 0x31, 0x11, 0x42, 0xe1,
|
0xe8, 0xbf, 0x2d, 0xe0, 0x33, 0x03, 0xca, 0xc3, 0x25, 0x50, 0x03, 0x4a, 0x7e, 0x10, 0xc4, 0x98,
|
||||||
0x9f, 0x58, 0xab, 0xbd, 0xf8, 0x65, 0x65, 0xc6, 0x94, 0xbd, 0xaf, 0x3d, 0xdb, 0x32, 0xa6, 0x51,
|
0x73, 0x89, 0xbf, 0xbc, 0x63, 0xbe, 0xf8, 0x65, 0x73, 0x51, 0x97, 0xbd, 0xaf, 0x3c, 0x07, 0x22,
|
||||||
0xe8, 0x65, 0x81, 0x68, 0x05, 0x2a, 0x3c, 0x69, 0xfb, 0x7b, 0xa4, 0x6f, 0x5a, 0x74, 0xc6, 0xd1,
|
0x26, 0x51, 0xe8, 0xa6, 0x81, 0x68, 0x13, 0x4a, 0xac, 0xd7, 0xf4, 0xda, 0x78, 0xa0, 0x8f, 0xe8,
|
||||||
0xfb, 0xd5, 0xc9, 0xb6, 0xb2, 0x73, 0x3f, 0xea, 0x7b, 0x63, 0x3c, 0x69, 0x3f, 0x24, 0xfd, 0x54,
|
0xa2, 0xad, 0xee, 0xab, 0x9d, 0x5e, 0x65, 0xfb, 0x7e, 0x34, 0x70, 0x67, 0x59, 0xaf, 0xf9, 0x11,
|
||||||
0xa7, 0x7d, 0x26, 0x69, 0x14, 0xfa, 0x9c, 0x7d, 0x49, 0x62, 0x85, 0xbd, 0xec, 0x55, 0xb5, 0x6d,
|
0x1e, 0x24, 0x3a, 0xf5, 0xa9, 0x20, 0x51, 0xe8, 0x31, 0xfa, 0x05, 0x8e, 0x25, 0xf6, 0xa2, 0x5b,
|
||||||
0x2b, 0x35, 0xa1, 0x65, 0x98, 0xe2, 0x31, 0xe3, 0x4c, 0x90, 0xd8, 0xe7, 0x31, 0x65, 0x31, 0x95,
|
0x51, 0xb6, 0xfd, 0xc4, 0x84, 0x36, 0xe0, 0x0a, 0x8b, 0x29, 0xa3, 0x1c, 0xc7, 0x1e, 0x8b, 0x09,
|
||||||
0xfd, 0xda, 0x45, 0x15, 0x37, 0x99, 0x39, 0xb6, 0x8c, 0xbd, 0xd1, 0x84, 0xd9, 0x0d, 0x22, 0xd7,
|
0x8d, 0x89, 0x18, 0x98, 0x97, 0x64, 0xdc, 0x7c, 0xea, 0xd8, 0xd7, 0xf6, 0x5a, 0x1d, 0x96, 0x76,
|
||||||
0x52, 0x99, 0x47, 0xdc, 0x57, 0x8d, 0xaf, 0xa1, 0x76, 0x3c, 0xc5, 0x2c, 0xe3, 0x4d, 0x18, 0xd7,
|
0xb1, 0xd8, 0x49, 0x64, 0x9e, 0xf0, 0x5e, 0xd5, 0xbe, 0x02, 0xf3, 0x74, 0x8a, 0xde, 0xc6, 0x5b,
|
||||||
0xcb, 0x48, 0x03, 0xd3, 0x2e, 0x73, 0xf9, 0x55, 0xd1, 0x07, 0x84, 0x4a, 0xdd, 0x5c, 0xf7, 0x2a,
|
0x30, 0xa7, 0xb6, 0x91, 0x04, 0xfa, 0xb8, 0x2c, 0x67, 0x77, 0x45, 0x35, 0x08, 0x99, 0xba, 0xf7,
|
||||||
0x2a, 0x74, 0x33, 0x40, 0x2b, 0x70, 0x49, 0xfd, 0x1a, 0x05, 0x66, 0x4f, 0x49, 0xf1, 0x74, 0x54,
|
0xc0, 0x2d, 0xc9, 0xd0, 0xbd, 0x00, 0x6d, 0xc2, 0x65, 0x39, 0xd4, 0x0a, 0x2c, 0x9d, 0x93, 0xe2,
|
||||||
0x63, 0x16, 0xde, 0x1e, 0x34, 0x93, 0x76, 0x68, 0xc4, 0x8d, 0xa7, 0x70, 0xf9, 0x55, 0xc7, 0x7f,
|
0xaa, 0xa8, 0xda, 0x12, 0xbc, 0x31, 0x3c, 0x4c, 0xca, 0xa1, 0x10, 0xd7, 0x9e, 0xc2, 0xd5, 0x57,
|
||||||
0x89, 0x6b, 0x1a, 0xa6, 0x36, 0x88, 0xdc, 0xee, 0x47, 0x9d, 0x74, 0x85, 0x0d, 0x26, 0x07, 0x50,
|
0x1d, 0xff, 0x26, 0xae, 0x05, 0xb8, 0xb2, 0x8b, 0xc5, 0xc1, 0x20, 0x6a, 0x25, 0x3b, 0xac, 0x31,
|
||||||
0xde, 0x68, 0xf0, 0xd4, 0xa0, 0x22, 0xb4, 0x49, 0xc1, 0x19, 0xf7, 0xb2, 0x61, 0x63, 0x46, 0xc5,
|
0xd9, 0x80, 0xb2, 0x46, 0x8d, 0xc7, 0x84, 0x12, 0x57, 0x26, 0x09, 0x67, 0xce, 0x4d, 0xa7, 0xb5,
|
||||||
0x3f, 0x66, 0x01, 0xd9, 0x8c, 0x76, 0x58, 0x56, 0xe5, 0x37, 0x0b, 0xa6, 0x0b, 0x66, 0x53, 0xe7,
|
0x45, 0x19, 0xff, 0x98, 0x06, 0x78, 0x2f, 0x3a, 0xa4, 0x69, 0x95, 0x9f, 0x0d, 0x58, 0xc8, 0x99,
|
||||||
0x21, 0x4c, 0x05, 0x64, 0x07, 0x27, 0x5d, 0xe9, 0x47, 0x2c, 0x20, 0x3e, 0x8d, 0x76, 0x98, 0x21,
|
0x75, 0x9d, 0x2d, 0x28, 0x47, 0x34, 0xc0, 0x1e, 0x89, 0x0e, 0xa9, 0x26, 0x66, 0x66, 0x51, 0xb2,
|
||||||
0x78, 0x35, 0x8f, 0x96, 0xb7, 0xb8, 0xb3, 0xae, 0x03, 0x07, 0x35, 0xde, 0x0a, 0x8a, 0x06, 0xf4,
|
0x06, 0xb3, 0x87, 0x49, 0x73, 0x91, 0x1e, 0xa1, 0xcf, 0x61, 0xc1, 0x67, 0xac, 0x43, 0x5a, 0xf2,
|
||||||
0x05, 0x4c, 0x63, 0xce, 0xbb, 0xb4, 0xa3, 0x7a, 0xdb, 0xdf, 0x27, 0xb1, 0x38, 0x3a, 0x39, 0x97,
|
0x14, 0x7b, 0x7d, 0x1c, 0xf3, 0x51, 0x8f, 0xdc, 0x18, 0x7b, 0xa7, 0x54, 0xb8, 0xac, 0x89, 0x32,
|
||||||
0x87, 0xee, 0x34, 0x1d, 0xae, 0x4a, 0xa3, 0x5c, 0x1d, 0x63, 0x6f, 0xfc, 0x54, 0x82, 0x6a, 0x2e,
|
0x75, 0xb4, 0xbd, 0xf6, 0x63, 0x01, 0x2a, 0x99, 0x18, 0x84, 0xe0, 0x52, 0xe4, 0x77, 0xb1, 0xba,
|
||||||
0x06, 0x21, 0xb8, 0x18, 0xe1, 0x1e, 0xd1, 0x3b, 0xc5, 0x53, 0xff, 0x68, 0x0e, 0xc6, 0x31, 0xe7,
|
0x13, 0xae, 0x1c, 0xa3, 0x65, 0x98, 0xf3, 0x19, 0xf3, 0xa4, 0xbd, 0x20, 0xed, 0x25, 0x9f, 0xb1,
|
||||||
0xbe, 0xb2, 0x97, 0x94, 0xbd, 0x82, 0x39, 0x7f, 0x9c, 0xba, 0x6a, 0x50, 0xc9, 0x00, 0x95, 0xb5,
|
0xc7, 0x89, 0xcb, 0x84, 0x52, 0x0a, 0xa8, 0xa8, 0x3c, 0x7a, 0x8a, 0xae, 0x01, 0x84, 0x44, 0x78,
|
||||||
0xc7, 0x0c, 0xd1, 0x15, 0x80, 0x90, 0x4a, 0xbf, 0xc3, 0x7a, 0x3d, 0x2a, 0x55, 0xa3, 0x4f, 0x78,
|
0x2d, 0xda, 0xed, 0x12, 0x21, 0x8f, 0x74, 0xd9, 0x2d, 0x87, 0x44, 0xbc, 0x2f, 0x0d, 0x89, 0xbb,
|
||||||
0x13, 0x21, 0x95, 0x1f, 0x2a, 0x43, 0xea, 0x6e, 0x27, 0xb4, 0x1b, 0xf8, 0x12, 0x87, 0xa2, 0x76,
|
0xd9, 0x23, 0x9d, 0xc0, 0x13, 0x7e, 0xc8, 0xcd, 0xcb, 0xca, 0x2d, 0x2d, 0x9f, 0xf8, 0x21, 0x97,
|
||||||
0x49, 0xbb, 0x95, 0xe5, 0x53, 0x1c, 0x0a, 0x95, 0xcd, 0x06, 0x5c, 0xc7, 0x4c, 0x36, 0x33, 0x48,
|
0xd9, 0x74, 0xc8, 0x75, 0x56, 0x67, 0x53, 0x8d, 0x14, 0x7d, 0x90, 0x66, 0x07, 0x98, 0x71, 0xb3,
|
||||||
0xd1, 0x47, 0x59, 0x76, 0x40, 0xb8, 0xa8, 0x55, 0xd4, 0xa1, 0x73, 0x6d, 0x98, 0x14, 0x9f, 0xb0,
|
0x24, 0xdb, 0xcb, 0xf5, 0x71, 0x52, 0x7c, 0x4c, 0x83, 0x5e, 0x07, 0xeb, 0x55, 0x1e, 0x60, 0xc6,
|
||||||
0x20, 0xe9, 0x12, 0x33, 0xcb, 0x3a, 0xe1, 0x02, 0xbd, 0x07, 0xc8, 0xdc, 0x71, 0x22, 0xd8, 0x1b,
|
0xd1, 0x3b, 0x80, 0xf4, 0xdf, 0x8c, 0x07, 0xed, 0xe1, 0x6a, 0x73, 0x72, 0xb5, 0x79, 0xe5, 0x39,
|
||||||
0xcc, 0x36, 0xae, 0x66, 0x9b, 0xd4, 0x9e, 0xed, 0x60, 0x2f, 0x93, 0xea, 0x01, 0x8c, 0xe9, 0x12,
|
0x08, 0xda, 0xa9, 0x54, 0x0f, 0x61, 0x56, 0x95, 0x48, 0x44, 0x62, 0xbe, 0x38, 0x4a, 0x45, 0x4a,
|
||||||
0xa9, 0x48, 0x1c, 0xcb, 0xdd, 0x4c, 0xa4, 0xf4, 0x3f, 0xaf, 0x44, 0xa9, 0xa8, 0xc4, 0x24, 0x94,
|
0xc6, 0x59, 0x25, 0x0a, 0x79, 0x25, 0xe6, 0xa1, 0xc8, 0x7b, 0x5d, 0xad, 0x4f, 0x32, 0x6c, 0x7c,
|
||||||
0x45, 0xd2, 0x33, 0xfa, 0xa4, 0xbf, 0xad, 0xef, 0x26, 0xa0, 0xb2, 0x4d, 0xe2, 0x7d, 0xda, 0x21,
|
0x5b, 0x86, 0xd2, 0x01, 0x8e, 0xfb, 0xa4, 0x85, 0xd1, 0x4f, 0x06, 0x54, 0x32, 0xa7, 0x05, 0x35,
|
||||||
0xe8, 0x67, 0x0b, 0xaa, 0xb9, 0x1e, 0x42, 0xad, 0x61, 0x34, 0x8e, 0xf7, 0xa1, 0x7d, 0xe3, 0x4c,
|
0xc6, 0xd1, 0x38, 0x7d, 0xe2, 0xac, 0x9b, 0x53, 0xe5, 0xa8, 0xe3, 0x58, 0xab, 0x7f, 0xf3, 0xfb,
|
||||||
0x39, 0xba, 0x49, 0x1b, 0xcd, 0x6f, 0xff, 0xf8, 0xe7, 0x87, 0xd2, 0x32, 0x5a, 0x72, 0x87, 0x3c,
|
0xdf, 0xdf, 0x17, 0x36, 0xd0, 0xba, 0x33, 0xe6, 0xc1, 0x33, 0x3c, 0xb4, 0xe8, 0x07, 0x03, 0x60,
|
||||||
0x83, 0x06, 0x2d, 0x8c, 0x7e, 0xb4, 0x00, 0x8e, 0xb6, 0x0d, 0x6a, 0x8e, 0x30, 0x6d, 0x71, 0xdf,
|
0x74, 0x41, 0x50, 0x7d, 0x82, 0x65, 0xf3, 0x37, 0xcc, 0x6a, 0x4c, 0x93, 0xa2, 0x81, 0x3a, 0x12,
|
||||||
0xd9, 0xad, 0xb3, 0xa4, 0x18, 0xa0, 0xae, 0x02, 0xba, 0x84, 0xae, 0x0f, 0x03, 0x6a, 0x36, 0x2b,
|
0xe8, 0x3a, 0xba, 0x31, 0x0e, 0xa8, 0xbe, 0x96, 0xe8, 0x57, 0x03, 0xfe, 0x9f, 0xef, 0x2d, 0x68,
|
||||||
0xfa, 0xd5, 0x82, 0x37, 0x8b, 0x27, 0x0e, 0xba, 0x35, 0xc2, 0xbc, 0xc7, 0x8f, 0x2e, 0x7b, 0xf5,
|
0x6b, 0x82, 0x75, 0x4f, 0x37, 0x29, 0x6b, 0x7b, 0xda, 0x34, 0x0d, 0x79, 0x4b, 0x42, 0x76, 0xd0,
|
||||||
0xac, 0x69, 0x06, 0xf2, 0x2d, 0x05, 0xd9, 0x45, 0x2b, 0xc3, 0x20, 0xab, 0x23, 0x4a, 0xb8, 0x5d,
|
0xe6, 0x38, 0xc8, 0xb2, 0x19, 0x71, 0xa7, 0x23, 0x6b, 0xa0, 0x67, 0x06, 0xcc, 0xbf, 0xda, 0xae,
|
||||||
0x55, 0x03, 0x3d, 0xb3, 0x60, 0xf2, 0xd5, 0x43, 0x1c, 0xdd, 0x1e, 0x01, 0xc3, 0x49, 0x37, 0x85,
|
0xd1, 0xed, 0x09, 0x30, 0x9c, 0xf5, 0x4f, 0xb0, 0xee, 0x4c, 0x9f, 0xa8, 0xe1, 0xdf, 0x96, 0xf0,
|
||||||
0x7d, 0xe7, 0xec, 0x89, 0x06, 0xfe, 0x6d, 0x05, 0xbf, 0x89, 0xdc, 0x11, 0xe1, 0x7f, 0xa5, 0xef,
|
0xeb, 0xc8, 0x99, 0x10, 0xfe, 0x97, 0xea, 0x6f, 0xf3, 0x14, 0xbd, 0x30, 0x32, 0xed, 0x3e, 0xfb,
|
||||||
0xa0, 0xa7, 0xe8, 0x85, 0x95, 0xbb, 0x04, 0xf2, 0x2f, 0x0a, 0x74, 0x77, 0x64, 0x25, 0x4f, 0x78,
|
0x76, 0x40, 0x77, 0x27, 0x56, 0xf2, 0x8c, 0xb7, 0x8d, 0xf5, 0xee, 0x05, 0xb3, 0x35, 0x9f, 0xbb,
|
||||||
0xf1, 0xd8, 0xef, 0x9f, 0x33, 0xdb, 0xf0, 0xb9, 0xab, 0xf8, 0xac, 0xa2, 0x9b, 0xc3, 0xf8, 0x1c,
|
0x92, 0xcf, 0x36, 0xba, 0x35, 0x8e, 0xcf, 0xe8, 0xd9, 0x81, 0xc5, 0x70, 0x57, 0xfe, 0x34, 0xe4,
|
||||||
0x3d, 0x46, 0x88, 0x1c, 0xac, 0xca, 0x5f, 0x96, 0xba, 0x8d, 0x4f, 0x7a, 0x69, 0xa2, 0x7b, 0x23,
|
0x7f, 0xf7, 0xac, 0x37, 0x25, 0xba, 0x37, 0x01, 0xb0, 0xd7, 0xbc, 0x87, 0xad, 0xf7, 0x2e, 0x9c,
|
||||||
0x00, 0x7b, 0xcd, 0x2b, 0xd9, 0xfe, 0xe0, 0xdc, 0xf9, 0x86, 0xda, 0x3d, 0x45, 0xed, 0x0e, 0x5a,
|
0xaf, 0xa9, 0xdd, 0x93, 0xd4, 0xee, 0xa0, 0xed, 0xe9, 0xa8, 0xa5, 0x3b, 0xb6, 0xf3, 0xe8, 0xb7,
|
||||||
0x3d, 0x1b, 0xb5, 0x6c, 0xc5, 0xd6, 0x1e, 0xfd, 0x7e, 0x50, 0xb7, 0x9e, 0x1f, 0xd4, 0xad, 0xbf,
|
0xe3, 0xaa, 0xf1, 0xfc, 0xb8, 0x6a, 0xfc, 0x75, 0x5c, 0x35, 0xbe, 0x3b, 0xa9, 0xce, 0x3c, 0x3f,
|
||||||
0x0f, 0xea, 0xd6, 0xf7, 0x87, 0xf5, 0x0b, 0xcf, 0x0f, 0xeb, 0x17, 0x5e, 0x1e, 0xd6, 0x2f, 0x7c,
|
0xa9, 0xce, 0xbc, 0x3c, 0xa9, 0xce, 0x7c, 0xd6, 0x08, 0x89, 0x38, 0xea, 0x35, 0xed, 0x16, 0xed,
|
||||||
0xde, 0x0a, 0xa9, 0xdc, 0x4d, 0xda, 0x4e, 0x87, 0xf5, 0xb2, 0xda, 0xfa, 0xb3, 0x22, 0x82, 0x3d,
|
0xa6, 0xb5, 0xd5, 0x67, 0x93, 0x07, 0x6d, 0xa7, 0xd5, 0x21, 0x38, 0x12, 0x4e, 0x18, 0xb3, 0x96,
|
||||||
0xb7, 0xd3, 0xa5, 0x24, 0x92, 0x6e, 0x18, 0xf3, 0x8e, 0x2b, 0x7b, 0x42, 0x1f, 0x66, 0xed, 0x31,
|
0x23, 0xba, 0x5c, 0x35, 0xb3, 0xe6, 0xac, 0x7c, 0x07, 0xdd, 0xfc, 0x27, 0x00, 0x00, 0xff, 0xff,
|
||||||
0xf5, 0x3a, 0xba, 0xf1, 0x6f, 0x00, 0x00, 0x00, 0xff, 0xff, 0x4b, 0xcb, 0x77, 0x6d, 0x5a, 0x0d,
|
0x1c, 0x72, 0x7c, 0x16, 0x44, 0x0d, 0x00, 0x00,
|
||||||
0x00, 0x00,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reference imports to suppress errors if they are not otherwise used.
|
// Reference imports to suppress errors if they are not otherwise used.
|
||||||
|
@ -1712,9 +1711,9 @@ func (m *GetNodeInfoResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
|
||||||
i--
|
i--
|
||||||
dAtA[i] = 0x12
|
dAtA[i] = 0x12
|
||||||
}
|
}
|
||||||
if m.DefaultNodeInfo != nil {
|
if m.NodeInfo != nil {
|
||||||
{
|
{
|
||||||
size, err := m.DefaultNodeInfo.MarshalToSizedBuffer(dAtA[:i])
|
size, err := m.NodeInfo.MarshalToSizedBuffer(dAtA[:i])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
|
@ -2055,8 +2054,8 @@ func (m *GetNodeInfoResponse) Size() (n int) {
|
||||||
}
|
}
|
||||||
var l int
|
var l int
|
||||||
_ = l
|
_ = l
|
||||||
if m.DefaultNodeInfo != nil {
|
if m.NodeInfo != nil {
|
||||||
l = m.DefaultNodeInfo.Size()
|
l = m.NodeInfo.Size()
|
||||||
n += 1 + l + sovQuery(uint64(l))
|
n += 1 + l + sovQuery(uint64(l))
|
||||||
}
|
}
|
||||||
if m.ApplicationVersion != nil {
|
if m.ApplicationVersion != nil {
|
||||||
|
@ -3325,7 +3324,7 @@ func (m *GetNodeInfoResponse) Unmarshal(dAtA []byte) error {
|
||||||
switch fieldNum {
|
switch fieldNum {
|
||||||
case 1:
|
case 1:
|
||||||
if wireType != 2 {
|
if wireType != 2 {
|
||||||
return fmt.Errorf("proto: wrong wireType = %d for field DefaultNodeInfo", wireType)
|
return fmt.Errorf("proto: wrong wireType = %d for field NodeInfo", wireType)
|
||||||
}
|
}
|
||||||
var msglen int
|
var msglen int
|
||||||
for shift := uint(0); ; shift += 7 {
|
for shift := uint(0); ; shift += 7 {
|
||||||
|
@ -3352,10 +3351,10 @@ func (m *GetNodeInfoResponse) Unmarshal(dAtA []byte) error {
|
||||||
if postIndex > l {
|
if postIndex > l {
|
||||||
return io.ErrUnexpectedEOF
|
return io.ErrUnexpectedEOF
|
||||||
}
|
}
|
||||||
if m.DefaultNodeInfo == nil {
|
if m.NodeInfo == nil {
|
||||||
m.DefaultNodeInfo = &p2p.DefaultNodeInfo{}
|
m.NodeInfo = &p2p.NodeInfo{}
|
||||||
}
|
}
|
||||||
if err := m.DefaultNodeInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
|
if err := m.NodeInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
iNdEx = postIndex
|
iNdEx = postIndex
|
||||||
|
|
|
@ -182,7 +182,7 @@ func (s queryServer) GetNodeInfo(ctx context.Context, req *GetNodeInfoRequest) (
|
||||||
}
|
}
|
||||||
|
|
||||||
resp := GetNodeInfoResponse{
|
resp := GetNodeInfoResponse{
|
||||||
DefaultNodeInfo: protoNodeInfo,
|
NodeInfo: protoNodeInfo,
|
||||||
ApplicationVersion: &VersionInfo{
|
ApplicationVersion: &VersionInfo{
|
||||||
AppName: nodeInfo.AppName,
|
AppName: nodeInfo.AppName,
|
||||||
Name: nodeInfo.Name,
|
Name: nodeInfo.Name,
|
||||||
|
|
|
@ -204,7 +204,7 @@ func (s IntegrationTestSuite) TestValidatorSetByHeight_GRPC() {
|
||||||
expErrMsg string
|
expErrMsg string
|
||||||
}{
|
}{
|
||||||
{"nil request", nil, true, "request cannot be nil"},
|
{"nil request", nil, true, "request cannot be nil"},
|
||||||
{"empty request", &tmservice.GetValidatorSetByHeightRequest{}, true, "height must be greater than 0"},
|
{"empty request", &tmservice.GetValidatorSetByHeightRequest{}, true, "height must be greater than zero"},
|
||||||
{"no pagination", &tmservice.GetValidatorSetByHeightRequest{Height: 1}, false, ""},
|
{"no pagination", &tmservice.GetValidatorSetByHeightRequest{Height: 1}, false, ""},
|
||||||
{"with pagination", &tmservice.GetValidatorSetByHeightRequest{Height: 1, Pagination: &qtypes.PageRequest{Offset: 0, Limit: 1}}, false, ""},
|
{"with pagination", &tmservice.GetValidatorSetByHeightRequest{Height: 1, Pagination: &qtypes.PageRequest{Offset: 0, Limit: 1}}, false, ""},
|
||||||
}
|
}
|
||||||
|
@ -232,7 +232,7 @@ func (s IntegrationTestSuite) TestValidatorSetByHeight_GRPCGateway() {
|
||||||
expErr bool
|
expErr bool
|
||||||
expErrMsg string
|
expErrMsg string
|
||||||
}{
|
}{
|
||||||
{"invalid height", fmt.Sprintf("%s/cosmos/base/tendermint/v1beta1/validatorsets/%d", vals[0].APIAddress, -1), true, "height must be greater than 0"},
|
{"invalid height", fmt.Sprintf("%s/cosmos/base/tendermint/v1beta1/validatorsets/%d", vals[0].APIAddress, -1), true, "height must be greater than zero"},
|
||||||
{"no pagination", fmt.Sprintf("%s/cosmos/base/tendermint/v1beta1/validatorsets/%d", vals[0].APIAddress, 1), false, ""},
|
{"no pagination", fmt.Sprintf("%s/cosmos/base/tendermint/v1beta1/validatorsets/%d", vals[0].APIAddress, 1), false, ""},
|
||||||
{"pagination invalid fields", fmt.Sprintf("%s/cosmos/base/tendermint/v1beta1/validatorsets/%d?pagination.offset=-1&pagination.limit=-2", vals[0].APIAddress, 1), true, "strconv.ParseUint"},
|
{"pagination invalid fields", fmt.Sprintf("%s/cosmos/base/tendermint/v1beta1/validatorsets/%d?pagination.offset=-1&pagination.limit=-2", vals[0].APIAddress, 1), true, "strconv.ParseUint"},
|
||||||
{"with pagination", fmt.Sprintf("%s/cosmos/base/tendermint/v1beta1/validatorsets/%d?pagination.offset=0&pagination.limit=2", vals[0].APIAddress, 1), false, ""},
|
{"with pagination", fmt.Sprintf("%s/cosmos/base/tendermint/v1beta1/validatorsets/%d?pagination.offset=0&pagination.limit=2", vals[0].APIAddress, 1), false, ""},
|
||||||
|
|
|
@ -3,15 +3,15 @@ package tmservice
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
"github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
)
|
)
|
||||||
|
|
||||||
func getNodeStatus(ctx context.Context, clientCtx client.Context) (*ctypes.ResultStatus, error) {
|
func getNodeStatus(ctx context.Context, clientCtx client.Context) (*coretypes.ResultStatus, error) {
|
||||||
node, err := clientCtx.GetNode()
|
node, err := clientCtx.GetNode()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return &ctypes.ResultStatus{}, err
|
return &coretypes.ResultStatus{}, err
|
||||||
}
|
}
|
||||||
return node.Status(ctx)
|
return node.Status(ctx)
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,8 +6,8 @@ import (
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
"github.com/tendermint/tendermint/libs/bytes"
|
"github.com/tendermint/tendermint/libs/bytes"
|
||||||
"github.com/tendermint/tendermint/p2p"
|
"github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
"github.com/cosmos/cosmos-sdk/client/flags"
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
||||||
|
@ -26,8 +26,8 @@ type validatorInfo struct {
|
||||||
// ResultStatus is node's info, same as Tendermint, except that we use our own
|
// ResultStatus is node's info, same as Tendermint, except that we use our own
|
||||||
// PubKey.
|
// PubKey.
|
||||||
type resultStatus struct {
|
type resultStatus struct {
|
||||||
NodeInfo p2p.DefaultNodeInfo
|
NodeInfo tmtypes.NodeInfo
|
||||||
SyncInfo ctypes.SyncInfo
|
SyncInfo coretypes.SyncInfo
|
||||||
ValidatorInfo validatorInfo
|
ValidatorInfo validatorInfo
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,10 +77,10 @@ func StatusCommand() *cobra.Command {
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
func getNodeStatus(clientCtx client.Context) (*ctypes.ResultStatus, error) {
|
func getNodeStatus(clientCtx client.Context) (*coretypes.ResultStatus, error) {
|
||||||
node, err := clientCtx.GetNode()
|
node, err := clientCtx.GetNode()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return &ctypes.ResultStatus{}, err
|
return &coretypes.ResultStatus{}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return node.Status(context.Background())
|
return node.Status(context.Background())
|
||||||
|
|
|
@ -73,8 +73,6 @@ func ReadPageRequest(flagSet *pflag.FlagSet) (*query.PageRequest, error) {
|
||||||
|
|
||||||
// NewClientFromNode sets up Client implementation that communicates with a Tendermint node over
|
// NewClientFromNode sets up Client implementation that communicates with a Tendermint node over
|
||||||
// JSON RPC and WebSockets
|
// JSON RPC and WebSockets
|
||||||
// TODO: We might not need to manually append `/websocket`:
|
|
||||||
// https://github.com/cosmos/cosmos-sdk/issues/8986
|
|
||||||
func NewClientFromNode(nodeURI string) (*rpchttp.HTTP, error) {
|
func NewClientFromNode(nodeURI string) (*rpchttp.HTTP, error) {
|
||||||
return rpchttp.New(nodeURI, "/websocket")
|
return rpchttp.New(nodeURI)
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
|
@ -4,14 +4,16 @@
|
||||||
package cosmovisor_test
|
package cosmovisor_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"net"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/otiai10/copy"
|
"github.com/otiai10/copy"
|
||||||
|
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
|
|
||||||
|
@ -139,7 +141,13 @@ func (s *upgradeTestSuite) TestGetDownloadURL() {
|
||||||
cases := map[string]struct {
|
cases := map[string]struct {
|
||||||
info string
|
info string
|
||||||
url string
|
url string
|
||||||
err string
|
err interface{}
|
||||||
|
|
||||||
|
// If err == nil, the test must not report an error.
|
||||||
|
// If err is a string, the test must report an error whose string has err
|
||||||
|
// as a substring.
|
||||||
|
// If err is a func(suite.Suite, error), it is called to check the error
|
||||||
|
// value.
|
||||||
}{
|
}{
|
||||||
"missing": {
|
"missing": {
|
||||||
err: "downloading reference link : invalid source string:",
|
err: "downloading reference link : invalid source string:",
|
||||||
|
@ -154,7 +162,12 @@ func (s *upgradeTestSuite) TestGetDownloadURL() {
|
||||||
},
|
},
|
||||||
"missing link": {
|
"missing link": {
|
||||||
info: "https://no.such.domain/exists.txt",
|
info: "https://no.such.domain/exists.txt",
|
||||||
err: "dial tcp: lookup no.such.domain: no such host",
|
err: func(s suite.Suite, err error) {
|
||||||
|
var dns *net.DNSError
|
||||||
|
s.Require().True(errors.As(err, &dns), "result is not a DNSError")
|
||||||
|
s.Require().Equal("no.such.domain", dns.Name)
|
||||||
|
s.Require().Equal(true, dns.IsNotFound)
|
||||||
|
},
|
||||||
},
|
},
|
||||||
"proper binary": {
|
"proper binary": {
|
||||||
info: `{"binaries": {"linux/amd64": "https://foo.bar/", "windows/amd64": "https://something.else"}}`,
|
info: `{"binaries": {"linux/amd64": "https://foo.bar/", "windows/amd64": "https://something.else"}}`,
|
||||||
|
@ -177,12 +190,17 @@ func (s *upgradeTestSuite) TestGetDownloadURL() {
|
||||||
for name, tc := range cases {
|
for name, tc := range cases {
|
||||||
s.Run(name, func() {
|
s.Run(name, func() {
|
||||||
url, err := cosmovisor.GetDownloadURL(upgradetypes.Plan{Info: tc.info})
|
url, err := cosmovisor.GetDownloadURL(upgradetypes.Plan{Info: tc.info})
|
||||||
if tc.err != "" {
|
switch e := tc.err.(type) {
|
||||||
s.Require().Error(err)
|
case nil:
|
||||||
s.Require().Contains(err.Error(), tc.err)
|
|
||||||
} else {
|
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
s.Require().Equal(tc.url, url)
|
s.Require().Equal(tc.url, url)
|
||||||
|
|
||||||
|
case string:
|
||||||
|
s.Require().Error(err)
|
||||||
|
s.Require().Contains(err.Error(), tc.err)
|
||||||
|
|
||||||
|
case func(suite.Suite, error):
|
||||||
|
e(s.Suite, err)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -230,43 +248,42 @@ func (s *upgradeTestSuite) TestDownloadBinary() {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range cases {
|
for label, tc := range cases {
|
||||||
var err error
|
s.Run(label, func() {
|
||||||
// make temp dir
|
var err error
|
||||||
home := copyTestData(s.T(), "download")
|
// make temp dir
|
||||||
|
home := copyTestData(s.T(), "download")
|
||||||
|
|
||||||
cfg := &cosmovisor.Config{
|
cfg := &cosmovisor.Config{
|
||||||
Home: home,
|
Home: home,
|
||||||
Name: "autod",
|
Name: "autod",
|
||||||
AllowDownloadBinaries: true,
|
AllowDownloadBinaries: true,
|
||||||
}
|
}
|
||||||
|
|
||||||
// if we have a relative path, make it absolute, but don't change eg. https://... urls
|
url := tc.url
|
||||||
url := tc.url
|
if strings.HasPrefix(url, "./") {
|
||||||
if strings.HasPrefix(url, "./") {
|
url, err = filepath.Abs(url)
|
||||||
url, err = filepath.Abs(url)
|
s.Require().NoError(err)
|
||||||
s.Require().NoError(err)
|
}
|
||||||
}
|
|
||||||
|
|
||||||
upgrade := "amazonas"
|
const upgrade = "amazonas"
|
||||||
info := upgradetypes.Plan{
|
info := upgradetypes.Plan{
|
||||||
Name: upgrade,
|
Name: upgrade,
|
||||||
Info: fmt.Sprintf(`{"binaries":{"%s": "%s"}}`, cosmovisor.OSArch(), url),
|
Info: fmt.Sprintf(`{"binaries":{"%s": "%s"}}`, cosmovisor.OSArch(), url),
|
||||||
}
|
}
|
||||||
|
|
||||||
err = cosmovisor.DownloadBinary(cfg, info)
|
err = cosmovisor.DownloadBinary(cfg, info)
|
||||||
if !tc.canDownload {
|
if !tc.canDownload {
|
||||||
s.Require().Error(err)
|
s.Require().Error(err)
|
||||||
} else {
|
} else {
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
}
|
||||||
|
|
||||||
err = cosmovisor.EnsureBinary(cfg.UpgradeBin(upgrade))
|
err = cosmovisor.EnsureBinary(cfg.UpgradeBin(upgrade))
|
||||||
if tc.validBinary {
|
if tc.validBinary {
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
} else {
|
|
||||||
s.Require().Error(err)
|
|
||||||
}
|
}
|
||||||
}
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,15 @@
|
||||||
package crypto
|
package crypto
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
|
||||||
"github.com/tendermint/crypto/bcrypt"
|
"github.com/tendermint/crypto/bcrypt"
|
||||||
"github.com/tendermint/tendermint/crypto"
|
"github.com/tendermint/tendermint/crypto"
|
||||||
"github.com/tendermint/tendermint/crypto/armor"
|
|
||||||
"github.com/tendermint/tendermint/crypto/xsalsa20symmetric"
|
"github.com/tendermint/tendermint/crypto/xsalsa20symmetric"
|
||||||
|
"golang.org/x/crypto/openpgp/armor" // nolint: staticcheck
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/codec/legacy"
|
"github.com/cosmos/cosmos-sdk/codec/legacy"
|
||||||
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
|
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
|
||||||
|
@ -50,7 +52,7 @@ func ArmorInfoBytes(bz []byte) string {
|
||||||
headerVersion: "0.0.0",
|
headerVersion: "0.0.0",
|
||||||
}
|
}
|
||||||
|
|
||||||
return armor.EncodeArmor(blockTypeKeyInfo, header, bz)
|
return EncodeArmor(blockTypeKeyInfo, header, bz)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Armor the PubKeyBytes
|
// Armor the PubKeyBytes
|
||||||
|
@ -62,7 +64,7 @@ func ArmorPubKeyBytes(bz []byte, algo string) string {
|
||||||
header[headerType] = algo
|
header[headerType] = algo
|
||||||
}
|
}
|
||||||
|
|
||||||
return armor.EncodeArmor(blockTypePubKey, header, bz)
|
return EncodeArmor(blockTypePubKey, header, bz)
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------
|
//-----------------------------------------------------------------
|
||||||
|
@ -107,7 +109,7 @@ func UnarmorPubKeyBytes(armorStr string) (bz []byte, algo string, err error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func unarmorBytes(armorStr, blockType string) (bz []byte, header map[string]string, err error) {
|
func unarmorBytes(armorStr, blockType string) (bz []byte, header map[string]string, err error) {
|
||||||
bType, header, bz, err := armor.DecodeArmor(armorStr)
|
bType, header, bz, err := DecodeArmor(armorStr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -135,7 +137,7 @@ func EncryptArmorPrivKey(privKey cryptotypes.PrivKey, passphrase string, algo st
|
||||||
header[headerType] = algo
|
header[headerType] = algo
|
||||||
}
|
}
|
||||||
|
|
||||||
armorStr := armor.EncodeArmor(blockTypePrivKey, header, encBytes)
|
armorStr := EncodeArmor(blockTypePrivKey, header, encBytes)
|
||||||
|
|
||||||
return armorStr
|
return armorStr
|
||||||
}
|
}
|
||||||
|
@ -159,7 +161,7 @@ func encryptPrivKey(privKey cryptotypes.PrivKey, passphrase string) (saltBytes [
|
||||||
|
|
||||||
// UnarmorDecryptPrivKey returns the privkey byte slice, a string of the algo type, and an error
|
// UnarmorDecryptPrivKey returns the privkey byte slice, a string of the algo type, and an error
|
||||||
func UnarmorDecryptPrivKey(armorStr string, passphrase string) (privKey cryptotypes.PrivKey, algo string, err error) {
|
func UnarmorDecryptPrivKey(armorStr string, passphrase string) (privKey cryptotypes.PrivKey, algo string, err error) {
|
||||||
blockType, header, encBytes, err := armor.DecodeArmor(armorStr)
|
blockType, header, encBytes, err := DecodeArmor(armorStr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return privKey, "", err
|
return privKey, "", err
|
||||||
}
|
}
|
||||||
|
@ -207,3 +209,36 @@ func decryptPrivKey(saltBytes []byte, encBytes []byte, passphrase string) (privK
|
||||||
|
|
||||||
return legacy.PrivKeyFromBytes(privKeyBytes)
|
return legacy.PrivKeyFromBytes(privKeyBytes)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------
|
||||||
|
// encode/decode with armor
|
||||||
|
|
||||||
|
func EncodeArmor(blockType string, headers map[string]string, data []byte) string {
|
||||||
|
buf := new(bytes.Buffer)
|
||||||
|
w, err := armor.Encode(buf, blockType, headers)
|
||||||
|
if err != nil {
|
||||||
|
panic(fmt.Errorf("could not encode ascii armor: %s", err))
|
||||||
|
}
|
||||||
|
_, err = w.Write(data)
|
||||||
|
if err != nil {
|
||||||
|
panic(fmt.Errorf("could not encode ascii armor: %s", err))
|
||||||
|
}
|
||||||
|
err = w.Close()
|
||||||
|
if err != nil {
|
||||||
|
panic(fmt.Errorf("could not encode ascii armor: %s", err))
|
||||||
|
}
|
||||||
|
return buf.String()
|
||||||
|
}
|
||||||
|
|
||||||
|
func DecodeArmor(armorStr string) (blockType string, headers map[string]string, data []byte, err error) {
|
||||||
|
buf := bytes.NewBufferString(armorStr)
|
||||||
|
block, err := armor.Decode(buf)
|
||||||
|
if err != nil {
|
||||||
|
return "", nil, nil, err
|
||||||
|
}
|
||||||
|
data, err = ioutil.ReadAll(block.Body)
|
||||||
|
if err != nil {
|
||||||
|
return "", nil, nil, err
|
||||||
|
}
|
||||||
|
return block.Type, block.Header, data, nil
|
||||||
|
}
|
||||||
|
|
|
@ -7,10 +7,10 @@ import (
|
||||||
"io"
|
"io"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
"github.com/tendermint/crypto/bcrypt"
|
"github.com/tendermint/crypto/bcrypt"
|
||||||
tmcrypto "github.com/tendermint/tendermint/crypto"
|
tmcrypto "github.com/tendermint/tendermint/crypto"
|
||||||
"github.com/tendermint/tendermint/crypto/armor"
|
|
||||||
"github.com/tendermint/tendermint/crypto/xsalsa20symmetric"
|
"github.com/tendermint/tendermint/crypto/xsalsa20symmetric"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/codec/legacy"
|
"github.com/cosmos/cosmos-sdk/codec/legacy"
|
||||||
|
@ -63,7 +63,7 @@ func TestArmorUnarmorPrivKey(t *testing.T) {
|
||||||
"salt": fmt.Sprintf("%X", saltBytes),
|
"salt": fmt.Sprintf("%X", saltBytes),
|
||||||
"type": "secp256k",
|
"type": "secp256k",
|
||||||
}
|
}
|
||||||
armored = armor.EncodeArmor("TENDERMINT PRIVATE KEY", headerWrongKdf, encBytes)
|
armored = crypto.EncodeArmor("TENDERMINT PRIVATE KEY", headerWrongKdf, encBytes)
|
||||||
_, _, err = crypto.UnarmorDecryptPrivKey(armored, "passphrase")
|
_, _, err = crypto.UnarmorDecryptPrivKey(armored, "passphrase")
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
require.Equal(t, "unrecognized KDF type: wrong", err.Error())
|
require.Equal(t, "unrecognized KDF type: wrong", err.Error())
|
||||||
|
@ -106,7 +106,7 @@ func TestArmorUnarmorPubKey(t *testing.T) {
|
||||||
"version": "0.0.0",
|
"version": "0.0.0",
|
||||||
"type": "unknown",
|
"type": "unknown",
|
||||||
}
|
}
|
||||||
armored = armor.EncodeArmor("TENDERMINT PUBLIC KEY", header, pubBytes)
|
armored = crypto.EncodeArmor("TENDERMINT PUBLIC KEY", header, pubBytes)
|
||||||
_, algo, err = crypto.UnarmorPubKeyBytes(armored)
|
_, algo, err = crypto.UnarmorPubKeyBytes(armored)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
// return secp256k1 if version is 0.0.0
|
// return secp256k1 if version is 0.0.0
|
||||||
|
@ -116,7 +116,7 @@ func TestArmorUnarmorPubKey(t *testing.T) {
|
||||||
header = map[string]string{
|
header = map[string]string{
|
||||||
"type": "unknown",
|
"type": "unknown",
|
||||||
}
|
}
|
||||||
armored = armor.EncodeArmor("TENDERMINT PUBLIC KEY", header, pubBytes)
|
armored = crypto.EncodeArmor("TENDERMINT PUBLIC KEY", header, pubBytes)
|
||||||
bz, algo, err := crypto.UnarmorPubKeyBytes(armored)
|
bz, algo, err := crypto.UnarmorPubKeyBytes(armored)
|
||||||
require.Nil(t, bz)
|
require.Nil(t, bz)
|
||||||
require.Empty(t, algo)
|
require.Empty(t, algo)
|
||||||
|
@ -128,7 +128,7 @@ func TestArmorUnarmorPubKey(t *testing.T) {
|
||||||
"type": "unknown",
|
"type": "unknown",
|
||||||
"version": "unknown",
|
"version": "unknown",
|
||||||
}
|
}
|
||||||
armored = armor.EncodeArmor("TENDERMINT PUBLIC KEY", header, pubBytes)
|
armored = crypto.EncodeArmor("TENDERMINT PUBLIC KEY", header, pubBytes)
|
||||||
bz, algo, err = crypto.UnarmorPubKeyBytes(armored)
|
bz, algo, err = crypto.UnarmorPubKeyBytes(armored)
|
||||||
require.Nil(t, bz)
|
require.Nil(t, bz)
|
||||||
require.Empty(t, algo)
|
require.Empty(t, algo)
|
||||||
|
@ -154,7 +154,7 @@ func TestUnarmorInfoBytesErrors(t *testing.T) {
|
||||||
"type": "Info",
|
"type": "Info",
|
||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
}
|
}
|
||||||
unarmoredBytes, err = crypto.UnarmorInfoBytes(armor.EncodeArmor(
|
unarmoredBytes, err = crypto.UnarmorInfoBytes(crypto.EncodeArmor(
|
||||||
"TENDERMINT KEY INFO", header, []byte("plain-text")))
|
"TENDERMINT KEY INFO", header, []byte("plain-text")))
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
require.Equal(t, "unrecognized version: 0.0.1", err.Error())
|
require.Equal(t, "unrecognized version: 0.0.1", err.Error())
|
||||||
|
@ -176,3 +176,15 @@ func BenchmarkBcryptGenerateFromPassword(b *testing.B) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestArmor(t *testing.T) {
|
||||||
|
blockType := "MINT TEST"
|
||||||
|
data := []byte("somedata")
|
||||||
|
armorStr := crypto.EncodeArmor(blockType, nil, data)
|
||||||
|
|
||||||
|
// Decode armorStr and test for equivalence.
|
||||||
|
blockType2, _, data2, err := crypto.DecodeArmor(armorStr)
|
||||||
|
require.Nil(t, err, "%+v", err)
|
||||||
|
assert.Equal(t, blockType, blockType2)
|
||||||
|
assert.Equal(t, data, data2)
|
||||||
|
}
|
||||||
|
|
|
@ -64,7 +64,7 @@ func tmToProto(tmPk tmMultisig) (*LegacyAminoPubKey, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// MarshalAminoJSON overrides amino JSON unmarshaling.
|
// MarshalAminoJSON overrides amino JSON unmarshaling.
|
||||||
func (m LegacyAminoPubKey) MarshalAminoJSON() (tmMultisig, error) { //nolint:revive
|
func (m LegacyAminoPubKey) MarshalAminoJSON() (tmMultisig, error) { //nolint:golint,revive
|
||||||
return protoToTm(&m)
|
return protoToTm(&m)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3263,7 +3263,7 @@ GetNodeInfoResponse is the response type for the Query/GetNodeInfo RPC method.
|
||||||
|
|
||||||
| Field | Type | Label | Description |
|
| Field | Type | Label | Description |
|
||||||
| ----- | ---- | ----- | ----------- |
|
| ----- | ---- | ----- | ----------- |
|
||||||
| `default_node_info` | [tendermint.p2p.DefaultNodeInfo](#tendermint.p2p.DefaultNodeInfo) | | |
|
| `node_info` | [tendermint.p2p.NodeInfo](#tendermint.p2p.NodeInfo) | | |
|
||||||
| `application_version` | [VersionInfo](#cosmos.base.tendermint.v1beta1.VersionInfo) | | |
|
| `application_version` | [VersionInfo](#cosmos.base.tendermint.v1beta1.VersionInfo) | | |
|
||||||
|
|
||||||
|
|
||||||
|
|
37
go.mod
37
go.mod
|
@ -32,8 +32,6 @@ require (
|
||||||
github.com/lazyledger/smt v0.2.1-0.20210709230900-03ea40719554
|
github.com/lazyledger/smt v0.2.1-0.20210709230900-03ea40719554
|
||||||
github.com/magiconair/properties v1.8.5
|
github.com/magiconair/properties v1.8.5
|
||||||
github.com/mattn/go-isatty v0.0.14
|
github.com/mattn/go-isatty v0.0.14
|
||||||
github.com/onsi/ginkgo v1.16.4 // indirect
|
|
||||||
github.com/onsi/gomega v1.13.0 // indirect
|
|
||||||
github.com/pkg/errors v0.9.1
|
github.com/pkg/errors v0.9.1
|
||||||
github.com/prometheus/client_golang v1.11.0
|
github.com/prometheus/client_golang v1.11.0
|
||||||
github.com/prometheus/common v0.32.1
|
github.com/prometheus/common v0.32.1
|
||||||
|
@ -48,10 +46,10 @@ require (
|
||||||
github.com/tendermint/btcd v0.1.1
|
github.com/tendermint/btcd v0.1.1
|
||||||
github.com/tendermint/crypto v0.0.0-20191022145703-50d29ede1e15
|
github.com/tendermint/crypto v0.0.0-20191022145703-50d29ede1e15
|
||||||
github.com/tendermint/go-amino v0.16.0
|
github.com/tendermint/go-amino v0.16.0
|
||||||
github.com/tendermint/tendermint v0.34.14
|
github.com/tendermint/tendermint v0.35.0
|
||||||
github.com/tendermint/tm-db v0.6.4
|
github.com/tendermint/tm-db v0.6.4
|
||||||
golang.org/x/crypto v0.0.0-20210817164053-32db794688a5
|
golang.org/x/crypto v0.0.0-20210921155107-089bfa567519
|
||||||
google.golang.org/genproto v0.0.0-20210828152312-66f60bf46e71
|
google.golang.org/genproto v0.0.0-20210917145530-b395a37504d4
|
||||||
google.golang.org/grpc v1.42.0
|
google.golang.org/grpc v1.42.0
|
||||||
google.golang.org/protobuf v1.27.1
|
google.golang.org/protobuf v1.27.1
|
||||||
sigs.k8s.io/yaml v1.3.0
|
sigs.k8s.io/yaml v1.3.0
|
||||||
|
@ -61,9 +59,8 @@ require (
|
||||||
cloud.google.com/go v0.93.3 // indirect
|
cloud.google.com/go v0.93.3 // indirect
|
||||||
cloud.google.com/go/storage v1.10.0 // indirect
|
cloud.google.com/go/storage v1.10.0 // indirect
|
||||||
filippo.io/edwards25519 v1.0.0-beta.2 // indirect
|
filippo.io/edwards25519 v1.0.0-beta.2 // indirect
|
||||||
github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d // indirect
|
github.com/Workiva/go-datastructures v1.0.53 // indirect
|
||||||
github.com/Workiva/go-datastructures v1.0.52 // indirect
|
github.com/aws/aws-sdk-go v1.40.45 // indirect
|
||||||
github.com/aws/aws-sdk-go v1.27.0 // indirect
|
|
||||||
github.com/beorn7/perks v1.0.1 // indirect
|
github.com/beorn7/perks v1.0.1 // indirect
|
||||||
github.com/bgentry/go-netrc v0.0.0-20140422174119-9fd32a8b3d3d // indirect
|
github.com/bgentry/go-netrc v0.0.0-20140422174119-9fd32a8b3d3d // indirect
|
||||||
github.com/cenkalti/backoff/v4 v4.1.1 // indirect
|
github.com/cenkalti/backoff/v4 v4.1.1 // indirect
|
||||||
|
@ -80,44 +77,43 @@ require (
|
||||||
github.com/dvsekhvalnov/jose2go v0.0.0-20200901110807-248326c1351b // indirect
|
github.com/dvsekhvalnov/jose2go v0.0.0-20200901110807-248326c1351b // indirect
|
||||||
github.com/felixge/httpsnoop v1.0.1 // indirect
|
github.com/felixge/httpsnoop v1.0.1 // indirect
|
||||||
github.com/fsnotify/fsnotify v1.5.1 // indirect
|
github.com/fsnotify/fsnotify v1.5.1 // indirect
|
||||||
github.com/go-kit/kit v0.10.0 // indirect
|
github.com/go-kit/kit v0.12.0 // indirect
|
||||||
github.com/go-logfmt/logfmt v0.5.0 // indirect
|
|
||||||
github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2 // indirect
|
github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2 // indirect
|
||||||
github.com/golang/glog v1.0.0 // indirect
|
github.com/golang/glog v1.0.0 // indirect
|
||||||
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect
|
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect
|
||||||
github.com/golang/snappy v0.0.4 // indirect
|
github.com/golang/snappy v0.0.4 // indirect
|
||||||
github.com/google/btree v1.0.1 // indirect
|
github.com/google/btree v1.0.1 // indirect
|
||||||
github.com/google/orderedcode v0.0.1 // indirect
|
github.com/google/orderedcode v0.0.1 // indirect
|
||||||
|
github.com/google/uuid v1.3.0 // indirect
|
||||||
github.com/googleapis/gax-go/v2 v2.1.0 // indirect
|
github.com/googleapis/gax-go/v2 v2.1.0 // indirect
|
||||||
github.com/gorilla/websocket v1.4.2 // indirect
|
github.com/gorilla/websocket v1.4.2 // indirect
|
||||||
|
github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 // indirect
|
||||||
github.com/gsterjov/go-libsecret v0.0.0-20161001094733-a6f4afe4910c // indirect
|
github.com/gsterjov/go-libsecret v0.0.0-20161001094733-a6f4afe4910c // indirect
|
||||||
github.com/gtank/merlin v0.1.1 // indirect
|
github.com/hashicorp/go-immutable-radix v1.3.1 // indirect
|
||||||
github.com/gtank/ristretto255 v0.1.2 // indirect
|
|
||||||
github.com/hashicorp/go-immutable-radix v1.0.0 // indirect
|
|
||||||
github.com/hashicorp/go-safetemp v1.0.0 // indirect
|
github.com/hashicorp/go-safetemp v1.0.0 // indirect
|
||||||
github.com/hashicorp/go-version v1.2.0 // indirect
|
github.com/hashicorp/go-version v1.2.1 // indirect
|
||||||
github.com/hashicorp/hcl v1.0.0 // indirect
|
github.com/hashicorp/hcl v1.0.0 // indirect
|
||||||
github.com/inconshreveable/mousetrap v1.0.0 // indirect
|
github.com/inconshreveable/mousetrap v1.0.0 // indirect
|
||||||
github.com/jmespath/go-jmespath v0.4.0 // indirect
|
github.com/jmespath/go-jmespath v0.4.0 // indirect
|
||||||
github.com/jmhodges/levigo v1.0.0 // indirect
|
github.com/jmhodges/levigo v1.0.0 // indirect
|
||||||
github.com/keybase/go-keychain v0.0.0-20190712205309-48d3d31d256d // indirect
|
github.com/keybase/go-keychain v0.0.0-20190712205309-48d3d31d256d // indirect
|
||||||
github.com/klauspost/compress v1.13.6 // indirect
|
github.com/klauspost/compress v1.13.6 // indirect
|
||||||
github.com/lib/pq v1.10.2 // indirect
|
github.com/lib/pq v1.10.3 // indirect
|
||||||
github.com/libp2p/go-buffer-pool v0.0.2 // indirect
|
github.com/libp2p/go-buffer-pool v0.0.2 // indirect
|
||||||
github.com/matttproud/golang_protobuf_extensions v1.0.1 // indirect
|
github.com/matttproud/golang_protobuf_extensions v1.0.1 // indirect
|
||||||
github.com/mimoo/StrobeGo v0.0.0-20181016162300-f8f6d4d2b643 // indirect
|
github.com/minio/highwayhash v1.0.2 // indirect
|
||||||
github.com/minio/highwayhash v1.0.1 // indirect
|
|
||||||
github.com/mitchellh/go-homedir v1.1.0 // indirect
|
github.com/mitchellh/go-homedir v1.1.0 // indirect
|
||||||
github.com/mitchellh/go-testing-interface v1.0.0 // indirect
|
github.com/mitchellh/go-testing-interface v1.0.0 // indirect
|
||||||
github.com/mitchellh/mapstructure v1.4.2 // indirect
|
github.com/mitchellh/mapstructure v1.4.2 // indirect
|
||||||
github.com/mtibben/percent v0.2.1 // indirect
|
github.com/mtibben/percent v0.2.1 // indirect
|
||||||
|
github.com/oasisprotocol/curve25519-voi v0.0.0-20210609091139-0a56a4bca00b // indirect
|
||||||
github.com/pelletier/go-toml v1.9.4 // indirect
|
github.com/pelletier/go-toml v1.9.4 // indirect
|
||||||
github.com/petermattis/goid v0.0.0-20180202154549-b0b1615b78e5 // indirect
|
github.com/petermattis/goid v0.0.0-20180202154549-b0b1615b78e5 // indirect
|
||||||
github.com/pmezard/go-difflib v1.0.0 // indirect
|
github.com/pmezard/go-difflib v1.0.0 // indirect
|
||||||
github.com/prometheus/client_model v0.2.0 // indirect
|
github.com/prometheus/client_model v0.2.0 // indirect
|
||||||
github.com/prometheus/procfs v0.6.0 // indirect
|
github.com/prometheus/procfs v0.7.3 // indirect
|
||||||
github.com/rcrowley/go-metrics v0.0.0-20200313005456-10cdbea86bc0 // indirect
|
github.com/rcrowley/go-metrics v0.0.0-20200313005456-10cdbea86bc0 // indirect
|
||||||
github.com/rs/cors v1.7.0 // indirect
|
github.com/rs/cors v1.8.0 // indirect
|
||||||
github.com/sasha-s/go-deadlock v0.2.1-0.20190427202633-1595213edefa // indirect
|
github.com/sasha-s/go-deadlock v0.2.1-0.20190427202633-1595213edefa // indirect
|
||||||
github.com/spf13/afero v1.6.0 // indirect
|
github.com/spf13/afero v1.6.0 // indirect
|
||||||
github.com/spf13/jwalterweatherman v1.1.0 // indirect
|
github.com/spf13/jwalterweatherman v1.1.0 // indirect
|
||||||
|
@ -130,9 +126,10 @@ require (
|
||||||
go.opencensus.io v0.23.0 // indirect
|
go.opencensus.io v0.23.0 // indirect
|
||||||
golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2 // indirect
|
golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2 // indirect
|
||||||
golang.org/x/oauth2 v0.0.0-20210819190943-2bc19b11175f // indirect
|
golang.org/x/oauth2 v0.0.0-20210819190943-2bc19b11175f // indirect
|
||||||
|
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c // indirect
|
||||||
golang.org/x/sys v0.0.0-20211113001501-0c823b97ae02 // indirect
|
golang.org/x/sys v0.0.0-20211113001501-0c823b97ae02 // indirect
|
||||||
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1 // indirect
|
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1 // indirect
|
||||||
golang.org/x/text v0.3.6 // indirect
|
golang.org/x/text v0.3.7 // indirect
|
||||||
google.golang.org/api v0.56.0 // indirect
|
google.golang.org/api v0.56.0 // indirect
|
||||||
google.golang.org/appengine v1.6.7 // indirect
|
google.golang.org/appengine v1.6.7 // indirect
|
||||||
gopkg.in/ini.v1 v1.63.2 // indirect
|
gopkg.in/ini.v1 v1.63.2 // indirect
|
||||||
|
|
|
@ -111,8 +111,8 @@ message GetNodeInfoRequest {}
|
||||||
|
|
||||||
// GetNodeInfoResponse is the response type for the Query/GetNodeInfo RPC method.
|
// GetNodeInfoResponse is the response type for the Query/GetNodeInfo RPC method.
|
||||||
message GetNodeInfoResponse {
|
message GetNodeInfoResponse {
|
||||||
.tendermint.p2p.DefaultNodeInfo default_node_info = 1;
|
.tendermint.p2p.NodeInfo node_info = 1;
|
||||||
VersionInfo application_version = 2;
|
VersionInfo application_version = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
// VersionInfo is the type for the GetNodeInfoResponse message.
|
// VersionInfo is the type for the GetNodeInfoResponse message.
|
||||||
|
|
|
@ -99,7 +99,7 @@ func (s *Server) Start(cfg config.Config) error {
|
||||||
tmCfg.WriteTimeout = time.Duration(cfg.API.RPCWriteTimeout) * time.Second
|
tmCfg.WriteTimeout = time.Duration(cfg.API.RPCWriteTimeout) * time.Second
|
||||||
tmCfg.MaxBodyBytes = int64(cfg.API.RPCMaxBodyBytes)
|
tmCfg.MaxBodyBytes = int64(cfg.API.RPCMaxBodyBytes)
|
||||||
|
|
||||||
listener, err := tmrpcserver.Listen(cfg.API.Address, tmCfg)
|
listener, err := tmrpcserver.Listen(cfg.API.Address, tmCfg.MaxOpenConnections)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,8 +5,8 @@ import (
|
||||||
|
|
||||||
"github.com/rs/zerolog"
|
"github.com/rs/zerolog"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
tmcfg "github.com/tendermint/tendermint/config"
|
|
||||||
tmcli "github.com/tendermint/tendermint/libs/cli"
|
tmcli "github.com/tendermint/tendermint/libs/cli"
|
||||||
|
tmlog "github.com/tendermint/tendermint/libs/log"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
"github.com/cosmos/cosmos-sdk/client/flags"
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
||||||
|
@ -30,7 +30,7 @@ func Execute(rootCmd *cobra.Command, defaultHome string) error {
|
||||||
ctx = context.WithValue(ctx, server.ServerContextKey, srvCtx)
|
ctx = context.WithValue(ctx, server.ServerContextKey, srvCtx)
|
||||||
|
|
||||||
rootCmd.PersistentFlags().String(flags.FlagLogLevel, zerolog.InfoLevel.String(), "The logging level (trace|debug|info|warn|error|fatal|panic)")
|
rootCmd.PersistentFlags().String(flags.FlagLogLevel, zerolog.InfoLevel.String(), "The logging level (trace|debug|info|warn|error|fatal|panic)")
|
||||||
rootCmd.PersistentFlags().String(flags.FlagLogFormat, tmcfg.LogFormatPlain, "The logging format (json|plain)")
|
rootCmd.PersistentFlags().String(flags.FlagLogFormat, tmlog.LogFormatPlain, "The logging format (json|plain)")
|
||||||
|
|
||||||
executor := tmcli.PrepareBaseCmd(rootCmd, "", defaultHome)
|
executor := tmcli.PrepareBaseCmd(rootCmd, "", defaultHome)
|
||||||
return executor.ExecuteContext(ctx)
|
return executor.ExecuteContext(ctx)
|
||||||
|
|
|
@ -2,10 +2,12 @@ package config
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
"text/template"
|
"text/template"
|
||||||
|
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
tmos "github.com/tendermint/tendermint/libs/os"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const DefaultConfigTemplate = `# This is a TOML config file.
|
const DefaultConfigTemplate = `# This is a TOML config file.
|
||||||
|
@ -245,5 +247,12 @@ func WriteConfigFile(configFilePath string, config interface{}) {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
tmos.MustWriteFile(configFilePath, buffer.Bytes(), 0644)
|
mustWriteFile(configFilePath, buffer.Bytes(), 0644)
|
||||||
|
}
|
||||||
|
|
||||||
|
func mustWriteFile(filePath string, contents []byte, mode os.FileMode) {
|
||||||
|
if err := ioutil.WriteFile(filePath, contents, mode); err != nil {
|
||||||
|
fmt.Printf(fmt.Sprintf("failed to write file: %v", err) + "\n")
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,6 @@ import (
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
tmjson "github.com/tendermint/tendermint/libs/json"
|
tmjson "github.com/tendermint/tendermint/libs/json"
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
|
||||||
tmtypes "github.com/tendermint/tendermint/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client/flags"
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
||||||
|
@ -80,18 +79,17 @@ func ExportCmd(appExporter types.AppExporter, defaultNodeHome string) *cobra.Com
|
||||||
doc.AppState = exported.AppState
|
doc.AppState = exported.AppState
|
||||||
doc.Validators = exported.Validators
|
doc.Validators = exported.Validators
|
||||||
doc.InitialHeight = exported.Height
|
doc.InitialHeight = exported.Height
|
||||||
doc.ConsensusParams = &tmproto.ConsensusParams{
|
doc.ConsensusParams = &tmtypes.ConsensusParams{
|
||||||
Block: tmproto.BlockParams{
|
Block: tmtypes.BlockParams{
|
||||||
MaxBytes: exported.ConsensusParams.Block.MaxBytes,
|
MaxBytes: exported.ConsensusParams.Block.MaxBytes,
|
||||||
MaxGas: exported.ConsensusParams.Block.MaxGas,
|
MaxGas: exported.ConsensusParams.Block.MaxGas,
|
||||||
TimeIotaMs: doc.ConsensusParams.Block.TimeIotaMs,
|
|
||||||
},
|
},
|
||||||
Evidence: tmproto.EvidenceParams{
|
Evidence: tmtypes.EvidenceParams{
|
||||||
MaxAgeNumBlocks: exported.ConsensusParams.Evidence.MaxAgeNumBlocks,
|
MaxAgeNumBlocks: exported.ConsensusParams.Evidence.MaxAgeNumBlocks,
|
||||||
MaxAgeDuration: exported.ConsensusParams.Evidence.MaxAgeDuration,
|
MaxAgeDuration: exported.ConsensusParams.Evidence.MaxAgeDuration,
|
||||||
MaxBytes: exported.ConsensusParams.Evidence.MaxBytes,
|
MaxBytes: exported.ConsensusParams.Evidence.MaxBytes,
|
||||||
},
|
},
|
||||||
Validator: tmproto.ValidatorParams{
|
Validator: tmtypes.ValidatorParams{
|
||||||
PubKeyTypes: exported.ConsensusParams.Validator.PubKeyTypes,
|
PubKeyTypes: exported.ConsensusParams.Validator.PubKeyTypes,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,7 +31,7 @@ import (
|
||||||
func TestExportCmd_ConsensusParams(t *testing.T) {
|
func TestExportCmd_ConsensusParams(t *testing.T) {
|
||||||
tempDir := t.TempDir()
|
tempDir := t.TempDir()
|
||||||
|
|
||||||
_, ctx, genDoc, cmd := setupApp(t, tempDir)
|
_, ctx, _, cmd := setupApp(t, tempDir)
|
||||||
|
|
||||||
output := &bytes.Buffer{}
|
output := &bytes.Buffer{}
|
||||||
cmd.SetOut(output)
|
cmd.SetOut(output)
|
||||||
|
@ -44,7 +44,6 @@ func TestExportCmd_ConsensusParams(t *testing.T) {
|
||||||
t.Fatalf("error unmarshaling exported genesis doc: %s", err)
|
t.Fatalf("error unmarshaling exported genesis doc: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
require.Equal(t, genDoc.ConsensusParams.Block.TimeIotaMs, exportedGenDoc.ConsensusParams.Block.TimeIotaMs)
|
|
||||||
require.Equal(t, simapp.DefaultConsensusParams.Block.MaxBytes, exportedGenDoc.ConsensusParams.Block.MaxBytes)
|
require.Equal(t, simapp.DefaultConsensusParams.Block.MaxBytes, exportedGenDoc.ConsensusParams.Block.MaxBytes)
|
||||||
require.Equal(t, simapp.DefaultConsensusParams.Block.MaxGas, exportedGenDoc.ConsensusParams.Block.MaxGas)
|
require.Equal(t, simapp.DefaultConsensusParams.Block.MaxGas, exportedGenDoc.ConsensusParams.Block.MaxGas)
|
||||||
|
|
||||||
|
@ -127,7 +126,7 @@ func setupApp(t *testing.T, tempDir string) (*simapp.SimApp, context.Context, *t
|
||||||
t.Fatalf("error creating config folder: %s", err)
|
t.Fatalf("error creating config folder: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
logger, _ := log.NewDefaultLogger("plain", "info", false)
|
||||||
db := dbm.NewMemDB()
|
db := dbm.NewMemDB()
|
||||||
encCfg := simapp.MakeTestEncodingConfig()
|
encCfg := simapp.MakeTestEncodingConfig()
|
||||||
app := simapp.NewSimApp(logger, db, nil, true, map[int64]bool{}, tempDir, 0, encCfg, simapp.EmptyAppOptions{})
|
app := simapp.NewSimApp(logger, db, nil, true, map[int64]bool{}, tempDir, 0, encCfg, simapp.EmptyAppOptions{})
|
||||||
|
|
|
@ -2,18 +2,28 @@ package mock
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
|
"github.com/rs/zerolog"
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
"github.com/tendermint/tendermint/libs/log"
|
tmlog "github.com/tendermint/tendermint/libs/log"
|
||||||
|
|
||||||
|
"github.com/cosmos/cosmos-sdk/server"
|
||||||
)
|
)
|
||||||
|
|
||||||
// SetupApp returns an application as well as a clean-up function
|
// SetupApp returns an application as well as a clean-up function
|
||||||
// to be used to quickly setup a test case with an app
|
// to be used to quickly setup a test case with an app
|
||||||
func SetupApp() (abci.Application, func(), error) {
|
func SetupApp() (abci.Application, func(), error) {
|
||||||
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout)).
|
var logger tmlog.Logger
|
||||||
With("module", "mock")
|
|
||||||
rootDir, err := os.MkdirTemp("", "mock-sdk")
|
logWriter := zerolog.ConsoleWriter{Out: os.Stderr}
|
||||||
|
logger = server.ZeroLogWrapper{
|
||||||
|
Logger: zerolog.New(logWriter).Level(zerolog.InfoLevel).With().Timestamp().Logger(),
|
||||||
|
}
|
||||||
|
logger = logger.With("module", "mock")
|
||||||
|
|
||||||
|
rootDir, err := ioutil.TempDir("", "mock-sdk")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,32 +11,26 @@ import (
|
||||||
"strconv"
|
"strconv"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/version"
|
|
||||||
|
|
||||||
abcitypes "github.com/tendermint/tendermint/abci/types"
|
|
||||||
|
|
||||||
rosettatypes "github.com/coinbase/rosetta-sdk-go/types"
|
rosettatypes "github.com/coinbase/rosetta-sdk-go/types"
|
||||||
"google.golang.org/grpc/metadata"
|
abcitypes "github.com/tendermint/tendermint/abci/types"
|
||||||
|
tmrpc "github.com/tendermint/tendermint/rpc/client"
|
||||||
"github.com/tendermint/tendermint/rpc/client/http"
|
"github.com/tendermint/tendermint/rpc/client/http"
|
||||||
"google.golang.org/grpc"
|
"google.golang.org/grpc"
|
||||||
|
"google.golang.org/grpc/metadata"
|
||||||
|
|
||||||
crgerrs "github.com/cosmos/cosmos-sdk/server/rosetta/lib/errors"
|
crgerrs "github.com/cosmos/cosmos-sdk/server/rosetta/lib/errors"
|
||||||
crgtypes "github.com/cosmos/cosmos-sdk/server/rosetta/lib/types"
|
crgtypes "github.com/cosmos/cosmos-sdk/server/rosetta/lib/types"
|
||||||
|
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
grpctypes "github.com/cosmos/cosmos-sdk/types/grpc"
|
grpctypes "github.com/cosmos/cosmos-sdk/types/grpc"
|
||||||
|
"github.com/cosmos/cosmos-sdk/version"
|
||||||
authtx "github.com/cosmos/cosmos-sdk/x/auth/tx"
|
authtx "github.com/cosmos/cosmos-sdk/x/auth/tx"
|
||||||
auth "github.com/cosmos/cosmos-sdk/x/auth/types"
|
auth "github.com/cosmos/cosmos-sdk/x/auth/types"
|
||||||
bank "github.com/cosmos/cosmos-sdk/x/bank/types"
|
bank "github.com/cosmos/cosmos-sdk/x/bank/types"
|
||||||
|
|
||||||
tmrpc "github.com/tendermint/tendermint/rpc/client"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// interface assertion
|
// interface assertion
|
||||||
var _ crgtypes.Client = (*Client)(nil)
|
var _ crgtypes.Client = (*Client)(nil)
|
||||||
|
|
||||||
const tmWebsocketPath = "/websocket"
|
|
||||||
const defaultNodeTimeout = 15 * time.Second
|
const defaultNodeTimeout = 15 * time.Second
|
||||||
|
|
||||||
// Client implements a single network client to interact with cosmos based chains
|
// Client implements a single network client to interact with cosmos based chains
|
||||||
|
@ -104,7 +98,7 @@ func (c *Client) Bootstrap() error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
tmRPC, err := http.New(c.config.TendermintRPC, tmWebsocketPath)
|
tmRPC, err := http.New(c.config.TendermintRPC)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -501,18 +495,15 @@ func (c *Client) getHeight(ctx context.Context, height *int64) (realHeight *int6
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var initialHeightRE = regexp.MustCompile(`"initial_height":"(\d+)"`)
|
||||||
|
|
||||||
func extractInitialHeightFromGenesisChunk(genesisChunk string) (int64, error) {
|
func extractInitialHeightFromGenesisChunk(genesisChunk string) (int64, error) {
|
||||||
firstChunk, err := base64.StdEncoding.DecodeString(genesisChunk)
|
firstChunk, err := base64.StdEncoding.DecodeString(genesisChunk)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
|
|
||||||
re, err := regexp.Compile("\"initial_height\":\"(\\d+)\"") //nolint:gocritic
|
matches := initialHeightRE.FindStringSubmatch(string(firstChunk))
|
||||||
if err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
|
|
||||||
matches := re.FindStringSubmatch(string(firstChunk))
|
|
||||||
if len(matches) != 2 {
|
if len(matches) != 2 {
|
||||||
return 0, errors.New("failed to fetch initial_height")
|
return 0, errors.New("failed to fetch initial_height")
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,30 +6,24 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"reflect"
|
"reflect"
|
||||||
|
|
||||||
auth "github.com/cosmos/cosmos-sdk/x/auth/types"
|
|
||||||
|
|
||||||
"github.com/tendermint/tendermint/crypto"
|
|
||||||
|
|
||||||
"github.com/btcsuite/btcd/btcec"
|
"github.com/btcsuite/btcd/btcec"
|
||||||
tmcoretypes "github.com/tendermint/tendermint/rpc/core/types"
|
|
||||||
|
|
||||||
crgtypes "github.com/cosmos/cosmos-sdk/server/rosetta/lib/types"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
|
|
||||||
"github.com/cosmos/cosmos-sdk/types/tx/signing"
|
|
||||||
|
|
||||||
rosettatypes "github.com/coinbase/rosetta-sdk-go/types"
|
rosettatypes "github.com/coinbase/rosetta-sdk-go/types"
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
|
"github.com/tendermint/tendermint/crypto"
|
||||||
|
tmcoretypes "github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
tmtypes "github.com/tendermint/tendermint/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
|
|
||||||
crgerrs "github.com/cosmos/cosmos-sdk/server/rosetta/lib/errors"
|
|
||||||
|
|
||||||
sdkclient "github.com/cosmos/cosmos-sdk/client"
|
sdkclient "github.com/cosmos/cosmos-sdk/client"
|
||||||
"github.com/cosmos/cosmos-sdk/codec"
|
"github.com/cosmos/cosmos-sdk/codec"
|
||||||
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
||||||
|
"github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
|
||||||
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
|
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
|
||||||
|
crgerrs "github.com/cosmos/cosmos-sdk/server/rosetta/lib/errors"
|
||||||
|
crgtypes "github.com/cosmos/cosmos-sdk/server/rosetta/lib/types"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
"github.com/cosmos/cosmos-sdk/types/tx/signing"
|
||||||
authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing"
|
authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing"
|
||||||
|
auth "github.com/cosmos/cosmos-sdk/x/auth/types"
|
||||||
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
|
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -345,11 +339,11 @@ func sdkEventToBalanceOperations(status string, event abci.Event) (operations []
|
||||||
default:
|
default:
|
||||||
return nil, false
|
return nil, false
|
||||||
case banktypes.EventTypeCoinSpent:
|
case banktypes.EventTypeCoinSpent:
|
||||||
spender, err := sdk.AccAddressFromBech32((string)(event.Attributes[0].Value))
|
spender, err := sdk.AccAddressFromBech32(event.Attributes[0].Value)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
coins, err := sdk.ParseCoinsNormalized((string)(event.Attributes[1].Value))
|
coins, err := sdk.ParseCoinsNormalized(event.Attributes[1].Value)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
@ -359,11 +353,11 @@ func sdkEventToBalanceOperations(status string, event abci.Event) (operations []
|
||||||
accountIdentifier = spender.String()
|
accountIdentifier = spender.String()
|
||||||
|
|
||||||
case banktypes.EventTypeCoinReceived:
|
case banktypes.EventTypeCoinReceived:
|
||||||
receiver, err := sdk.AccAddressFromBech32((string)(event.Attributes[0].Value))
|
receiver, err := sdk.AccAddressFromBech32(event.Attributes[0].Value)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
coins, err := sdk.ParseCoinsNormalized((string)(event.Attributes[1].Value))
|
coins, err := sdk.ParseCoinsNormalized(event.Attributes[1].Value)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
@ -375,7 +369,7 @@ func sdkEventToBalanceOperations(status string, event abci.Event) (operations []
|
||||||
// rosetta does not have the concept of burning coins, so we need to mock
|
// rosetta does not have the concept of burning coins, so we need to mock
|
||||||
// the burn as a send to an address that cannot be resolved to anything
|
// the burn as a send to an address that cannot be resolved to anything
|
||||||
case banktypes.EventTypeCoinBurn:
|
case banktypes.EventTypeCoinBurn:
|
||||||
coins, err := sdk.ParseCoinsNormalized((string)(event.Attributes[1].Value))
|
coins, err := sdk.ParseCoinsNormalized(event.Attributes[1].Value)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
@ -571,9 +565,9 @@ func (c converter) Peers(peers []tmcoretypes.Peer) []*rosettatypes.Peer {
|
||||||
|
|
||||||
for i, peer := range peers {
|
for i, peer := range peers {
|
||||||
converted[i] = &rosettatypes.Peer{
|
converted[i] = &rosettatypes.Peer{
|
||||||
PeerID: peer.NodeInfo.Moniker,
|
PeerID: string(peer.ID),
|
||||||
Metadata: map[string]interface{}{
|
Metadata: map[string]interface{}{
|
||||||
"addr": peer.NodeInfo.ListenAddr,
|
"addr": peer.URL,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,28 +9,24 @@ import (
|
||||||
"runtime/pprof"
|
"runtime/pprof"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/codec"
|
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
"google.golang.org/grpc"
|
abciclient "github.com/tendermint/tendermint/abci/client"
|
||||||
|
|
||||||
"github.com/tendermint/tendermint/abci/server"
|
"github.com/tendermint/tendermint/abci/server"
|
||||||
tcmd "github.com/tendermint/tendermint/cmd/tendermint/commands"
|
tcmd "github.com/tendermint/tendermint/cmd/tendermint/commands"
|
||||||
tmos "github.com/tendermint/tendermint/libs/os"
|
tmos "github.com/tendermint/tendermint/libs/os"
|
||||||
"github.com/tendermint/tendermint/node"
|
"github.com/tendermint/tendermint/node"
|
||||||
"github.com/tendermint/tendermint/p2p"
|
|
||||||
pvm "github.com/tendermint/tendermint/privval"
|
|
||||||
"github.com/tendermint/tendermint/proxy"
|
|
||||||
"github.com/tendermint/tendermint/rpc/client/local"
|
"github.com/tendermint/tendermint/rpc/client/local"
|
||||||
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
"github.com/cosmos/cosmos-sdk/server/rosetta"
|
"google.golang.org/grpc"
|
||||||
crgserver "github.com/cosmos/cosmos-sdk/server/rosetta/lib/server"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
"github.com/cosmos/cosmos-sdk/client/flags"
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
||||||
|
"github.com/cosmos/cosmos-sdk/codec"
|
||||||
"github.com/cosmos/cosmos-sdk/server/api"
|
"github.com/cosmos/cosmos-sdk/server/api"
|
||||||
"github.com/cosmos/cosmos-sdk/server/config"
|
"github.com/cosmos/cosmos-sdk/server/config"
|
||||||
servergrpc "github.com/cosmos/cosmos-sdk/server/grpc"
|
servergrpc "github.com/cosmos/cosmos-sdk/server/grpc"
|
||||||
|
"github.com/cosmos/cosmos-sdk/server/rosetta"
|
||||||
|
crgserver "github.com/cosmos/cosmos-sdk/server/rosetta/lib/server"
|
||||||
"github.com/cosmos/cosmos-sdk/server/types"
|
"github.com/cosmos/cosmos-sdk/server/types"
|
||||||
storetypes "github.com/cosmos/cosmos-sdk/store/types"
|
storetypes "github.com/cosmos/cosmos-sdk/store/types"
|
||||||
)
|
)
|
||||||
|
@ -252,21 +248,16 @@ func startInProcess(ctx *Context, clientCtx client.Context, appCreator types.App
|
||||||
|
|
||||||
app := appCreator(ctx.Logger, db, traceWriter, ctx.Viper)
|
app := appCreator(ctx.Logger, db, traceWriter, ctx.Viper)
|
||||||
|
|
||||||
nodeKey, err := p2p.LoadOrGenNodeKey(cfg.NodeKeyFile())
|
genDoc, err := tmtypes.GenesisDocFromFile(cfg.GenesisFile())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
genDocProvider := node.DefaultGenesisDocProviderFunc(cfg)
|
tmNode, err := node.New(
|
||||||
tmNode, err := node.NewNode(
|
|
||||||
cfg,
|
cfg,
|
||||||
pvm.LoadOrGenFilePV(cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile()),
|
|
||||||
nodeKey,
|
|
||||||
proxy.NewLocalClientCreator(app),
|
|
||||||
genDocProvider,
|
|
||||||
node.DefaultDBProvider,
|
|
||||||
node.DefaultMetricsProvider(cfg.Instrumentation),
|
|
||||||
ctx.Logger,
|
ctx.Logger,
|
||||||
|
abciclient.NewLocalCreator(app),
|
||||||
|
genDoc,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -282,7 +273,15 @@ func startInProcess(ctx *Context, clientCtx client.Context, appCreator types.App
|
||||||
// service if API or gRPC is enabled, and avoid doing so in the general
|
// service if API or gRPC is enabled, and avoid doing so in the general
|
||||||
// case, because it spawns a new local tendermint RPC client.
|
// case, because it spawns a new local tendermint RPC client.
|
||||||
if config.API.Enable || config.GRPC.Enable {
|
if config.API.Enable || config.GRPC.Enable {
|
||||||
clientCtx = clientCtx.WithClient(local.New(tmNode))
|
node, ok := tmNode.(local.NodeService)
|
||||||
|
if !ok {
|
||||||
|
panic("unable to set node type. Please try reinstalling the binary.")
|
||||||
|
}
|
||||||
|
localNode, err := local.New(node)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
clientCtx = clientCtx.WithClient(localNode)
|
||||||
|
|
||||||
app.RegisterTxService(clientCtx)
|
app.RegisterTxService(clientCtx)
|
||||||
app.RegisterTendermintService(clientCtx)
|
app.RegisterTendermintService(clientCtx)
|
||||||
|
@ -290,7 +289,7 @@ func startInProcess(ctx *Context, clientCtx client.Context, appCreator types.App
|
||||||
|
|
||||||
var apiSrv *api.Server
|
var apiSrv *api.Server
|
||||||
if config.API.Enable {
|
if config.API.Enable {
|
||||||
genDoc, err := genDocProvider()
|
genDoc, err := tmtypes.GenesisDocFromFile(cfg.GenesisFile())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,6 @@ import (
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
tcmd "github.com/tendermint/tendermint/cmd/tendermint/commands"
|
tcmd "github.com/tendermint/tendermint/cmd/tendermint/commands"
|
||||||
"github.com/tendermint/tendermint/p2p"
|
|
||||||
pvm "github.com/tendermint/tendermint/privval"
|
pvm "github.com/tendermint/tendermint/privval"
|
||||||
tversion "github.com/tendermint/tendermint/version"
|
tversion "github.com/tendermint/tendermint/version"
|
||||||
"sigs.k8s.io/yaml"
|
"sigs.k8s.io/yaml"
|
||||||
|
@ -26,11 +25,11 @@ func ShowNodeIDCmd() *cobra.Command {
|
||||||
serverCtx := GetServerContextFromCmd(cmd)
|
serverCtx := GetServerContextFromCmd(cmd)
|
||||||
cfg := serverCtx.Config
|
cfg := serverCtx.Config
|
||||||
|
|
||||||
nodeKey, err := p2p.LoadNodeKey(cfg.NodeKeyFile())
|
nodeKey, err := cfg.LoadNodeKeyID()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
fmt.Println(nodeKey.ID())
|
fmt.Println(nodeKey)
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -45,8 +44,11 @@ func ShowValidatorCmd() *cobra.Command {
|
||||||
serverCtx := GetServerContextFromCmd(cmd)
|
serverCtx := GetServerContextFromCmd(cmd)
|
||||||
cfg := serverCtx.Config
|
cfg := serverCtx.Config
|
||||||
|
|
||||||
privValidator := pvm.LoadFilePV(cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
|
privValidator, err := pvm.LoadFilePV(cfg.PrivValidator.KeyFile(), cfg.PrivValidator.StateFile())
|
||||||
pk, err := privValidator.GetPubKey()
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
pk, err := privValidator.GetPubKey(cmd.Context())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -76,7 +78,10 @@ func ShowAddressCmd() *cobra.Command {
|
||||||
serverCtx := GetServerContextFromCmd(cmd)
|
serverCtx := GetServerContextFromCmd(cmd)
|
||||||
cfg := serverCtx.Config
|
cfg := serverCtx.Config
|
||||||
|
|
||||||
privValidator := pvm.LoadFilePV(cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
|
privValidator, err := pvm.LoadFilePV(cfg.PrivValidator.Key, cfg.PrivValidator.State)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
valConsAddr := (sdk.ConsAddress)(privValidator.GetAddress())
|
valConsAddr := (sdk.ConsAddress)(privValidator.GetAddress())
|
||||||
fmt.Println(valConsAddr.String())
|
fmt.Println(valConsAddr.String())
|
||||||
return nil
|
return nil
|
||||||
|
@ -101,7 +106,7 @@ against which this app has been compiled.
|
||||||
BlockProtocol uint64
|
BlockProtocol uint64
|
||||||
P2PProtocol uint64
|
P2PProtocol uint64
|
||||||
}{
|
}{
|
||||||
Tendermint: tversion.TMCoreSemVer,
|
Tendermint: tversion.TMVersion,
|
||||||
ABCI: tversion.ABCIVersion,
|
ABCI: tversion.ABCIVersion,
|
||||||
BlockProtocol: tversion.BlockProtocol,
|
BlockProtocol: tversion.BlockProtocol,
|
||||||
P2PProtocol: tversion.P2PProtocol,
|
P2PProtocol: tversion.P2PProtocol,
|
||||||
|
@ -125,7 +130,7 @@ func UnsafeResetAllCmd() *cobra.Command {
|
||||||
serverCtx := GetServerContextFromCmd(cmd)
|
serverCtx := GetServerContextFromCmd(cmd)
|
||||||
cfg := serverCtx.Config
|
cfg := serverCtx.Config
|
||||||
|
|
||||||
tcmd.ResetAll(cfg.DBDir(), cfg.P2P.AddrBookFile(), cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile(), serverCtx.Logger)
|
tcmd.ResetAll(cfg.DBDir(), cfg.P2P.AddrBookFile(), cfg.PrivValidator.Key, cfg.PrivValidator.State, serverCtx.Logger)
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,7 @@ import (
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
"github.com/tendermint/tendermint/libs/log"
|
"github.com/tendermint/tendermint/libs/log"
|
||||||
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
tmtypes "github.com/tendermint/tendermint/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
dbm "github.com/tendermint/tm-db"
|
dbm "github.com/tendermint/tm-db"
|
||||||
|
|
||||||
|
@ -70,7 +71,7 @@ type (
|
||||||
// Height is the app's latest block height.
|
// Height is the app's latest block height.
|
||||||
Height int64
|
Height int64
|
||||||
// ConsensusParams are the exported consensus params for ABCI.
|
// ConsensusParams are the exported consensus params for ABCI.
|
||||||
ConsensusParams *abci.ConsensusParams
|
ConsensusParams *tmproto.ConsensusParams
|
||||||
}
|
}
|
||||||
|
|
||||||
// AppExporter is a function that dumps all app state to
|
// AppExporter is a function that dumps all app state to
|
||||||
|
|
|
@ -138,7 +138,7 @@ func InterceptConfigsPreRunHandler(cmd *cobra.Command, customAppConfigTemplate s
|
||||||
}
|
}
|
||||||
|
|
||||||
var logWriter io.Writer
|
var logWriter io.Writer
|
||||||
if strings.ToLower(serverCtx.Viper.GetString(flags.FlagLogFormat)) == tmcfg.LogFormatPlain {
|
if strings.ToLower(serverCtx.Viper.GetString(flags.FlagLogFormat)) == tmlog.LogFormatPlain {
|
||||||
logWriter = zerolog.ConsoleWriter{Out: os.Stderr}
|
logWriter = zerolog.ConsoleWriter{Out: os.Stderr}
|
||||||
} else {
|
} else {
|
||||||
logWriter = os.Stderr
|
logWriter = os.Stderr
|
||||||
|
@ -203,7 +203,7 @@ func interceptConfigs(rootViper *viper.Viper, customAppTemplate string, customCo
|
||||||
conf.P2P.RecvRate = 5120000
|
conf.P2P.RecvRate = 5120000
|
||||||
conf.P2P.SendRate = 5120000
|
conf.P2P.SendRate = 5120000
|
||||||
conf.Consensus.TimeoutCommit = 5 * time.Second
|
conf.Consensus.TimeoutCommit = 5 * time.Second
|
||||||
tmcfg.WriteConfigFile(tmCfgFile, conf)
|
tmcfg.WriteConfigFile(rootDir, conf)
|
||||||
|
|
||||||
case err != nil:
|
case err != nil:
|
||||||
return nil, err
|
return nil, err
|
||||||
|
|
|
@ -104,7 +104,7 @@ func TestInterceptConfigsPreRunHandlerReadsConfigToml(t *testing.T) {
|
||||||
t.Fatalf("creating config.toml file failed: %v", err)
|
t.Fatalf("creating config.toml file failed: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err = writer.WriteString(fmt.Sprintf("db_backend = '%s'\n", testDbBackend))
|
_, err = writer.WriteString(fmt.Sprintf("db-backend = '%s'\n", testDbBackend))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Failed writing string to config.toml: %v", err)
|
t.Fatalf("Failed writing string to config.toml: %v", err)
|
||||||
}
|
}
|
||||||
|
@ -128,7 +128,7 @@ func TestInterceptConfigsPreRunHandlerReadsConfigToml(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if testDbBackend != serverCtx.Config.DBBackend {
|
if testDbBackend != serverCtx.Config.DBBackend {
|
||||||
t.Error("DBPath was not set from config.toml")
|
t.Error("backend was not set from config.toml")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,6 @@ package simapp
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"os"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/golang/mock/gomock"
|
"github.com/golang/mock/gomock"
|
||||||
|
@ -39,8 +38,9 @@ import (
|
||||||
func TestSimAppExportAndBlockedAddrs(t *testing.T) {
|
func TestSimAppExportAndBlockedAddrs(t *testing.T) {
|
||||||
encCfg := MakeTestEncodingConfig()
|
encCfg := MakeTestEncodingConfig()
|
||||||
db := dbm.NewMemDB()
|
db := dbm.NewMemDB()
|
||||||
|
logger, _ := log.NewDefaultLogger("plain", "info", false)
|
||||||
app := NewSimappWithCustomOptions(t, false, SetupOptions{
|
app := NewSimappWithCustomOptions(t, false, SetupOptions{
|
||||||
Logger: log.NewTMLogger(log.NewSyncWriter(os.Stdout)),
|
Logger: logger,
|
||||||
DB: db,
|
DB: db,
|
||||||
InvCheckPeriod: 0,
|
InvCheckPeriod: 0,
|
||||||
EncConfig: encCfg,
|
EncConfig: encCfg,
|
||||||
|
@ -59,8 +59,9 @@ func TestSimAppExportAndBlockedAddrs(t *testing.T) {
|
||||||
|
|
||||||
app.Commit()
|
app.Commit()
|
||||||
|
|
||||||
|
logger2, _ := log.NewDefaultLogger("plain", "info", false)
|
||||||
// Making a new app object with the db, so that initchain hasn't been called
|
// Making a new app object with the db, so that initchain hasn't been called
|
||||||
app2 := NewSimApp(log.NewTMLogger(log.NewSyncWriter(os.Stdout)), db, nil, true, map[int64]bool{}, DefaultNodeHome, 0, encCfg, EmptyAppOptions{})
|
app2 := NewSimApp(logger2, db, nil, true, map[int64]bool{}, DefaultNodeHome, 0, encCfg, EmptyAppOptions{})
|
||||||
_, err := app2.ExportAppStateAndValidators(false, []string{})
|
_, err := app2.ExportAppStateAndValidators(false, []string{})
|
||||||
require.NoError(t, err, "ExportAppStateAndValidators should not have an error")
|
require.NoError(t, err, "ExportAppStateAndValidators should not have an error")
|
||||||
}
|
}
|
||||||
|
@ -73,7 +74,7 @@ func TestGetMaccPerms(t *testing.T) {
|
||||||
func TestRunMigrations(t *testing.T) {
|
func TestRunMigrations(t *testing.T) {
|
||||||
db := dbm.NewMemDB()
|
db := dbm.NewMemDB()
|
||||||
encCfg := MakeTestEncodingConfig()
|
encCfg := MakeTestEncodingConfig()
|
||||||
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
logger, _ := log.NewDefaultLogger("plain", "info", false)
|
||||||
app := NewSimApp(logger, db, nil, true, map[int64]bool{}, DefaultNodeHome, 0, encCfg, EmptyAppOptions{})
|
app := NewSimApp(logger, db, nil, true, map[int64]bool{}, DefaultNodeHome, 0, encCfg, EmptyAppOptions{})
|
||||||
|
|
||||||
// Create a new baseapp and configurator for the purpose of this test.
|
// Create a new baseapp and configurator for the purpose of this test.
|
||||||
|
@ -202,7 +203,7 @@ func TestRunMigrations(t *testing.T) {
|
||||||
func TestInitGenesisOnMigration(t *testing.T) {
|
func TestInitGenesisOnMigration(t *testing.T) {
|
||||||
db := dbm.NewMemDB()
|
db := dbm.NewMemDB()
|
||||||
encCfg := MakeTestEncodingConfig()
|
encCfg := MakeTestEncodingConfig()
|
||||||
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
logger, _ := log.NewDefaultLogger("plain", "info", false)
|
||||||
app := NewSimApp(logger, db, nil, true, map[int64]bool{}, DefaultNodeHome, 0, encCfg, EmptyAppOptions{})
|
app := NewSimApp(logger, db, nil, true, map[int64]bool{}, DefaultNodeHome, 0, encCfg, EmptyAppOptions{})
|
||||||
ctx := app.NewContext(true, tmproto.Header{Height: app.LastBlockHeight()})
|
ctx := app.NewContext(true, tmproto.Header{Height: app.LastBlockHeight()})
|
||||||
|
|
||||||
|
@ -246,8 +247,9 @@ func TestInitGenesisOnMigration(t *testing.T) {
|
||||||
func TestUpgradeStateOnGenesis(t *testing.T) {
|
func TestUpgradeStateOnGenesis(t *testing.T) {
|
||||||
encCfg := MakeTestEncodingConfig()
|
encCfg := MakeTestEncodingConfig()
|
||||||
db := dbm.NewMemDB()
|
db := dbm.NewMemDB()
|
||||||
|
logger, _ := log.NewDefaultLogger("plain", "info", false)
|
||||||
app := NewSimappWithCustomOptions(t, false, SetupOptions{
|
app := NewSimappWithCustomOptions(t, false, SetupOptions{
|
||||||
Logger: log.NewTMLogger(log.NewSyncWriter(os.Stdout)),
|
Logger: logger,
|
||||||
DB: db,
|
DB: db,
|
||||||
InvCheckPeriod: 0,
|
InvCheckPeriod: 0,
|
||||||
EncConfig: encCfg,
|
EncConfig: encCfg,
|
||||||
|
|
|
@ -6,6 +6,7 @@ import (
|
||||||
"bufio"
|
"bufio"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
"net"
|
"net"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
@ -14,8 +15,8 @@ import (
|
||||||
tmconfig "github.com/tendermint/tendermint/config"
|
tmconfig "github.com/tendermint/tendermint/config"
|
||||||
tmos "github.com/tendermint/tendermint/libs/os"
|
tmos "github.com/tendermint/tendermint/libs/os"
|
||||||
tmrand "github.com/tendermint/tendermint/libs/rand"
|
tmrand "github.com/tendermint/tendermint/libs/rand"
|
||||||
|
tmtime "github.com/tendermint/tendermint/libs/time"
|
||||||
"github.com/tendermint/tendermint/types"
|
"github.com/tendermint/tendermint/types"
|
||||||
tmtime "github.com/tendermint/tendermint/types/time"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
"github.com/cosmos/cosmos-sdk/client/flags"
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
||||||
|
@ -199,11 +200,9 @@ func initTestnetFiles(
|
||||||
genBalIterator banktypes.GenesisBalancesIterator,
|
genBalIterator banktypes.GenesisBalancesIterator,
|
||||||
args initArgs,
|
args initArgs,
|
||||||
) error {
|
) error {
|
||||||
|
|
||||||
if args.chainID == "" {
|
if args.chainID == "" {
|
||||||
args.chainID = "chain-" + tmrand.NewRand().Str(6)
|
args.chainID = "chain-" + tmrand.Str(6)
|
||||||
}
|
}
|
||||||
|
|
||||||
nodeIDs := make([]string, args.numValidators)
|
nodeIDs := make([]string, args.numValidators)
|
||||||
valPubKeys := make([]cryptotypes.PubKey, args.numValidators)
|
valPubKeys := make([]cryptotypes.PubKey, args.numValidators)
|
||||||
|
|
||||||
|
@ -229,15 +228,15 @@ func initTestnetFiles(
|
||||||
gentxsDir := filepath.Join(args.outputDir, "gentxs")
|
gentxsDir := filepath.Join(args.outputDir, "gentxs")
|
||||||
|
|
||||||
nodeConfig.SetRoot(nodeDir)
|
nodeConfig.SetRoot(nodeDir)
|
||||||
|
nodeConfig.Moniker = nodeDirName
|
||||||
nodeConfig.RPC.ListenAddress = "tcp://0.0.0.0:26657"
|
nodeConfig.RPC.ListenAddress = "tcp://0.0.0.0:26657"
|
||||||
|
nodeConfig.Mode = tmconfig.ModeValidator
|
||||||
|
|
||||||
if err := os.MkdirAll(filepath.Join(nodeDir, "config"), nodeDirPerm); err != nil {
|
if err := os.MkdirAll(filepath.Join(nodeDir, "config"), nodeDirPerm); err != nil {
|
||||||
_ = os.RemoveAll(args.outputDir)
|
_ = os.RemoveAll(args.outputDir)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
nodeConfig.Moniker = nodeDirName
|
|
||||||
|
|
||||||
ip, err := getIP(i, args.startingIPAddress)
|
ip, err := getIP(i, args.startingIPAddress)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
_ = os.RemoveAll(args.outputDir)
|
_ = os.RemoveAll(args.outputDir)
|
||||||
|
@ -332,7 +331,7 @@ func initTestnetFiles(
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
srvconfig.WriteConfigFile(filepath.Join(nodeDir, "config/app.toml"), simappConfig)
|
srvconfig.WriteConfigFile(filepath.Join(nodeDir, "config", "app.toml"), simappConfig)
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := initGenFiles(clientCtx, mbm, args.chainID, genAccounts, genBalances, genFiles, args.numValidators); err != nil {
|
if err := initGenFiles(clientCtx, mbm, args.chainID, genAccounts, genBalances, genFiles, args.numValidators); err != nil {
|
||||||
|
@ -480,7 +479,7 @@ func writeFile(name string, dir string, contents []byte) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = tmos.WriteFile(file, contents, 0644)
|
err = ioutil.WriteFile(file, contents, 0644) // nolint: gosec
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package simapp
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"context"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
@ -38,8 +39,8 @@ import (
|
||||||
|
|
||||||
// DefaultConsensusParams defines the default Tendermint consensus params used in
|
// DefaultConsensusParams defines the default Tendermint consensus params used in
|
||||||
// SimApp testing.
|
// SimApp testing.
|
||||||
var DefaultConsensusParams = &abci.ConsensusParams{
|
var DefaultConsensusParams = &tmproto.ConsensusParams{
|
||||||
Block: &abci.BlockParams{
|
Block: &tmproto.BlockParams{
|
||||||
MaxBytes: 200000,
|
MaxBytes: 200000,
|
||||||
MaxGas: 2000000,
|
MaxGas: 2000000,
|
||||||
},
|
},
|
||||||
|
@ -81,7 +82,7 @@ func NewSimappWithCustomOptions(t *testing.T, isCheckTx bool, options SetupOptio
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
privVal := mock.NewPV()
|
privVal := mock.NewPV()
|
||||||
pubKey, err := privVal.GetPubKey()
|
pubKey, err := privVal.GetPubKey(context.TODO())
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
// create validator set with single validator
|
// create validator set with single validator
|
||||||
validator := tmtypes.NewValidator(pubKey, 1)
|
validator := tmtypes.NewValidator(pubKey, 1)
|
||||||
|
@ -122,7 +123,7 @@ func Setup(t *testing.T, isCheckTx bool) *SimApp {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
privVal := mock.NewPV()
|
privVal := mock.NewPV()
|
||||||
pubKey, err := privVal.GetPubKey()
|
pubKey, err := privVal.GetPubKey(context.TODO())
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// create validator set with single validator
|
// create validator set with single validator
|
||||||
|
@ -245,7 +246,7 @@ func SetupWithGenesisAccounts(t *testing.T, genAccs []authtypes.GenesisAccount,
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
privVal := mock.NewPV()
|
privVal := mock.NewPV()
|
||||||
pubKey, err := privVal.GetPubKey()
|
pubKey, err := privVal.GetPubKey(context.TODO())
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// create validator set with single validator
|
// create validator set with single validator
|
||||||
|
@ -261,7 +262,7 @@ func GenesisStateWithSingleValidator(t *testing.T, app *SimApp) GenesisState {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
privVal := mock.NewPV()
|
privVal := mock.NewPV()
|
||||||
pubKey, err := privVal.GetPubKey()
|
pubKey, err := privVal.GetPubKey(context.TODO())
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// create validator set with single validator
|
// create validator set with single validator
|
||||||
|
|
|
@ -70,7 +70,7 @@ func GetKey(allkeys []string, loc Where) string {
|
||||||
return allkeys[len(allkeys)-1]
|
return allkeys[len(allkeys)-1]
|
||||||
}
|
}
|
||||||
// select a random index between 1 and allkeys-2
|
// select a random index between 1 and allkeys-2
|
||||||
idx := rand.Int()%(len(allkeys)-2) + 1
|
idx := rand.NewRand().Int()%(len(allkeys)-2) + 1
|
||||||
return allkeys[idx]
|
return allkeys[idx]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ var (
|
||||||
}
|
}
|
||||||
testEndBlockRes = abci.ResponseEndBlock{
|
testEndBlockRes = abci.ResponseEndBlock{
|
||||||
Events: []abci.Event{},
|
Events: []abci.Event{},
|
||||||
ConsensusParamUpdates: &abci.ConsensusParams{},
|
ConsensusParamUpdates: &types1.ConsensusParams{},
|
||||||
ValidatorUpdates: []abci.ValidatorUpdate{},
|
ValidatorUpdates: []abci.ValidatorUpdate{},
|
||||||
}
|
}
|
||||||
mockTxBytes1 = []byte{9, 8, 7, 6, 5, 4, 3, 2, 1}
|
mockTxBytes1 = []byte{9, 8, 7, 6, 5, 4, 3, 2, 1}
|
||||||
|
|
|
@ -102,7 +102,7 @@ func NewStore(db dbm.DBConnection, opts StoreConfig) (ret *Store, err error) {
|
||||||
}
|
}
|
||||||
// Version sets of each DB must match
|
// Version sets of each DB must match
|
||||||
if !versions.Equal(mversions) {
|
if !versions.Equal(mversions) {
|
||||||
err = fmt.Errorf("Storage and Merkle DB have different version history") //nolint:stylecheck
|
err = fmt.Errorf("storage and Merkle DB have different version history")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
err = opts.MerkleDB.Revert()
|
err = opts.MerkleDB.Revert()
|
||||||
|
@ -424,12 +424,12 @@ func (s *Store) Query(req abci.RequestQuery) (res abci.ResponseQuery) {
|
||||||
return sdkerrors.QueryResult(err, false)
|
return sdkerrors.QueryResult(err, false)
|
||||||
}
|
}
|
||||||
if root == nil {
|
if root == nil {
|
||||||
return sdkerrors.QueryResult(errors.New("Merkle root hash not found"), false) //nolint:stylecheck
|
return sdkerrors.QueryResult(errors.New("Merkle root hash not found"), false) //nolint: stylecheck // proper name
|
||||||
}
|
}
|
||||||
merkleStore := loadSMT(dbm.ReaderAsReadWriter(merkleView), root)
|
merkleStore := loadSMT(dbm.ReaderAsReadWriter(merkleView), root)
|
||||||
res.ProofOps, err = merkleStore.GetProof(res.Key)
|
res.ProofOps, err = merkleStore.GetProof(res.Key)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return sdkerrors.QueryResult(fmt.Errorf("Merkle proof creation failed for key: %v", res.Key), false) //nolint:stylecheck
|
return sdkerrors.QueryResult(fmt.Errorf("Merkle proof creation failed for key: %v", res.Key), false) //nolint: stylecheck // proper name
|
||||||
}
|
}
|
||||||
|
|
||||||
case "/subspace":
|
case "/subspace":
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
package mock
|
package mock
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
"github.com/tendermint/tendermint/crypto"
|
"github.com/tendermint/tendermint/crypto"
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
tmtypes "github.com/tendermint/tendermint/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
|
@ -23,12 +25,12 @@ func NewPV() PV {
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetPubKey implements PrivValidator interface
|
// GetPubKey implements PrivValidator interface
|
||||||
func (pv PV) GetPubKey() (crypto.PubKey, error) {
|
func (pv PV) GetPubKey(_ context.Context) (crypto.PubKey, error) {
|
||||||
return cryptocodec.ToTmPubKeyInterface(pv.PrivKey.PubKey())
|
return cryptocodec.ToTmPubKeyInterface(pv.PrivKey.PubKey())
|
||||||
}
|
}
|
||||||
|
|
||||||
// SignVote implements PrivValidator interface
|
// SignVote implements PrivValidator interface
|
||||||
func (pv PV) SignVote(chainID string, vote *tmproto.Vote) error {
|
func (pv PV) SignVote(_ context.Context, chainID string, vote *tmproto.Vote) error {
|
||||||
signBytes := tmtypes.VoteSignBytes(chainID, vote)
|
signBytes := tmtypes.VoteSignBytes(chainID, vote)
|
||||||
sig, err := pv.PrivKey.Sign(signBytes)
|
sig, err := pv.PrivKey.Sign(signBytes)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -39,7 +41,7 @@ func (pv PV) SignVote(chainID string, vote *tmproto.Vote) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// SignProposal implements PrivValidator interface
|
// SignProposal implements PrivValidator interface
|
||||||
func (pv PV) SignProposal(chainID string, proposal *tmproto.Proposal) error {
|
func (pv PV) SignProposal(_ context.Context, chainID string, proposal *tmproto.Proposal) error {
|
||||||
signBytes := tmtypes.ProposalSignBytes(chainID, proposal)
|
signBytes := tmtypes.ProposalSignBytes(chainID, proposal)
|
||||||
sig, err := pv.PrivKey.Sign(signBytes)
|
sig, err := pv.PrivKey.Sign(signBytes)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -15,12 +15,11 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/rs/zerolog"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
tmcfg "github.com/tendermint/tendermint/config"
|
"github.com/tendermint/tendermint/config"
|
||||||
tmflags "github.com/tendermint/tendermint/libs/cli/flags"
|
|
||||||
"github.com/tendermint/tendermint/libs/log"
|
|
||||||
tmrand "github.com/tendermint/tendermint/libs/rand"
|
tmrand "github.com/tendermint/tendermint/libs/rand"
|
||||||
"github.com/tendermint/tendermint/node"
|
"github.com/tendermint/tendermint/libs/service"
|
||||||
tmclient "github.com/tendermint/tendermint/rpc/client"
|
tmclient "github.com/tendermint/tendermint/rpc/client"
|
||||||
dbm "github.com/tendermint/tm-db"
|
dbm "github.com/tendermint/tm-db"
|
||||||
"google.golang.org/grpc"
|
"google.golang.org/grpc"
|
||||||
|
@ -111,7 +110,7 @@ func DefaultConfig() Config {
|
||||||
AppConstructor: NewAppConstructor(encCfg),
|
AppConstructor: NewAppConstructor(encCfg),
|
||||||
GenesisState: simapp.ModuleBasics.DefaultGenesis(encCfg.Codec),
|
GenesisState: simapp.ModuleBasics.DefaultGenesis(encCfg.Codec),
|
||||||
TimeoutCommit: 2 * time.Second,
|
TimeoutCommit: 2 * time.Second,
|
||||||
ChainID: "chain-" + tmrand.NewRand().Str(6),
|
ChainID: "chain-" + tmrand.Str(6),
|
||||||
NumValidators: 4,
|
NumValidators: 4,
|
||||||
BondDenom: sdk.DefaultBondDenom,
|
BondDenom: sdk.DefaultBondDenom,
|
||||||
MinGasPrices: fmt.Sprintf("0.000006%s", sdk.DefaultBondDenom),
|
MinGasPrices: fmt.Sprintf("0.000006%s", sdk.DefaultBondDenom),
|
||||||
|
@ -163,7 +162,7 @@ type (
|
||||||
ValAddress sdk.ValAddress
|
ValAddress sdk.ValAddress
|
||||||
RPCClient tmclient.Client
|
RPCClient tmclient.Client
|
||||||
|
|
||||||
tmNode *node.Node
|
tmNode service.Service
|
||||||
api *api.Server
|
api *api.Server
|
||||||
grpc *grpc.Server
|
grpc *grpc.Server
|
||||||
grpcWeb *http.Server
|
grpcWeb *http.Server
|
||||||
|
@ -235,6 +234,7 @@ func New(l Logger, baseDir string, cfg Config) (*Network, error) {
|
||||||
ctx := server.NewDefaultContext()
|
ctx := server.NewDefaultContext()
|
||||||
tmCfg := ctx.Config
|
tmCfg := ctx.Config
|
||||||
tmCfg.Consensus.TimeoutCommit = cfg.TimeoutCommit
|
tmCfg.Consensus.TimeoutCommit = cfg.TimeoutCommit
|
||||||
|
tmCfg.Mode = config.ModeValidator
|
||||||
|
|
||||||
// Only allow the first validator to expose an RPC, API and gRPC
|
// Only allow the first validator to expose an RPC, API and gRPC
|
||||||
// server/client due to Tendermint in-process constraints.
|
// server/client due to Tendermint in-process constraints.
|
||||||
|
@ -290,10 +290,10 @@ func New(l Logger, baseDir string, cfg Config) (*Network, error) {
|
||||||
appCfg.GRPCWeb.Enable = true
|
appCfg.GRPCWeb.Enable = true
|
||||||
}
|
}
|
||||||
|
|
||||||
logger := log.NewNopLogger()
|
logger := server.ZeroLogWrapper{Logger: zerolog.Nop()}
|
||||||
if cfg.EnableTMLogging {
|
if cfg.EnableTMLogging {
|
||||||
logger = log.NewTMLogger(log.NewSyncWriter(os.Stdout))
|
logWriter := zerolog.ConsoleWriter{Out: os.Stderr}
|
||||||
logger, _ = tmflags.ParseLogLevel("info", logger, tmcfg.DefaultLogLevel)
|
logger = server.ZeroLogWrapper{Logger: zerolog.New(logWriter).Level(zerolog.InfoLevel).With().Timestamp().Logger()}
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.Logger = logger
|
ctx.Logger = logger
|
||||||
|
@ -434,8 +434,7 @@ func New(l Logger, baseDir string, cfg Config) (*Network, error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
srvconfig.WriteConfigFile(filepath.Join(nodeDir, "config", "app.toml"), appCfg)
|
||||||
srvconfig.WriteConfigFile(filepath.Join(nodeDir, "config/app.toml"), appCfg)
|
|
||||||
|
|
||||||
clientCtx := client.Context{}.
|
clientCtx := client.Context{}.
|
||||||
WithKeyringDir(clientDir).
|
WithKeyringDir(clientDir).
|
||||||
|
@ -474,14 +473,20 @@ func New(l Logger, baseDir string, cfg Config) (*Network, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
l.Log("starting test network...")
|
l.Log("starting test network...")
|
||||||
for _, v := range network.Validators {
|
for idx, v := range network.Validators {
|
||||||
err := startInProcess(cfg, v)
|
err := startInProcess(cfg, v)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
l.Log("started validator", idx)
|
||||||
}
|
}
|
||||||
|
|
||||||
l.Log("started test network")
|
height, err := network.LatestHeight()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
l.Log("started test network at height:", height)
|
||||||
|
|
||||||
// Ensure we cleanup incase any test was abruptly halted (e.g. SIGINT) as any
|
// Ensure we cleanup incase any test was abruptly halted (e.g. SIGINT) as any
|
||||||
// defer in a test would not be called.
|
// defer in a test would not be called.
|
||||||
|
@ -516,7 +521,10 @@ func (n *Network) WaitForHeight(h int64) (int64, error) {
|
||||||
// provide a custom timeout.
|
// provide a custom timeout.
|
||||||
func (n *Network) WaitForHeightWithTimeout(h int64, t time.Duration) (int64, error) {
|
func (n *Network) WaitForHeightWithTimeout(h int64, t time.Duration) (int64, error) {
|
||||||
ticker := time.NewTicker(time.Second)
|
ticker := time.NewTicker(time.Second)
|
||||||
timeout := time.After(t)
|
defer ticker.Stop()
|
||||||
|
|
||||||
|
timeout := time.NewTimer(t)
|
||||||
|
defer timeout.Stop()
|
||||||
|
|
||||||
if len(n.Validators) == 0 {
|
if len(n.Validators) == 0 {
|
||||||
return 0, errors.New("no validators available")
|
return 0, errors.New("no validators available")
|
||||||
|
@ -527,8 +535,7 @@ func (n *Network) WaitForHeightWithTimeout(h int64, t time.Duration) (int64, err
|
||||||
|
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case <-timeout:
|
case <-timeout.C:
|
||||||
ticker.Stop()
|
|
||||||
return latestHeight, errors.New("timeout exceeded waiting for block")
|
return latestHeight, errors.New("timeout exceeded waiting for block")
|
||||||
case <-ticker.C:
|
case <-ticker.C:
|
||||||
status, err := val.RPCClient.Status(context.Background())
|
status, err := val.RPCClient.Status(context.Background())
|
||||||
|
|
|
@ -24,8 +24,8 @@ func (s *IntegrationTestSuite) SetupSuite() {
|
||||||
s.network, err = network.New(s.T(), s.T().TempDir(), network.DefaultConfig())
|
s.network, err = network.New(s.T(), s.T().TempDir(), network.DefaultConfig())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
_, err = s.network.WaitForHeight(1)
|
h, err := s.network.WaitForHeight(1)
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err, "stalled at height %d", h)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *IntegrationTestSuite) TearDownSuite() {
|
func (s *IntegrationTestSuite) TearDownSuite() {
|
||||||
|
|
|
@ -2,17 +2,16 @@ package network
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"io/ioutil"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
abciclient "github.com/tendermint/tendermint/abci/client"
|
||||||
tmos "github.com/tendermint/tendermint/libs/os"
|
tmos "github.com/tendermint/tendermint/libs/os"
|
||||||
|
tmtime "github.com/tendermint/tendermint/libs/time"
|
||||||
"github.com/tendermint/tendermint/node"
|
"github.com/tendermint/tendermint/node"
|
||||||
"github.com/tendermint/tendermint/p2p"
|
|
||||||
pvm "github.com/tendermint/tendermint/privval"
|
|
||||||
"github.com/tendermint/tendermint/proxy"
|
|
||||||
"github.com/tendermint/tendermint/rpc/client/local"
|
"github.com/tendermint/tendermint/rpc/client/local"
|
||||||
"github.com/tendermint/tendermint/types"
|
"github.com/tendermint/tendermint/types"
|
||||||
tmtime "github.com/tendermint/tendermint/types/time"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/server/api"
|
"github.com/cosmos/cosmos-sdk/server/api"
|
||||||
servergrpc "github.com/cosmos/cosmos-sdk/server/grpc"
|
servergrpc "github.com/cosmos/cosmos-sdk/server/grpc"
|
||||||
|
@ -32,36 +31,36 @@ func startInProcess(cfg Config, val *Validator) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
nodeKey, err := p2p.LoadOrGenNodeKey(tmCfg.NodeKeyFile())
|
app := cfg.AppConstructor(*val)
|
||||||
|
|
||||||
|
genDoc, err := types.GenesisDocFromFile(tmCfg.GenesisFile())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
app := cfg.AppConstructor(*val)
|
val.tmNode, err = node.New(
|
||||||
|
|
||||||
genDocProvider := node.DefaultGenesisDocProviderFunc(tmCfg)
|
|
||||||
tmNode, err := node.NewNode(
|
|
||||||
tmCfg,
|
tmCfg,
|
||||||
pvm.LoadOrGenFilePV(tmCfg.PrivValidatorKeyFile(), tmCfg.PrivValidatorStateFile()),
|
|
||||||
nodeKey,
|
|
||||||
proxy.NewLocalClientCreator(app),
|
|
||||||
genDocProvider,
|
|
||||||
node.DefaultDBProvider,
|
|
||||||
node.DefaultMetricsProvider(tmCfg.Instrumentation),
|
|
||||||
logger.With("module", val.Moniker),
|
logger.With("module", val.Moniker),
|
||||||
|
abciclient.NewLocalCreator(app),
|
||||||
|
genDoc,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := tmNode.Start(); err != nil {
|
if err := val.tmNode.Start(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
val.tmNode = tmNode
|
|
||||||
|
|
||||||
if val.RPCAddress != "" {
|
if val.RPCAddress != "" {
|
||||||
val.RPCClient = local.New(tmNode)
|
node, ok := val.tmNode.(local.NodeService)
|
||||||
|
if !ok {
|
||||||
|
panic("can't cast service.Service to NodeService")
|
||||||
|
}
|
||||||
|
val.RPCClient, err = local.New(node)
|
||||||
|
if err != nil {
|
||||||
|
panic("cant create a local node")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// We'll need a RPC client if the validator exposes a gRPC or REST endpoint.
|
// We'll need a RPC client if the validator exposes a gRPC or REST endpoint.
|
||||||
|
@ -112,7 +111,6 @@ func startInProcess(cfg Config, val *Validator) error {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,7 +200,7 @@ func writeFile(name string, dir string, contents []byte) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = tmos.WriteFile(file, contents, 0644)
|
err = ioutil.WriteFile(file, contents, 0644) // nolint: gosec
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,12 +4,7 @@ package tendermint.p2p;
|
||||||
option go_package = "github.com/tendermint/tendermint/proto/tendermint/p2p";
|
option go_package = "github.com/tendermint/tendermint/proto/tendermint/p2p";
|
||||||
|
|
||||||
import "gogoproto/gogo.proto";
|
import "gogoproto/gogo.proto";
|
||||||
|
import "google/protobuf/timestamp.proto";
|
||||||
message NetAddress {
|
|
||||||
string id = 1 [(gogoproto.customname) = "ID"];
|
|
||||||
string ip = 2 [(gogoproto.customname) = "IP"];
|
|
||||||
uint32 port = 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
message ProtocolVersion {
|
message ProtocolVersion {
|
||||||
uint64 p2p = 1 [(gogoproto.customname) = "P2P"];
|
uint64 p2p = 1 [(gogoproto.customname) = "P2P"];
|
||||||
|
@ -17,18 +12,31 @@ message ProtocolVersion {
|
||||||
uint64 app = 3;
|
uint64 app = 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
message DefaultNodeInfo {
|
message NodeInfo {
|
||||||
ProtocolVersion protocol_version = 1 [(gogoproto.nullable) = false];
|
ProtocolVersion protocol_version = 1 [(gogoproto.nullable) = false];
|
||||||
string default_node_id = 2 [(gogoproto.customname) = "DefaultNodeID"];
|
string node_id = 2 [(gogoproto.customname) = "NodeID"];
|
||||||
string listen_addr = 3;
|
string listen_addr = 3;
|
||||||
string network = 4;
|
string network = 4;
|
||||||
string version = 5;
|
string version = 5;
|
||||||
bytes channels = 6;
|
bytes channels = 6;
|
||||||
string moniker = 7;
|
string moniker = 7;
|
||||||
DefaultNodeInfoOther other = 8 [(gogoproto.nullable) = false];
|
NodeInfoOther other = 8 [(gogoproto.nullable) = false];
|
||||||
}
|
}
|
||||||
|
|
||||||
message DefaultNodeInfoOther {
|
message NodeInfoOther {
|
||||||
string tx_index = 1;
|
string tx_index = 1;
|
||||||
string rpc_address = 2 [(gogoproto.customname) = "RPCAddress"];
|
string rpc_address = 2 [(gogoproto.customname) = "RPCAddress"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message PeerInfo {
|
||||||
|
string id = 1 [(gogoproto.customname) = "ID"];
|
||||||
|
repeated PeerAddressInfo address_info = 2;
|
||||||
|
google.protobuf.Timestamp last_connected = 3 [(gogoproto.stdtime) = true];
|
||||||
|
}
|
||||||
|
|
||||||
|
message PeerAddressInfo {
|
||||||
|
string address = 1;
|
||||||
|
google.protobuf.Timestamp last_dial_success = 2 [(gogoproto.stdtime) = true];
|
||||||
|
google.protobuf.Timestamp last_dial_failure = 3 [(gogoproto.stdtime) = true];
|
||||||
|
uint32 dial_failures = 4;
|
||||||
|
}
|
||||||
|
|
|
@ -36,7 +36,7 @@ type Context struct {
|
||||||
checkTx bool
|
checkTx bool
|
||||||
recheckTx bool // if recheckTx == true, then checkTx must also be true
|
recheckTx bool // if recheckTx == true, then checkTx must also be true
|
||||||
minGasPrice DecCoins
|
minGasPrice DecCoins
|
||||||
consParams *abci.ConsensusParams
|
consParams *tmproto.ConsensusParams
|
||||||
eventManager *EventManager
|
eventManager *EventManager
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,8 +72,8 @@ func (c Context) HeaderHash() tmbytes.HexBytes {
|
||||||
return hash
|
return hash
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c Context) ConsensusParams() *abci.ConsensusParams {
|
func (c Context) ConsensusParams() *tmproto.ConsensusParams {
|
||||||
return proto.Clone(c.consParams).(*abci.ConsensusParams)
|
return proto.Clone(c.consParams).(*tmproto.ConsensusParams)
|
||||||
}
|
}
|
||||||
|
|
||||||
// create a new context
|
// create a new context
|
||||||
|
@ -203,7 +203,7 @@ func (c Context) WithMinGasPrices(gasPrices DecCoins) Context {
|
||||||
}
|
}
|
||||||
|
|
||||||
// WithConsensusParams returns a Context with an updated consensus params
|
// WithConsensusParams returns a Context with an updated consensus params
|
||||||
func (c Context) WithConsensusParams(params *abci.ConsensusParams) Context {
|
func (c Context) WithConsensusParams(params *tmproto.ConsensusParams) Context {
|
||||||
c.consParams = params
|
c.consParams = params
|
||||||
return c
|
return c
|
||||||
}
|
}
|
||||||
|
|
|
@ -127,7 +127,7 @@ func (s *contextTestSuite) TestContextWithCustom() {
|
||||||
|
|
||||||
// test consensus param
|
// test consensus param
|
||||||
s.Require().Nil(ctx.ConsensusParams())
|
s.Require().Nil(ctx.ConsensusParams())
|
||||||
cp := &abci.ConsensusParams{}
|
cp := &tmproto.ConsensusParams{}
|
||||||
s.Require().Equal(cp, ctx.WithConsensusParams(cp).ConsensusParams())
|
s.Require().Equal(cp, ctx.WithConsensusParams(cp).ConsensusParams())
|
||||||
|
|
||||||
// test inner context
|
// test inner context
|
||||||
|
|
|
@ -90,8 +90,8 @@ func TypedEventToEvent(tev proto.Message) (Event, error) {
|
||||||
attrs := make([]abci.EventAttribute, 0, len(attrMap))
|
attrs := make([]abci.EventAttribute, 0, len(attrMap))
|
||||||
for k, v := range attrMap {
|
for k, v := range attrMap {
|
||||||
attrs = append(attrs, abci.EventAttribute{
|
attrs = append(attrs, abci.EventAttribute{
|
||||||
Key: []byte(k),
|
Key: k,
|
||||||
Value: v,
|
Value: string(v),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ func ParseTypedEvent(event abci.Event) (proto.Message, error) {
|
||||||
|
|
||||||
attrMap := make(map[string]json.RawMessage)
|
attrMap := make(map[string]json.RawMessage)
|
||||||
for _, attr := range event.Attributes {
|
for _, attr := range event.Attributes {
|
||||||
attrMap[string(attr.Key)] = attr.Value
|
attrMap[attr.Key] = json.RawMessage(attr.Value)
|
||||||
}
|
}
|
||||||
|
|
||||||
attrBytes, err := json.Marshal(attrMap)
|
attrBytes, err := json.Marshal(attrMap)
|
||||||
|
@ -178,7 +178,7 @@ func (a Attribute) String() string {
|
||||||
|
|
||||||
// ToKVPair converts an Attribute object into a Tendermint key/value pair.
|
// ToKVPair converts an Attribute object into a Tendermint key/value pair.
|
||||||
func (a Attribute) ToKVPair() abci.EventAttribute {
|
func (a Attribute) ToKVPair() abci.EventAttribute {
|
||||||
return abci.EventAttribute{Key: toBytes(a.Key), Value: toBytes(a.Value)}
|
return abci.EventAttribute{Key: a.Key, Value: a.Value}
|
||||||
}
|
}
|
||||||
|
|
||||||
// AppendAttributes adds one or more attributes to an Event.
|
// AppendAttributes adds one or more attributes to an Event.
|
||||||
|
@ -210,17 +210,6 @@ func (e Events) ToABCIEvents() []abci.Event {
|
||||||
return res
|
return res
|
||||||
}
|
}
|
||||||
|
|
||||||
func toBytes(i interface{}) []byte {
|
|
||||||
switch x := i.(type) {
|
|
||||||
case []uint8:
|
|
||||||
return x
|
|
||||||
case string:
|
|
||||||
return []byte(x)
|
|
||||||
default:
|
|
||||||
panic(i)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Common event types and attribute keys
|
// Common event types and attribute keys
|
||||||
var (
|
var (
|
||||||
EventTypeTx = "tx"
|
EventTypeTx = "tx"
|
||||||
|
@ -286,7 +275,7 @@ func StringifyEvent(e abci.Event) StringEvent {
|
||||||
for _, attr := range e.Attributes {
|
for _, attr := range e.Attributes {
|
||||||
res.Attributes = append(
|
res.Attributes = append(
|
||||||
res.Attributes,
|
res.Attributes,
|
||||||
Attribute{string(attr.Key), string(attr.Value)},
|
Attribute{Key: attr.Key, Value: attr.Value},
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -124,15 +124,15 @@ func (s *eventsTestSuite) TestMarkEventsToIndex() {
|
||||||
{
|
{
|
||||||
Type: "message",
|
Type: "message",
|
||||||
Attributes: []abci.EventAttribute{
|
Attributes: []abci.EventAttribute{
|
||||||
{Key: []byte("sender"), Value: []byte("foo")},
|
{Key: "sender", Value: "foo"},
|
||||||
{Key: []byte("recipient"), Value: []byte("bar")},
|
{Key: "recipient", Value: "bar"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
Type: "staking",
|
Type: "staking",
|
||||||
Attributes: []abci.EventAttribute{
|
Attributes: []abci.EventAttribute{
|
||||||
{Key: []byte("deposit"), Value: []byte("5")},
|
{Key: "deposit", Value: "5"},
|
||||||
{Key: []byte("unbond"), Value: []byte("10")},
|
{Key: "unbond", Value: "10"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -148,15 +148,15 @@ func (s *eventsTestSuite) TestMarkEventsToIndex() {
|
||||||
{
|
{
|
||||||
Type: "message",
|
Type: "message",
|
||||||
Attributes: []abci.EventAttribute{
|
Attributes: []abci.EventAttribute{
|
||||||
{Key: []byte("sender"), Value: []byte("foo"), Index: true},
|
{Key: "sender", Value: "foo", Index: true},
|
||||||
{Key: []byte("recipient"), Value: []byte("bar"), Index: true},
|
{Key: "recipient", Value: "bar", Index: true},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
Type: "staking",
|
Type: "staking",
|
||||||
Attributes: []abci.EventAttribute{
|
Attributes: []abci.EventAttribute{
|
||||||
{Key: []byte("deposit"), Value: []byte("5"), Index: true},
|
{Key: "deposit", Value: "5", Index: true},
|
||||||
{Key: []byte("unbond"), Value: []byte("10"), Index: true},
|
{Key: "unbond", Value: "10", Index: true},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -168,15 +168,15 @@ func (s *eventsTestSuite) TestMarkEventsToIndex() {
|
||||||
{
|
{
|
||||||
Type: "message",
|
Type: "message",
|
||||||
Attributes: []abci.EventAttribute{
|
Attributes: []abci.EventAttribute{
|
||||||
{Key: []byte("sender"), Value: []byte("foo"), Index: true},
|
{Key: "sender", Value: "foo", Index: true},
|
||||||
{Key: []byte("recipient"), Value: []byte("bar")},
|
{Key: "recipient", Value: "bar"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
Type: "staking",
|
Type: "staking",
|
||||||
Attributes: []abci.EventAttribute{
|
Attributes: []abci.EventAttribute{
|
||||||
{Key: []byte("deposit"), Value: []byte("5"), Index: true},
|
{Key: "deposit", Value: "5", Index: true},
|
||||||
{Key: []byte("unbond"), Value: []byte("10")},
|
{Key: "unbond", Value: "10"},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -191,15 +191,15 @@ func (s *eventsTestSuite) TestMarkEventsToIndex() {
|
||||||
{
|
{
|
||||||
Type: "message",
|
Type: "message",
|
||||||
Attributes: []abci.EventAttribute{
|
Attributes: []abci.EventAttribute{
|
||||||
{Key: []byte("sender"), Value: []byte("foo"), Index: true},
|
{Key: "sender", Value: "foo", Index: true},
|
||||||
{Key: []byte("recipient"), Value: []byte("bar"), Index: true},
|
{Key: "recipient", Value: "bar", Index: true},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
Type: "staking",
|
Type: "staking",
|
||||||
Attributes: []abci.EventAttribute{
|
Attributes: []abci.EventAttribute{
|
||||||
{Key: []byte("deposit"), Value: []byte("5"), Index: true},
|
{Key: "deposit", Value: "5", Index: true},
|
||||||
{Key: []byte("unbond"), Value: []byte("10"), Index: true},
|
{Key: "unbond", Value: "10", Index: true},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -12,7 +12,7 @@ import (
|
||||||
"sigs.k8s.io/yaml"
|
"sigs.k8s.io/yaml"
|
||||||
|
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
"github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/codec"
|
"github.com/cosmos/cosmos-sdk/codec"
|
||||||
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
||||||
|
@ -63,7 +63,7 @@ func (logs ABCIMessageLogs) String() (str string) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewResponseResultTx returns a TxResponse given a ResultTx from tendermint
|
// NewResponseResultTx returns a TxResponse given a ResultTx from tendermint
|
||||||
func NewResponseResultTx(res *ctypes.ResultTx, anyTx *codectypes.Any, timestamp string) *TxResponse {
|
func NewResponseResultTx(res *coretypes.ResultTx, anyTx *codectypes.Any, timestamp string) *TxResponse {
|
||||||
if res == nil {
|
if res == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -88,7 +88,7 @@ func NewResponseResultTx(res *ctypes.ResultTx, anyTx *codectypes.Any, timestamp
|
||||||
|
|
||||||
// NewResponseFormatBroadcastTxCommit returns a TxResponse given a
|
// NewResponseFormatBroadcastTxCommit returns a TxResponse given a
|
||||||
// ResultBroadcastTxCommit from tendermint.
|
// ResultBroadcastTxCommit from tendermint.
|
||||||
func NewResponseFormatBroadcastTxCommit(res *ctypes.ResultBroadcastTxCommit) *TxResponse {
|
func NewResponseFormatBroadcastTxCommit(res *coretypes.ResultBroadcastTxCommit) *TxResponse {
|
||||||
if res == nil {
|
if res == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -100,7 +100,7 @@ func NewResponseFormatBroadcastTxCommit(res *ctypes.ResultBroadcastTxCommit) *Tx
|
||||||
return newTxResponseDeliverTx(res)
|
return newTxResponseDeliverTx(res)
|
||||||
}
|
}
|
||||||
|
|
||||||
func newTxResponseCheckTx(res *ctypes.ResultBroadcastTxCommit) *TxResponse {
|
func newTxResponseCheckTx(res *coretypes.ResultBroadcastTxCommit) *TxResponse {
|
||||||
if res == nil {
|
if res == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -126,7 +126,7 @@ func newTxResponseCheckTx(res *ctypes.ResultBroadcastTxCommit) *TxResponse {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func newTxResponseDeliverTx(res *ctypes.ResultBroadcastTxCommit) *TxResponse {
|
func newTxResponseDeliverTx(res *coretypes.ResultBroadcastTxCommit) *TxResponse {
|
||||||
if res == nil {
|
if res == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -153,7 +153,7 @@ func newTxResponseDeliverTx(res *ctypes.ResultBroadcastTxCommit) *TxResponse {
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewResponseFormatBroadcastTx returns a TxResponse given a ResultBroadcastTx from tendermint
|
// NewResponseFormatBroadcastTx returns a TxResponse given a ResultBroadcastTx from tendermint
|
||||||
func NewResponseFormatBroadcastTx(res *ctypes.ResultBroadcastTx) *TxResponse {
|
func NewResponseFormatBroadcastTx(res *coretypes.ResultBroadcastTx) *TxResponse {
|
||||||
if res == nil {
|
if res == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ import (
|
||||||
|
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
"github.com/tendermint/tendermint/libs/bytes"
|
"github.com/tendermint/tendermint/libs/bytes"
|
||||||
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
"github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/codec"
|
"github.com/cosmos/cosmos-sdk/codec"
|
||||||
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
||||||
|
@ -75,7 +75,7 @@ func (s *resultTestSuite) TestResponseResultTx() {
|
||||||
GasWanted: 100,
|
GasWanted: 100,
|
||||||
GasUsed: 90,
|
GasUsed: 90,
|
||||||
}
|
}
|
||||||
resultTx := &ctypes.ResultTx{
|
resultTx := &coretypes.ResultTx{
|
||||||
Hash: bytes.HexBytes([]byte("test")),
|
Hash: bytes.HexBytes([]byte("test")),
|
||||||
Height: 10,
|
Height: 10,
|
||||||
TxResult: deliverTxResult,
|
TxResult: deliverTxResult,
|
||||||
|
@ -116,7 +116,7 @@ func (s *resultTestSuite) TestResponseResultTx() {
|
||||||
s.Require().True(sdk.TxResponse{}.Empty())
|
s.Require().True(sdk.TxResponse{}.Empty())
|
||||||
s.Require().False(want.Empty())
|
s.Require().False(want.Empty())
|
||||||
|
|
||||||
resultBroadcastTx := &ctypes.ResultBroadcastTx{
|
resultBroadcastTx := &coretypes.ResultBroadcastTx{
|
||||||
Code: 1,
|
Code: 1,
|
||||||
Codespace: "codespace",
|
Codespace: "codespace",
|
||||||
Data: []byte("data"),
|
Data: []byte("data"),
|
||||||
|
@ -143,7 +143,7 @@ func (s *resultTestSuite) TestResponseFormatBroadcastTxCommit() {
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
// test checkTx
|
// test checkTx
|
||||||
checkTxResult := &ctypes.ResultBroadcastTxCommit{
|
checkTxResult := &coretypes.ResultBroadcastTxCommit{
|
||||||
Height: 10,
|
Height: 10,
|
||||||
Hash: bytes.HexBytes([]byte("test")),
|
Hash: bytes.HexBytes([]byte("test")),
|
||||||
CheckTx: abci.ResponseCheckTx{
|
CheckTx: abci.ResponseCheckTx{
|
||||||
|
@ -156,7 +156,7 @@ func (s *resultTestSuite) TestResponseFormatBroadcastTxCommit() {
|
||||||
Codespace: "codespace",
|
Codespace: "codespace",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
deliverTxResult := &ctypes.ResultBroadcastTxCommit{
|
deliverTxResult := &coretypes.ResultBroadcastTxCommit{
|
||||||
Height: 10,
|
Height: 10,
|
||||||
Hash: bytes.HexBytes([]byte("test")),
|
Hash: bytes.HexBytes([]byte("test")),
|
||||||
DeliverTx: abci.ResponseDeliverTx{
|
DeliverTx: abci.ResponseDeliverTx{
|
||||||
|
|
|
@ -134,7 +134,7 @@ func (s *IntegrationTestSuite) TestCLISignGenOnly() {
|
||||||
sendTokens.String(),
|
sendTokens.String(),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly), // shouldn't break if we use keyname with --generate-only flag
|
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly), // shouldn't break if we use keyname with --generate-only flag
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
}
|
}
|
||||||
generatedStd, err := clitestutil.ExecTestCLICmd(val.ClientCtx, bank.NewSendTxCmd(), args)
|
generatedStd, err := clitestutil.ExecTestCLICmd(val.ClientCtx, bank.NewSendTxCmd(), args)
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
@ -760,7 +760,7 @@ func (s *IntegrationTestSuite) TestCLISendGenerateSignAndBroadcast() {
|
||||||
s.Require().NoError(s.network.WaitForNextBlock())
|
s.Require().NoError(s.network.WaitForNextBlock())
|
||||||
|
|
||||||
// Broadcast correct transaction.
|
// Broadcast correct transaction.
|
||||||
val1.ClientCtx.BroadcastMode = flags.BroadcastBlock
|
val1.ClientCtx.BroadcastMode = flags.BroadcastSync
|
||||||
_, err = TxBroadcastExec(val1.ClientCtx, signedTxFile.Name())
|
_, err = TxBroadcastExec(val1.ClientCtx, signedTxFile.Name())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
|
@ -815,7 +815,7 @@ func (s *IntegrationTestSuite) TestCLIMultisignInsufficientCosigners() {
|
||||||
sdk.NewInt64Coin(s.cfg.BondDenom, 5),
|
sdk.NewInt64Coin(s.cfg.BondDenom, 5),
|
||||||
),
|
),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
||||||
)
|
)
|
||||||
|
@ -925,7 +925,7 @@ func (s *IntegrationTestSuite) TestCLIMultisignSortSignatures() {
|
||||||
sdk.NewInt64Coin(s.cfg.BondDenom, 5),
|
sdk.NewInt64Coin(s.cfg.BondDenom, 5),
|
||||||
),
|
),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
||||||
)
|
)
|
||||||
|
@ -960,7 +960,7 @@ func (s *IntegrationTestSuite) TestCLIMultisignSortSignatures() {
|
||||||
_, err = TxValidateSignaturesExec(val1.ClientCtx, signedTxFile.Name())
|
_, err = TxValidateSignaturesExec(val1.ClientCtx, signedTxFile.Name())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
val1.ClientCtx.BroadcastMode = flags.BroadcastBlock
|
val1.ClientCtx.BroadcastMode = flags.BroadcastSync
|
||||||
_, err = TxBroadcastExec(val1.ClientCtx, signedTxFile.Name())
|
_, err = TxBroadcastExec(val1.ClientCtx, signedTxFile.Name())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
|
@ -1009,7 +1009,7 @@ func (s *IntegrationTestSuite) TestCLIMultisign() {
|
||||||
sdk.NewInt64Coin(s.cfg.BondDenom, 5),
|
sdk.NewInt64Coin(s.cfg.BondDenom, 5),
|
||||||
),
|
),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
||||||
)
|
)
|
||||||
|
@ -1049,7 +1049,7 @@ func (s *IntegrationTestSuite) TestCLIMultisign() {
|
||||||
_, err = TxValidateSignaturesExec(val1.ClientCtx, signedTxFile.Name())
|
_, err = TxValidateSignaturesExec(val1.ClientCtx, signedTxFile.Name())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
val1.ClientCtx.BroadcastMode = flags.BroadcastBlock
|
val1.ClientCtx.BroadcastMode = flags.BroadcastSync
|
||||||
_, err = TxBroadcastExec(val1.ClientCtx, signedTxFile.Name())
|
_, err = TxBroadcastExec(val1.ClientCtx, signedTxFile.Name())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
|
|
||||||
|
@ -1087,7 +1087,7 @@ func (s *IntegrationTestSuite) TestSignBatchMultisig() {
|
||||||
sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(1)),
|
sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(1)),
|
||||||
),
|
),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
||||||
)
|
)
|
||||||
|
@ -1150,7 +1150,7 @@ func (s *IntegrationTestSuite) TestMultisignBatch() {
|
||||||
sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(1)),
|
sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(1)),
|
||||||
),
|
),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
||||||
)
|
)
|
||||||
|
@ -1190,7 +1190,7 @@ func (s *IntegrationTestSuite) TestMultisignBatch() {
|
||||||
// Broadcast transactions.
|
// Broadcast transactions.
|
||||||
for _, signedTx := range signedTxs {
|
for _, signedTx := range signedTxs {
|
||||||
signedTxFile := testutil.WriteToNewTempFile(s.T(), signedTx)
|
signedTxFile := testutil.WriteToNewTempFile(s.T(), signedTx)
|
||||||
val.ClientCtx.BroadcastMode = flags.BroadcastBlock
|
val.ClientCtx.BroadcastMode = flags.BroadcastSync
|
||||||
_, err = TxBroadcastExec(val.ClientCtx, signedTxFile.Name())
|
_, err = TxBroadcastExec(val.ClientCtx, signedTxFile.Name())
|
||||||
s.Require().NoError(err)
|
s.Require().NoError(err)
|
||||||
s.Require().NoError(s.network.WaitForNextBlock())
|
s.Require().NoError(s.network.WaitForNextBlock())
|
||||||
|
@ -1461,7 +1461,7 @@ func (s *IntegrationTestSuite) TestSignWithMultiSignersAminoJSON() {
|
||||||
|
|
||||||
func (s *IntegrationTestSuite) createBankMsg(val *network.Validator, toAddr sdk.AccAddress, amount sdk.Coins, extraFlags ...string) (testutil.BufferWriter, error) {
|
func (s *IntegrationTestSuite) createBankMsg(val *network.Validator, toAddr sdk.AccAddress, amount sdk.Coins, extraFlags ...string) (testutil.BufferWriter, error) {
|
||||||
flags := []string{fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
flags := []string{fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees,
|
fmt.Sprintf("--%s=%s", flags.FlagFees,
|
||||||
sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
}
|
}
|
||||||
|
|
|
@ -295,6 +295,7 @@ func (cgts consumeTxSizeGasTxHandler) simulateSigGasCost(ctx context.Context, tx
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//nolint:unparam
|
||||||
func (cgts consumeTxSizeGasTxHandler) consumeTxSizeGas(ctx context.Context, _ sdk.Tx, txBytes []byte) error {
|
func (cgts consumeTxSizeGasTxHandler) consumeTxSizeGas(ctx context.Context, _ sdk.Tx, txBytes []byte) error {
|
||||||
sdkCtx := sdk.UnwrapSDKContext(ctx)
|
sdkCtx := sdk.UnwrapSDKContext(ctx)
|
||||||
params := cgts.ak.GetParams(sdkCtx)
|
params := cgts.ak.GetParams(sdkCtx)
|
||||||
|
|
|
@ -8,7 +8,7 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
"github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
||||||
|
@ -84,7 +84,7 @@ func QueryTx(clientCtx client.Context, hashHexStr string) (*sdk.TxResponse, erro
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
resBlocks, err := getBlocksForTxResults(clientCtx, []*ctypes.ResultTx{resTx})
|
resBlocks, err := getBlocksForTxResults(clientCtx, []*coretypes.ResultTx{resTx})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -98,7 +98,7 @@ func QueryTx(clientCtx client.Context, hashHexStr string) (*sdk.TxResponse, erro
|
||||||
}
|
}
|
||||||
|
|
||||||
// formatTxResults parses the indexed txs into a slice of TxResponse objects.
|
// formatTxResults parses the indexed txs into a slice of TxResponse objects.
|
||||||
func formatTxResults(txConfig client.TxConfig, resTxs []*ctypes.ResultTx, resBlocks map[int64]*ctypes.ResultBlock) ([]*sdk.TxResponse, error) {
|
func formatTxResults(txConfig client.TxConfig, resTxs []*coretypes.ResultTx, resBlocks map[int64]*coretypes.ResultBlock) ([]*sdk.TxResponse, error) {
|
||||||
var err error
|
var err error
|
||||||
out := make([]*sdk.TxResponse, len(resTxs))
|
out := make([]*sdk.TxResponse, len(resTxs))
|
||||||
for i := range resTxs {
|
for i := range resTxs {
|
||||||
|
@ -111,13 +111,13 @@ func formatTxResults(txConfig client.TxConfig, resTxs []*ctypes.ResultTx, resBlo
|
||||||
return out, nil
|
return out, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func getBlocksForTxResults(clientCtx client.Context, resTxs []*ctypes.ResultTx) (map[int64]*ctypes.ResultBlock, error) {
|
func getBlocksForTxResults(clientCtx client.Context, resTxs []*coretypes.ResultTx) (map[int64]*coretypes.ResultBlock, error) {
|
||||||
node, err := clientCtx.GetNode()
|
node, err := clientCtx.GetNode()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
resBlocks := make(map[int64]*ctypes.ResultBlock)
|
resBlocks := make(map[int64]*coretypes.ResultBlock)
|
||||||
|
|
||||||
for _, resTx := range resTxs {
|
for _, resTx := range resTxs {
|
||||||
if _, ok := resBlocks[resTx.Height]; !ok {
|
if _, ok := resBlocks[resTx.Height]; !ok {
|
||||||
|
@ -133,7 +133,7 @@ func getBlocksForTxResults(clientCtx client.Context, resTxs []*ctypes.ResultTx)
|
||||||
return resBlocks, nil
|
return resBlocks, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func mkTxResult(txConfig client.TxConfig, resTx *ctypes.ResultTx, resBlock *ctypes.ResultBlock) (*sdk.TxResponse, error) {
|
func mkTxResult(txConfig client.TxConfig, resTx *coretypes.ResultTx, resBlock *coretypes.ResultBlock) (*sdk.TxResponse, error) {
|
||||||
txb, err := txConfig.TxDecoder()(resTx.Tx)
|
txb, err := txConfig.TxDecoder()(resTx.Tx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
|
|
@ -71,7 +71,7 @@ func (s *IntegrationTestSuite) SetupSuite() {
|
||||||
sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10)),
|
sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10)),
|
||||||
),
|
),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--gas=%d", flags.DefaultGasLimit),
|
fmt.Sprintf("--gas=%d", flags.DefaultGasLimit),
|
||||||
fmt.Sprintf("--%s=foobar", flags.FlagNote),
|
fmt.Sprintf("--%s=foobar", flags.FlagNote),
|
||||||
|
@ -525,7 +525,7 @@ func (s *IntegrationTestSuite) TestSimMultiSigTx() {
|
||||||
addr,
|
addr,
|
||||||
sdk.NewCoins(coins),
|
sdk.NewCoins(coins),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--gas=%d", flags.DefaultGasLimit),
|
fmt.Sprintf("--gas=%d", flags.DefaultGasLimit),
|
||||||
)
|
)
|
||||||
|
@ -543,7 +543,7 @@ func (s *IntegrationTestSuite) TestSimMultiSigTx() {
|
||||||
sdk.NewInt64Coin(s.cfg.BondDenom, 5),
|
sdk.NewInt64Coin(s.cfg.BondDenom, 5),
|
||||||
),
|
),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
||||||
fmt.Sprintf("--%s=foobar", flags.FlagNote),
|
fmt.Sprintf("--%s=foobar", flags.FlagNote),
|
||||||
|
|
|
@ -56,7 +56,7 @@ func (s *IntegrationTestSuite) TestNewMsgCreateVestingAccountCmd() {
|
||||||
"4070908800",
|
"4070908800",
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFrom, val.Address),
|
fmt.Sprintf("--%s=%s", flags.FlagFrom, val.Address),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
},
|
},
|
||||||
expectErr: false,
|
expectErr: false,
|
||||||
|
@ -71,7 +71,7 @@ func (s *IntegrationTestSuite) TestNewMsgCreateVestingAccountCmd() {
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFrom, val.Address),
|
fmt.Sprintf("--%s=%s", flags.FlagFrom, val.Address),
|
||||||
fmt.Sprintf("--%s=true", cli.FlagDelayed),
|
fmt.Sprintf("--%s=true", cli.FlagDelayed),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
},
|
},
|
||||||
expectErr: false,
|
expectErr: false,
|
||||||
|
@ -80,7 +80,7 @@ func (s *IntegrationTestSuite) TestNewMsgCreateVestingAccountCmd() {
|
||||||
},
|
},
|
||||||
"invalid address": {
|
"invalid address": {
|
||||||
args: []string{
|
args: []string{
|
||||||
sdk.AccAddress("addr4").String(),
|
"addr4",
|
||||||
sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String(),
|
sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String(),
|
||||||
"4070908800",
|
"4070908800",
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFrom, val.Address),
|
fmt.Sprintf("--%s=%s", flags.FlagFrom, val.Address),
|
||||||
|
@ -113,6 +113,13 @@ func (s *IntegrationTestSuite) TestNewMsgCreateVestingAccountCmd() {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Synchronize height between test runs, to ensure sequence numbers are
|
||||||
|
// properly updated.
|
||||||
|
height, err := s.network.LatestHeight()
|
||||||
|
if err != nil {
|
||||||
|
s.T().Fatalf("Getting initial latest height: %v", err)
|
||||||
|
}
|
||||||
|
s.T().Logf("Initial latest height: %d", height)
|
||||||
for name, tc := range testCases {
|
for name, tc := range testCases {
|
||||||
tc := tc
|
tc := tc
|
||||||
|
|
||||||
|
@ -130,5 +137,12 @@ func (s *IntegrationTestSuite) TestNewMsgCreateVestingAccountCmd() {
|
||||||
s.Require().Equal(tc.expectedCode, txResp.Code)
|
s.Require().Equal(tc.expectedCode, txResp.Code)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
next, err := s.network.WaitForHeight(height + 1)
|
||||||
|
if err != nil {
|
||||||
|
s.T().Fatalf("Waiting for height %d: %v", height+1, err)
|
||||||
|
}
|
||||||
|
height = next
|
||||||
|
s.T().Logf("Height now: %d", height)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,8 +6,8 @@ import (
|
||||||
|
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
|
tmtime "github.com/tendermint/tendermint/libs/time"
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
tmtime "github.com/tendermint/tendermint/types/time"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
|
"github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
|
|
|
@ -5,8 +5,8 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
|
tmtime "github.com/tendermint/tendermint/libs/time"
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
tmtime "github.com/tendermint/tendermint/types/time"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/baseapp"
|
"github.com/cosmos/cosmos-sdk/baseapp"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
|
|
|
@ -375,7 +375,7 @@ func (s *IntegrationTestSuite) TestNewSendTxCmdGenOnly() {
|
||||||
)
|
)
|
||||||
args := []string{
|
args := []string{
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
fmt.Sprintf("--%s=true", flags.FlagGenerateOnly),
|
||||||
}
|
}
|
||||||
|
@ -409,7 +409,7 @@ func (s *IntegrationTestSuite) TestNewSendTxCmd() {
|
||||||
),
|
),
|
||||||
[]string{
|
[]string{
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
},
|
},
|
||||||
false, 0, &sdk.TxResponse{},
|
false, 0, &sdk.TxResponse{},
|
||||||
|
@ -424,7 +424,7 @@ func (s *IntegrationTestSuite) TestNewSendTxCmd() {
|
||||||
),
|
),
|
||||||
[]string{
|
[]string{
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(1))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(1))).String()),
|
||||||
},
|
},
|
||||||
false,
|
false,
|
||||||
|
@ -441,7 +441,7 @@ func (s *IntegrationTestSuite) TestNewSendTxCmd() {
|
||||||
),
|
),
|
||||||
[]string{
|
[]string{
|
||||||
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
fmt.Sprintf("--%s=true", flags.FlagSkipConfirmation),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastBlock),
|
fmt.Sprintf("--%s=%s", flags.FlagBroadcastMode, flags.BroadcastSync),
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
fmt.Sprintf("--%s=%s", flags.FlagFees, sdk.NewCoins(sdk.NewCoin(s.cfg.BondDenom, sdk.NewInt(10))).String()),
|
||||||
"--gas=10",
|
"--gas=10",
|
||||||
},
|
},
|
||||||
|
|
|
@ -6,8 +6,8 @@ import (
|
||||||
|
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
|
tmtime "github.com/tendermint/tendermint/libs/time"
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
tmtime "github.com/tendermint/tendermint/types/time"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/baseapp"
|
"github.com/cosmos/cosmos-sdk/baseapp"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
|
@ -560,15 +560,15 @@ func (suite *IntegrationTestSuite) TestMsgSendEvents() {
|
||||||
}
|
}
|
||||||
event1.Attributes = append(
|
event1.Attributes = append(
|
||||||
event1.Attributes,
|
event1.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(types.AttributeKeyRecipient), Value: []byte(addr2.String())},
|
abci.EventAttribute{Key: types.AttributeKeyRecipient, Value: addr2.String()},
|
||||||
)
|
)
|
||||||
event1.Attributes = append(
|
event1.Attributes = append(
|
||||||
event1.Attributes,
|
event1.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(types.AttributeKeySender), Value: []byte(addr.String())},
|
abci.EventAttribute{Key: types.AttributeKeySender, Value: addr.String()},
|
||||||
)
|
)
|
||||||
event1.Attributes = append(
|
event1.Attributes = append(
|
||||||
event1.Attributes,
|
event1.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(sdk.AttributeKeyAmount), Value: []byte(newCoins.String())},
|
abci.EventAttribute{Key: sdk.AttributeKeyAmount, Value: newCoins.String()},
|
||||||
)
|
)
|
||||||
|
|
||||||
event2 := sdk.Event{
|
event2 := sdk.Event{
|
||||||
|
@ -577,7 +577,7 @@ func (suite *IntegrationTestSuite) TestMsgSendEvents() {
|
||||||
}
|
}
|
||||||
event2.Attributes = append(
|
event2.Attributes = append(
|
||||||
event2.Attributes,
|
event2.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(types.AttributeKeySender), Value: []byte(addr.String())},
|
abci.EventAttribute{Key: types.AttributeKeySender, Value: addr.String()},
|
||||||
)
|
)
|
||||||
|
|
||||||
// events are shifted due to the funding account events
|
// events are shifted due to the funding account events
|
||||||
|
@ -631,7 +631,7 @@ func (suite *IntegrationTestSuite) TestMsgMultiSendEvents() {
|
||||||
}
|
}
|
||||||
event1.Attributes = append(
|
event1.Attributes = append(
|
||||||
event1.Attributes,
|
event1.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(types.AttributeKeySender), Value: []byte(addr.String())},
|
abci.EventAttribute{Key: types.AttributeKeySender, Value: addr.String()},
|
||||||
)
|
)
|
||||||
suite.Require().Equal(abci.Event(event1), events[7])
|
suite.Require().Equal(abci.Event(event1), events[7])
|
||||||
|
|
||||||
|
@ -653,7 +653,7 @@ func (suite *IntegrationTestSuite) TestMsgMultiSendEvents() {
|
||||||
}
|
}
|
||||||
event2.Attributes = append(
|
event2.Attributes = append(
|
||||||
event2.Attributes,
|
event2.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(types.AttributeKeySender), Value: []byte(addr2.String())},
|
abci.EventAttribute{Key: types.AttributeKeySender, Value: addr2.String()},
|
||||||
)
|
)
|
||||||
event3 := sdk.Event{
|
event3 := sdk.Event{
|
||||||
Type: types.EventTypeTransfer,
|
Type: types.EventTypeTransfer,
|
||||||
|
@ -661,22 +661,22 @@ func (suite *IntegrationTestSuite) TestMsgMultiSendEvents() {
|
||||||
}
|
}
|
||||||
event3.Attributes = append(
|
event3.Attributes = append(
|
||||||
event3.Attributes,
|
event3.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(types.AttributeKeyRecipient), Value: []byte(addr3.String())},
|
abci.EventAttribute{Key: types.AttributeKeyRecipient, Value: addr3.String()},
|
||||||
)
|
)
|
||||||
event3.Attributes = append(
|
event3.Attributes = append(
|
||||||
event3.Attributes,
|
event3.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(sdk.AttributeKeyAmount), Value: []byte(newCoins.String())})
|
abci.EventAttribute{Key: sdk.AttributeKeyAmount, Value: newCoins.String()})
|
||||||
event4 := sdk.Event{
|
event4 := sdk.Event{
|
||||||
Type: types.EventTypeTransfer,
|
Type: types.EventTypeTransfer,
|
||||||
Attributes: []abci.EventAttribute{},
|
Attributes: []abci.EventAttribute{},
|
||||||
}
|
}
|
||||||
event4.Attributes = append(
|
event4.Attributes = append(
|
||||||
event4.Attributes,
|
event4.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(types.AttributeKeyRecipient), Value: []byte(addr4.String())},
|
abci.EventAttribute{Key: types.AttributeKeyRecipient, Value: addr4.String()},
|
||||||
)
|
)
|
||||||
event4.Attributes = append(
|
event4.Attributes = append(
|
||||||
event4.Attributes,
|
event4.Attributes,
|
||||||
abci.EventAttribute{Key: []byte(sdk.AttributeKeyAmount), Value: []byte(newCoins2.String())},
|
abci.EventAttribute{Key: sdk.AttributeKeyAmount, Value: newCoins2.String()},
|
||||||
)
|
)
|
||||||
// events are shifted due to the funding account events
|
// events are shifted due to the funding account events
|
||||||
suite.Require().Equal(abci.Event(event1), events[21])
|
suite.Require().Equal(abci.Event(event1), events[21])
|
||||||
|
|
|
@ -9,13 +9,17 @@ import (
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
"github.com/cosmos/cosmos-sdk/x/crisis/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestLogger(t *testing.T) {
|
func TestLogger(t *testing.T) {
|
||||||
app := simapp.Setup(t, false)
|
app := simapp.Setup(t, false)
|
||||||
|
|
||||||
ctx := app.NewContext(true, tmproto.Header{})
|
ctx := app.NewContext(true, tmproto.Header{})
|
||||||
require.Equal(t, ctx.Logger(), app.CrisisKeeper.Logger(ctx))
|
|
||||||
|
require.Equal(t,
|
||||||
|
ctx.Logger().With("module", "x/"+types.ModuleName),
|
||||||
|
app.CrisisKeeper.Logger(ctx))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestInvariants(t *testing.T) {
|
func TestInvariants(t *testing.T) {
|
||||||
|
|
|
@ -3,10 +3,10 @@ package evidence_test
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
"github.com/tendermint/tendermint/types/time"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/crypto/keys/ed25519"
|
"github.com/cosmos/cosmos-sdk/crypto/keys/ed25519"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
|
|
|
@ -853,24 +853,28 @@ func (s *IntegrationTestSuite) TestFilteredFeeAllowance() {
|
||||||
&sdk.TxResponse{},
|
&sdk.TxResponse{},
|
||||||
2,
|
2,
|
||||||
},
|
},
|
||||||
{
|
/* TODO(#10559): This case times out after TM v0.35.
|
||||||
"should fail with unauthorized msgs",
|
Figure out why and fix it.
|
||||||
func() (testutil.BufferWriter, error) {
|
|
||||||
args := append(
|
{
|
||||||
[]string{
|
"should fail with unauthorized msgs",
|
||||||
grantee.String(),
|
func() (testutil.BufferWriter, error) {
|
||||||
"cosmos14cm33pvnrv2497tyt8sp9yavhmw83nwej3m0e8",
|
args := append(
|
||||||
fmt.Sprintf("--%s=%s", cli.FlagSpendLimit, "100stake"),
|
[]string{
|
||||||
fmt.Sprintf("--%s=%s", flags.FlagFeeAccount, granter),
|
grantee.String(),
|
||||||
|
"cosmos14cm33pvnrv2497tyt8sp9yavhmw83nwej3m0e8",
|
||||||
|
fmt.Sprintf("--%s=%s", cli.FlagSpendLimit, "100stake"),
|
||||||
|
fmt.Sprintf("--%s=%s", flags.FlagFeeAccount, granter),
|
||||||
|
},
|
||||||
|
commonFlags...,
|
||||||
|
)
|
||||||
|
cmd := cli.NewCmdFeeGrant()
|
||||||
|
return clitestutil.ExecTestCLICmd(clientCtx, cmd, args)
|
||||||
},
|
},
|
||||||
commonFlags...,
|
&sdk.TxResponse{},
|
||||||
)
|
7,
|
||||||
cmd := cli.NewCmdFeeGrant()
|
},
|
||||||
return clitestutil.ExecTestCLICmd(clientCtx, cmd, args)
|
*/
|
||||||
},
|
|
||||||
&sdk.TxResponse{},
|
|
||||||
7,
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range cases {
|
for _, tc := range cases {
|
||||||
|
|
|
@ -5,7 +5,6 @@ import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
|
||||||
|
|
||||||
"github.com/cosmos/go-bip39"
|
"github.com/cosmos/go-bip39"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
@ -169,7 +168,7 @@ func InitCmd(mbm module.BasicManager, defaultNodeHome string) *cobra.Command {
|
||||||
|
|
||||||
toPrint := newPrintInfo(config.Moniker, chainID, nodeID, "", appState)
|
toPrint := newPrintInfo(config.Moniker, chainID, nodeID, "", appState)
|
||||||
|
|
||||||
cfg.WriteConfigFile(filepath.Join(config.RootDir, "config", "config.toml"), config)
|
cfg.WriteConfigFile(config.RootDir, config)
|
||||||
return displayInfo(toPrint)
|
return displayInfo(toPrint)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,7 @@ func GenAppStateFromConfig(cdc codec.JSONCodec, txEncodingConfig client.TxEncodi
|
||||||
}
|
}
|
||||||
|
|
||||||
config.P2P.PersistentPeers = persistentPeers
|
config.P2P.PersistentPeers = persistentPeers
|
||||||
cfg.WriteConfigFile(filepath.Join(config.RootDir, "config", "config.toml"), config)
|
cfg.WriteConfigFile(config.RootDir, config)
|
||||||
|
|
||||||
// if there are no gen txs to be processed, return the default empty state
|
// if there are no gen txs to be processed, return the default empty state
|
||||||
if len(appGenTxs) == 0 {
|
if len(appGenTxs) == 0 {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package genutil
|
package genutil
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
@ -10,7 +11,6 @@ import (
|
||||||
cfg "github.com/tendermint/tendermint/config"
|
cfg "github.com/tendermint/tendermint/config"
|
||||||
tmed25519 "github.com/tendermint/tendermint/crypto/ed25519"
|
tmed25519 "github.com/tendermint/tendermint/crypto/ed25519"
|
||||||
tmos "github.com/tendermint/tendermint/libs/os"
|
tmos "github.com/tendermint/tendermint/libs/os"
|
||||||
"github.com/tendermint/tendermint/p2p"
|
|
||||||
"github.com/tendermint/tendermint/privval"
|
"github.com/tendermint/tendermint/privval"
|
||||||
tmtypes "github.com/tendermint/tendermint/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
|
|
||||||
|
@ -60,34 +60,36 @@ func InitializeNodeValidatorFilesFromMnemonic(config *cfg.Config, mnemonic strin
|
||||||
if len(mnemonic) > 0 && !bip39.IsMnemonicValid(mnemonic) {
|
if len(mnemonic) > 0 && !bip39.IsMnemonicValid(mnemonic) {
|
||||||
return "", nil, fmt.Errorf("invalid mnemonic")
|
return "", nil, fmt.Errorf("invalid mnemonic")
|
||||||
}
|
}
|
||||||
|
nodeKey, err := tmtypes.LoadOrGenNodeKey(config.NodeKeyFile())
|
||||||
nodeKey, err := p2p.LoadOrGenNodeKey(config.NodeKeyFile())
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", nil, err
|
return "", nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
nodeID = string(nodeKey.ID())
|
nodeID = string(nodeKey.ID)
|
||||||
|
|
||||||
pvKeyFile := config.PrivValidatorKeyFile()
|
pvKeyFile := config.PrivValidator.KeyFile()
|
||||||
if err := tmos.EnsureDir(filepath.Dir(pvKeyFile), 0777); err != nil {
|
if err := tmos.EnsureDir(filepath.Dir(pvKeyFile), 0777); err != nil {
|
||||||
return "", nil, err
|
return "", nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
pvStateFile := config.PrivValidatorStateFile()
|
pvStateFile := config.PrivValidator.StateFile()
|
||||||
if err := tmos.EnsureDir(filepath.Dir(pvStateFile), 0777); err != nil {
|
if err := tmos.EnsureDir(filepath.Dir(pvStateFile), 0777); err != nil {
|
||||||
return "", nil, err
|
return "", nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var filePV *privval.FilePV
|
var filePV *privval.FilePV
|
||||||
if len(mnemonic) == 0 {
|
if len(mnemonic) == 0 {
|
||||||
filePV = privval.LoadOrGenFilePV(pvKeyFile, pvStateFile)
|
filePV, err = privval.LoadOrGenFilePV(pvKeyFile, pvStateFile)
|
||||||
|
if err != nil {
|
||||||
|
return "", nil, err
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
privKey := tmed25519.GenPrivKeyFromSecret([]byte(mnemonic))
|
privKey := tmed25519.GenPrivKeyFromSecret([]byte(mnemonic))
|
||||||
filePV = privval.NewFilePV(privKey, pvKeyFile, pvStateFile)
|
filePV = privval.NewFilePV(privKey, pvKeyFile, pvStateFile)
|
||||||
filePV.Save()
|
filePV.Save()
|
||||||
}
|
}
|
||||||
|
|
||||||
tmValPubKey, err := filePV.GetPubKey()
|
tmValPubKey, err := filePV.GetPubKey(context.TODO())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", nil, err
|
return "", nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,9 +62,9 @@ func TestInitializeNodeValidatorFilesFromMnemonic(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
if tt.mnemonic != "" {
|
if tt.mnemonic != "" {
|
||||||
actualPVFile := privval.LoadFilePV(cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
|
actualPVFile, _ := privval.LoadFilePV(cfg.PrivValidator.KeyFile(), cfg.PrivValidator.StateFile())
|
||||||
expectedPrivateKey := tmed25519.GenPrivKeyFromSecret([]byte(tt.mnemonic))
|
expectedPrivateKey := tmed25519.GenPrivKeyFromSecret([]byte(tt.mnemonic))
|
||||||
expectedFile := privval.NewFilePV(expectedPrivateKey, cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
|
expectedFile := privval.NewFilePV(expectedPrivateKey, cfg.PrivValidator.KeyFile(), cfg.PrivValidator.StateFile())
|
||||||
require.Equal(t, expectedFile, actualPVFile)
|
require.Equal(t, expectedFile, actualPVFile)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ import (
|
||||||
|
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
"github.com/tendermint/tendermint/rpc/client/mock"
|
"github.com/tendermint/tendermint/rpc/client/mock"
|
||||||
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
"github.com/tendermint/tendermint/rpc/coretypes"
|
||||||
tmtypes "github.com/tendermint/tendermint/types"
|
tmtypes "github.com/tendermint/tendermint/types"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client"
|
"github.com/cosmos/cosmos-sdk/client"
|
||||||
|
@ -24,7 +24,7 @@ type TxSearchMock struct {
|
||||||
txs []tmtypes.Tx
|
txs []tmtypes.Tx
|
||||||
}
|
}
|
||||||
|
|
||||||
func (mock TxSearchMock) TxSearch(ctx context.Context, query string, prove bool, page, perPage *int, orderBy string) (*ctypes.ResultTxSearch, error) {
|
func (mock TxSearchMock) TxSearch(ctx context.Context, query string, prove bool, page, perPage *int, orderBy string) (*coretypes.ResultTxSearch, error) {
|
||||||
if page == nil {
|
if page == nil {
|
||||||
*page = 0
|
*page = 0
|
||||||
}
|
}
|
||||||
|
@ -55,23 +55,23 @@ func (mock TxSearchMock) TxSearch(ctx context.Context, query string, prove bool,
|
||||||
start, end := client.Paginate(len(mock.txs), *page, *perPage, 100)
|
start, end := client.Paginate(len(mock.txs), *page, *perPage, 100)
|
||||||
if start < 0 || end < 0 {
|
if start < 0 || end < 0 {
|
||||||
// nil result with nil error crashes utils.QueryTxsByEvents
|
// nil result with nil error crashes utils.QueryTxsByEvents
|
||||||
return &ctypes.ResultTxSearch{}, nil
|
return &coretypes.ResultTxSearch{}, nil
|
||||||
}
|
}
|
||||||
if len(matchingTxs) < end {
|
if len(matchingTxs) < end {
|
||||||
return &ctypes.ResultTxSearch{}, nil
|
return &coretypes.ResultTxSearch{}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
txs := matchingTxs[start:end]
|
txs := matchingTxs[start:end]
|
||||||
rst := &ctypes.ResultTxSearch{Txs: make([]*ctypes.ResultTx, len(txs)), TotalCount: len(txs)}
|
rst := &coretypes.ResultTxSearch{Txs: make([]*coretypes.ResultTx, len(txs)), TotalCount: len(txs)}
|
||||||
for i := range txs {
|
for i := range txs {
|
||||||
rst.Txs[i] = &ctypes.ResultTx{Tx: txs[i]}
|
rst.Txs[i] = &coretypes.ResultTx{Tx: txs[i]}
|
||||||
}
|
}
|
||||||
return rst, nil
|
return rst, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (mock TxSearchMock) Block(ctx context.Context, height *int64) (*ctypes.ResultBlock, error) {
|
func (mock TxSearchMock) Block(ctx context.Context, height *int64) (*coretypes.ResultBlock, error) {
|
||||||
// any non nil Block needs to be returned. used to get time value
|
// any non nil Block needs to be returned. used to get time value
|
||||||
return &ctypes.ResultBlock{Block: &tmtypes.Block{}}, nil
|
return &coretypes.ResultBlock{Block: &tmtypes.Block{}}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetPaginatedVotes(t *testing.T) {
|
func TestGetPaginatedVotes(t *testing.T) {
|
||||||
|
|
|
@ -30,29 +30,24 @@ require (
|
||||||
github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 // indirect
|
github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 // indirect
|
||||||
github.com/dustin/go-humanize v1.0.0 // indirect
|
github.com/dustin/go-humanize v1.0.0 // indirect
|
||||||
github.com/fsnotify/fsnotify v1.5.1 // indirect
|
github.com/fsnotify/fsnotify v1.5.1 // indirect
|
||||||
github.com/go-kit/kit v0.10.0 // indirect
|
|
||||||
github.com/go-logfmt/logfmt v0.5.0 // indirect
|
|
||||||
github.com/golang/glog v1.0.0 // indirect
|
github.com/golang/glog v1.0.0 // indirect
|
||||||
github.com/golang/protobuf v1.5.2 // indirect
|
github.com/golang/protobuf v1.5.2 // indirect
|
||||||
github.com/golang/snappy v0.0.4 // indirect
|
github.com/golang/snappy v0.0.4 // indirect
|
||||||
github.com/google/btree v1.0.1 // indirect
|
github.com/google/btree v1.0.1 // indirect
|
||||||
github.com/google/gofuzz v1.1.1-0.20200604201612-c04b05f3adfa // indirect
|
github.com/google/gofuzz v1.1.1-0.20200604201612-c04b05f3adfa // indirect
|
||||||
|
github.com/google/uuid v1.3.0 // indirect
|
||||||
github.com/grpc-ecosystem/grpc-gateway v1.16.0 // indirect
|
github.com/grpc-ecosystem/grpc-gateway v1.16.0 // indirect
|
||||||
github.com/gtank/merlin v0.1.1 // indirect
|
github.com/hashicorp/go-immutable-radix v1.3.1 // indirect
|
||||||
github.com/hashicorp/go-immutable-radix v1.0.0 // indirect
|
|
||||||
github.com/hashicorp/golang-lru v0.5.5-0.20210104140557-80c98217689d // indirect
|
github.com/hashicorp/golang-lru v0.5.5-0.20210104140557-80c98217689d // indirect
|
||||||
github.com/hashicorp/hcl v1.0.0 // indirect
|
github.com/hashicorp/hcl v1.0.0 // indirect
|
||||||
github.com/inconshreveable/mousetrap v1.0.0 // indirect
|
github.com/inconshreveable/mousetrap v1.0.0 // indirect
|
||||||
github.com/jmhodges/levigo v1.0.0 // indirect
|
github.com/jmhodges/levigo v1.0.0 // indirect
|
||||||
github.com/klauspost/compress v1.13.6 // indirect
|
github.com/klauspost/compress v1.13.6 // indirect
|
||||||
github.com/kr/text v0.2.0 // indirect
|
|
||||||
github.com/lazyledger/smt v0.2.1-0.20210709230900-03ea40719554 // indirect
|
github.com/lazyledger/smt v0.2.1-0.20210709230900-03ea40719554 // indirect
|
||||||
github.com/libp2p/go-buffer-pool v0.0.2 // indirect
|
|
||||||
github.com/magiconair/properties v1.8.5 // indirect
|
github.com/magiconair/properties v1.8.5 // indirect
|
||||||
github.com/matttproud/golang_protobuf_extensions v1.0.1 // indirect
|
github.com/matttproud/golang_protobuf_extensions v1.0.1 // indirect
|
||||||
github.com/mimoo/StrobeGo v0.0.0-20181016162300-f8f6d4d2b643 // indirect
|
|
||||||
github.com/mitchellh/mapstructure v1.4.2 // indirect
|
github.com/mitchellh/mapstructure v1.4.2 // indirect
|
||||||
github.com/nxadm/tail v1.4.8 // indirect
|
github.com/oasisprotocol/curve25519-voi v0.0.0-20210609091139-0a56a4bca00b // indirect
|
||||||
github.com/pelletier/go-toml v1.9.4 // indirect
|
github.com/pelletier/go-toml v1.9.4 // indirect
|
||||||
github.com/petermattis/goid v0.0.0-20180202154549-b0b1615b78e5 // indirect
|
github.com/petermattis/goid v0.0.0-20180202154549-b0b1615b78e5 // indirect
|
||||||
github.com/pkg/errors v0.9.1 // indirect
|
github.com/pkg/errors v0.9.1 // indirect
|
||||||
|
@ -60,7 +55,8 @@ require (
|
||||||
github.com/prometheus/client_golang v1.11.0 // indirect
|
github.com/prometheus/client_golang v1.11.0 // indirect
|
||||||
github.com/prometheus/client_model v0.2.0 // indirect
|
github.com/prometheus/client_model v0.2.0 // indirect
|
||||||
github.com/prometheus/common v0.32.1 // indirect
|
github.com/prometheus/common v0.32.1 // indirect
|
||||||
github.com/prometheus/procfs v0.6.0 // indirect
|
github.com/prometheus/procfs v0.7.3 // indirect
|
||||||
|
github.com/rs/zerolog v1.26.0 // indirect
|
||||||
github.com/sasha-s/go-deadlock v0.2.1-0.20190427202633-1595213edefa // indirect
|
github.com/sasha-s/go-deadlock v0.2.1-0.20190427202633-1595213edefa // indirect
|
||||||
github.com/spf13/afero v1.6.0 // indirect
|
github.com/spf13/afero v1.6.0 // indirect
|
||||||
github.com/spf13/cast v1.4.1 // indirect
|
github.com/spf13/cast v1.4.1 // indirect
|
||||||
|
@ -72,13 +68,13 @@ require (
|
||||||
github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7 // indirect
|
github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7 // indirect
|
||||||
github.com/tecbot/gorocksdb v0.0.0-20191217155057-f0fad39f321c // indirect
|
github.com/tecbot/gorocksdb v0.0.0-20191217155057-f0fad39f321c // indirect
|
||||||
github.com/tendermint/go-amino v0.16.0 // indirect
|
github.com/tendermint/go-amino v0.16.0 // indirect
|
||||||
github.com/tendermint/tendermint v0.34.14 // indirect
|
github.com/tendermint/tendermint v0.35.0 // indirect
|
||||||
go.etcd.io/bbolt v1.3.5 // indirect
|
go.etcd.io/bbolt v1.3.5 // indirect
|
||||||
golang.org/x/crypto v0.0.0-20210817164053-32db794688a5 // indirect
|
golang.org/x/crypto v0.0.0-20210921155107-089bfa567519 // indirect
|
||||||
golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2 // indirect
|
golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2 // indirect
|
||||||
golang.org/x/sys v0.0.0-20211113001501-0c823b97ae02 // indirect
|
golang.org/x/sys v0.0.0-20211113001501-0c823b97ae02 // indirect
|
||||||
golang.org/x/text v0.3.6 // indirect
|
golang.org/x/text v0.3.7 // indirect
|
||||||
google.golang.org/genproto v0.0.0-20210828152312-66f60bf46e71 // indirect
|
google.golang.org/genproto v0.0.0-20210917145530-b395a37504d4 // indirect
|
||||||
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c // indirect
|
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c // indirect
|
||||||
gopkg.in/ini.v1 v1.63.2 // indirect
|
gopkg.in/ini.v1 v1.63.2 // indirect
|
||||||
gopkg.in/yaml.v2 v2.4.0 // indirect
|
gopkg.in/yaml.v2 v2.4.0 // indirect
|
||||||
|
|
454
x/group/go.sum
454
x/group/go.sum
File diff suppressed because it is too large
Load Diff
|
@ -4,8 +4,8 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
|
tmtime "github.com/tendermint/tendermint/libs/time"
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
tmtime "github.com/tendermint/tendermint/types/time"
|
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/baseapp"
|
"github.com/cosmos/cosmos-sdk/baseapp"
|
||||||
"github.com/cosmos/cosmos-sdk/simapp"
|
"github.com/cosmos/cosmos-sdk/simapp"
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
package types
|
package types
|
||||||
|
|
||||||
import (
|
import (
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/baseapp"
|
"github.com/cosmos/cosmos-sdk/baseapp"
|
||||||
|
@ -15,7 +14,7 @@ import (
|
||||||
func ConsensusParamsKeyTable() KeyTable {
|
func ConsensusParamsKeyTable() KeyTable {
|
||||||
return NewKeyTable(
|
return NewKeyTable(
|
||||||
NewParamSetPair(
|
NewParamSetPair(
|
||||||
baseapp.ParamStoreKeyBlockParams, abci.BlockParams{}, baseapp.ValidateBlockParams,
|
baseapp.ParamStoreKeyBlockParams, tmproto.BlockParams{}, baseapp.ValidateBlockParams,
|
||||||
),
|
),
|
||||||
NewParamSetPair(
|
NewParamSetPair(
|
||||||
baseapp.ParamStoreKeyEvidenceParams, tmproto.EvidenceParams{}, baseapp.ValidateEvidenceParams,
|
baseapp.ParamStoreKeyEvidenceParams, tmproto.EvidenceParams{}, baseapp.ValidateEvidenceParams,
|
||||||
|
|
|
@ -5,7 +5,6 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math/rand"
|
"math/rand"
|
||||||
|
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
|
||||||
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||||||
"github.com/tendermint/tendermint/types"
|
"github.com/tendermint/tendermint/types"
|
||||||
|
|
||||||
|
@ -151,7 +150,7 @@ func (w WeightedProposalContent) ContentSimulatorFn() simulation.ContentSimulato
|
||||||
// Param change proposals
|
// Param change proposals
|
||||||
|
|
||||||
// randomConsensusParams returns random simulation consensus parameters, it extracts the Evidence from the Staking genesis state.
|
// randomConsensusParams returns random simulation consensus parameters, it extracts the Evidence from the Staking genesis state.
|
||||||
func randomConsensusParams(r *rand.Rand, appState json.RawMessage, cdc codec.JSONCodec) *abci.ConsensusParams {
|
func randomConsensusParams(r *rand.Rand, appState json.RawMessage, cdc codec.JSONCodec) *tmproto.ConsensusParams {
|
||||||
var genesisState map[string]json.RawMessage
|
var genesisState map[string]json.RawMessage
|
||||||
err := json.Unmarshal(appState, &genesisState)
|
err := json.Unmarshal(appState, &genesisState)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -159,8 +158,8 @@ func randomConsensusParams(r *rand.Rand, appState json.RawMessage, cdc codec.JSO
|
||||||
}
|
}
|
||||||
|
|
||||||
stakingGenesisState := stakingtypes.GetGenesisStateFromAppState(cdc, genesisState)
|
stakingGenesisState := stakingtypes.GetGenesisStateFromAppState(cdc, genesisState)
|
||||||
consensusParams := &abci.ConsensusParams{
|
consensusParams := &tmproto.ConsensusParams{
|
||||||
Block: &abci.BlockParams{
|
Block: &tmproto.BlockParams{
|
||||||
MaxBytes: int64(simulation.RandIntBetween(r, 20000000, 30000000)),
|
MaxBytes: int64(simulation.RandIntBetween(r, 20000000, 30000000)),
|
||||||
MaxGas: -1,
|
MaxGas: -1,
|
||||||
},
|
},
|
||||||
|
|
|
@ -1337,7 +1337,7 @@ func (s *IntegrationTestSuite) TestBlockResults() {
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
|
|
||||||
// Create a HTTP rpc client.
|
// Create a HTTP rpc client.
|
||||||
rpcClient, err := http.New(val.RPCAddress, "/websocket")
|
rpcClient, err := http.New(val.RPCAddress)
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
|
|
||||||
// Loop until we find a block result with the correct validator updates.
|
// Loop until we find a block result with the correct validator updates.
|
||||||
|
|
|
@ -6,6 +6,7 @@ import (
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/rs/zerolog"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
"github.com/tendermint/tendermint/libs/log"
|
"github.com/tendermint/tendermint/libs/log"
|
||||||
|
@ -13,6 +14,7 @@ import (
|
||||||
dbm "github.com/tendermint/tm-db"
|
dbm "github.com/tendermint/tm-db"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/baseapp"
|
"github.com/cosmos/cosmos-sdk/baseapp"
|
||||||
|
"github.com/cosmos/cosmos-sdk/server"
|
||||||
"github.com/cosmos/cosmos-sdk/store/rootmulti"
|
"github.com/cosmos/cosmos-sdk/store/rootmulti"
|
||||||
storetypes "github.com/cosmos/cosmos-sdk/store/types"
|
storetypes "github.com/cosmos/cosmos-sdk/store/types"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
@ -25,7 +27,10 @@ func useUpgradeLoader(height int64, upgrades *storetypes.StoreUpgrades) func(*ba
|
||||||
}
|
}
|
||||||
|
|
||||||
func defaultLogger() log.Logger {
|
func defaultLogger() log.Logger {
|
||||||
return log.NewTMLogger(log.NewSyncWriter(os.Stdout)).With("module", "sdk/app")
|
writer := zerolog.ConsoleWriter{Out: os.Stderr}
|
||||||
|
return server.ZeroLogWrapper{
|
||||||
|
Logger: zerolog.New(writer).Level(zerolog.InfoLevel).With().Timestamp().Logger(),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func initStore(t *testing.T, db dbm.DB, storeKey string, k, v []byte) {
|
func initStore(t *testing.T, db dbm.DB, storeKey string, k, v []byte) {
|
||||||
|
|
Loading…
Reference in New Issue