Some checks failed
CodeQL / Analyze (push) Waiting to run
golangci-lint / lint (push) Waiting to run
Tests / Code Coverage / build (amd64) (push) Waiting to run
Tests / Code Coverage / build (arm64) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[additional-args:-tags="test_e2e" name:e2e path:./e2e]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:08-wasm path:./modules/light-clients/08-wasm]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:ibc-go path:.]) (push) Waiting to run
Docker Build & Push Simapp (main) / docker-build (push) Has been cancelled
77 lines
2.4 KiB
Go
77 lines
2.4 KiB
Go
package ibctesting_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
sdkmath "cosmossdk.io/math"
|
|
|
|
sdk "git.cw.tr/mukan-network/mukan-sdk/types"
|
|
"git.cw.tr/mukan-network/mukan-sdk/x/staking/types"
|
|
|
|
ibctesting "git.cw.tr/mukan-network/mukan-ibc/testing"
|
|
)
|
|
|
|
func TestChangeValSet(t *testing.T) {
|
|
coord := ibctesting.NewCoordinator(t, 2)
|
|
chainA := coord.GetChain(ibctesting.GetChainID(1))
|
|
chainB := coord.GetChain(ibctesting.GetChainID(2))
|
|
|
|
path := ibctesting.NewPath(chainA, chainB)
|
|
path.Setup()
|
|
|
|
amount, ok := sdkmath.NewIntFromString("10000000000000000000")
|
|
require.True(t, ok)
|
|
amount2, ok := sdkmath.NewIntFromString("30000000000000000000")
|
|
require.True(t, ok)
|
|
|
|
val, err := chainA.GetSimApp().StakingKeeper.GetValidators(chainA.GetContext(), 4)
|
|
require.NoError(t, err)
|
|
|
|
chainA.GetSimApp().StakingKeeper.Delegate(chainA.GetContext(), chainA.SenderAccounts[1].SenderAccount.GetAddress(), //nolint:errcheck // ignore error for test
|
|
amount, types.Unbonded, val[1], true)
|
|
chainA.GetSimApp().StakingKeeper.Delegate(chainA.GetContext(), chainA.SenderAccounts[3].SenderAccount.GetAddress(), //nolint:errcheck // ignore error for test
|
|
amount2, types.Unbonded, val[3], true)
|
|
|
|
coord.CommitBlock(chainA)
|
|
|
|
// verify that update clients works even after validator update goes into effect
|
|
err = path.EndpointB.UpdateClient()
|
|
require.NoError(t, err)
|
|
err = path.EndpointB.UpdateClient()
|
|
require.NoError(t, err)
|
|
}
|
|
|
|
func TestJailProposerValidator(t *testing.T) {
|
|
coord := ibctesting.NewCoordinator(t, 2)
|
|
chainA := coord.GetChain(ibctesting.GetChainID(1))
|
|
chainB := coord.GetChain(ibctesting.GetChainID(2))
|
|
|
|
path := ibctesting.NewPath(chainA, chainB)
|
|
coord.Setup(path)
|
|
|
|
// save valset length before jailing
|
|
valsetLen := len(chainA.Vals.Validators)
|
|
|
|
// jail the proposer validator in chain A
|
|
propAddr := sdk.ConsAddress(chainA.Vals.Proposer.Address)
|
|
|
|
err := chainA.GetSimApp().StakingKeeper.Jail(
|
|
chainA.GetContext(), propAddr)
|
|
require.NoError(t, err)
|
|
|
|
coord.CommitBlock(chainA)
|
|
|
|
// verify that update clients works even after validator update goes into effect
|
|
err = path.EndpointB.UpdateClient()
|
|
require.NoError(t, err)
|
|
err = path.EndpointB.UpdateClient()
|
|
require.NoError(t, err)
|
|
|
|
// check that the jailing has taken effect in chain A
|
|
require.Equal(t, valsetLen-1, len(chainA.Vals.Validators))
|
|
|
|
// check that the valset in chain A has a new proposer
|
|
require.False(t, propAddr.Equals(sdk.ConsAddress(chainA.Vals.Proposer.Address)))
|
|
}
|