From 252cc59e7a5dcac38f6dfe74b3991fbbde84d984 Mon Sep 17 00:00:00 2001
From: Philip Offtermatt
Date: Mon, 25 Mar 2024 14:23:24 +0100
Subject: [PATCH] Fix flagging valset changed
---
tests/mbt/driver/mbt_test.go | 1 -
tests/mbt/driver/setup.go | 30 ++++++++++++++++++++++++------
tests/mbt/model/ccv.qnt | 2 +-
tests/mbt/model/ccv_model.qnt | 2 +-
tests/mbt/model/ccv_pss_model.qnt | 5 +++--
5 files changed, 29 insertions(+), 11 deletions(-)
diff --git a/tests/mbt/driver/mbt_test.go b/tests/mbt/driver/mbt_test.go
index c48538b300..0e65d36a7e 100644
--- a/tests/mbt/driver/mbt_test.go
+++ b/tests/mbt/driver/mbt_test.go
@@ -350,7 +350,6 @@ func RunItfTrace(t *testing.T, path string) {
driver.setupConsumer(
chainId,
modelParams,
- &initialValSet,
consumerSigners,
nodes,
valNames,
diff --git a/tests/mbt/driver/setup.go b/tests/mbt/driver/setup.go
index ff0fd744f5..fe2f281190 100644
--- a/tests/mbt/driver/setup.go
+++ b/tests/mbt/driver/setup.go
@@ -1,6 +1,7 @@
package main
import (
+ "bytes"
"encoding/json"
"log"
"testing"
@@ -444,7 +445,6 @@ func (s *Driver) setupProvider(
func (s *Driver) setupConsumer(
chain string,
params ModelParams,
- valSet *cmttypes.ValidatorSet, // the current validator set on the provider chain
signers map[string]cmttypes.PrivValidator, // a map of validator addresses to private validators (signers)
nodes []*cmttypes.Validator, // the list of nodes, even ones that have no voting power initially
valNames []string,
@@ -454,16 +454,34 @@ func (s *Driver) setupConsumer(
) {
s.t.Logf("Starting consumer %v", chain)
- // TODO: reuse the partial set computation logic to compute the initial validator set
- // for top N chains
- initValUpdates := cmttypes.TM2PB.ValidatorUpdates(valSet)
+ minPowerToOptIn := s.providerKeeper().ComputeMinPowerToOptIn(s.providerCtx(), s.providerValidatorSet(), uint32(topN))
+
+ valSet := s.providerChain().Vals
+
+ // Filter out all the validators that do not either a) have power at least minPowerToOptIn, or b) are in the validatorsToOptIn slice
+ filteredValSet := make([]*cmttypes.Validator, 0)
+ for _, val := range valSet.Validators {
+ if val.VotingPower >= minPowerToOptIn && topN > 0 {
+ filteredValSet = append(filteredValSet, val)
+ continue
+ }
+ for _, optInVal := range validatorsToOptIn {
+ if bytes.Equal(val.Address, optInVal.Address.Bytes()) {
+ filteredValSet = append(filteredValSet, val)
+ break
+ }
+ }
+ }
+
+ initValSet := cmttypes.ValidatorSet{Validators: filteredValSet, Proposer: filteredValSet[0]}
+ initValUpdates := cmttypes.TM2PB.ValidatorUpdates(&initValSet)
// start consumer chains
s.t.Logf("Creating consumer chain %v", chain)
- consumerChain := newChain(s.t, params, s.coordinator, icstestingutils.ConsumerAppIniter(initValUpdates), chain, valSet, signers, nodes, valNames)
+ consumerChain := newChain(s.t, params, s.coordinator, icstestingutils.ConsumerAppIniter(initValUpdates), chain, &initValSet, signers, nodes, valNames)
s.coordinator.Chains[chain] = consumerChain
- valUpdates := cmttypes.TM2PB.ValidatorUpdates(valSet)
+ valUpdates := cmttypes.TM2PB.ValidatorUpdates(&initValSet)
path := s.ConfigureNewPath(consumerChain, providerChain, params, uint32(topN), validatorsToOptIn, valUpdates)
s.simibcs[ChainId(chain)] = simibc.MakeRelayedPath(s.t, path)
diff --git a/tests/mbt/model/ccv.qnt b/tests/mbt/model/ccv.qnt
index 9f95abf1df..cd6a42ce52 100644
--- a/tests/mbt/model/ccv.qnt
+++ b/tests/mbt/model/ccv.qnt
@@ -343,7 +343,7 @@ module ccv {
} else {
// set the validator set changed flag
val newProviderState = currentState.providerState.with(
- "consumersWithPowerChangesInThisEpoch", getRunningConsumers(currentState.providerState)
+ "consumersWithPowerChangesInThisEpoch", getRunningConsumers(currentState.providerState).filter(consumer => currentState.providerState.optedInVals.get(consumer).contains(validator))
)
pure val tmpState = currentState.with(
"providerState", newProviderState
diff --git a/tests/mbt/model/ccv_model.qnt b/tests/mbt/model/ccv_model.qnt
index 4bb368ae3f..4c95738947 100644
--- a/tests/mbt/model/ccv_model.qnt
+++ b/tests/mbt/model/ccv_model.qnt
@@ -13,7 +13,7 @@ module ccv_model {
pure val unbondingPeriods = chains.mapBy(chain => defUnbondingPeriod)
pure val trustingPeriods = chains.mapBy(chain => defUnbondingPeriod - 1 * Hour)
pure val ccvTimeouts = chains.mapBy(chain => 3 * Week)
- pure val epochLength = 3
+ pure val epochLength = 1
pure val nodes = Set("node1", "node2", "node3", "node4", "node5", "node6", "node7", "node8", "node9", "node10")
// possible consumer addresses that nodes can assign their key to
diff --git a/tests/mbt/model/ccv_pss_model.qnt b/tests/mbt/model/ccv_pss_model.qnt
index d2911a0989..a2ff82af3e 100644
--- a/tests/mbt/model/ccv_pss_model.qnt
+++ b/tests/mbt/model/ccv_pss_model.qnt
@@ -40,8 +40,9 @@ module ccv_pss_model {
action OptOut_Deterministic(consumer: Chain, validator: Node): bool = {
val res = OptOut(currentState, consumer, validator)
- all {
- currentState' = res.newState,
+ all {
+ // since we sometimes get expected errors here, we need to rollback to the current state if that is the case
+ currentState' = if (res.error == "") res.newState else currentState,
trace' = trace.append(
{
...emptyAction,