Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merge Signer-indices to master #2414

Merged
merged 60 commits into from
May 24, 2022
Merged
Show file tree
Hide file tree
Changes from 55 commits
Commits
Show all changes
60 commits
Select commit Hold shift + click to select a range
fba427f
[Consensus] SignerIndices Optimization Interface changes (1/4) (#2047)
zhangchiqing Mar 30, 2022
691a2f1
fix test cases
zhangchiqing Mar 30, 2022
fa56b80
update flow dep
zhangchiqing Mar 30, 2022
36294d5
fix rpc convert
zhangchiqing Mar 30, 2022
2c24ca4
update go.mod
zhangchiqing Mar 30, 2022
99a8575
fix go.mod
zhangchiqing Mar 30, 2022
2053d82
fix testnet network
zhangchiqing Mar 30, 2022
c4dd437
Merge branch 'master' into leo/master-to-signer-indices-feature
zhangchiqing Apr 28, 2022
d1baa6e
update mocks
zhangchiqing Apr 28, 2022
8139d22
upgrade flow
zhangchiqing Apr 28, 2022
873099a
update mock
zhangchiqing Apr 28, 2022
8c77f49
update go.sum
zhangchiqing Apr 28, 2022
41ccd19
Merge branch 'leo/fix-linting' into leo/master-to-signer-indices-feature
zhangchiqing Apr 28, 2022
5ce0236
Merge branch 'master' into leo/master-to-signer-indices-feature
zhangchiqing Apr 29, 2022
51318c5
fix hotstuff integration tests
zhangchiqing Apr 29, 2022
7cf0f88
fix integration test
zhangchiqing Apr 29, 2022
32463bf
Merge branch 'master' into leo/master-to-signer-indices-feature
zhangchiqing Apr 30, 2022
8de941d
upgrade onflow/flow package to v0.3.0 (#2377)
zhangchiqing May 9, 2022
affb9a5
add checksum
zhangchiqing May 2, 2022
76713fe
add checksum to signer indices
zhangchiqing May 2, 2022
251789d
fix execution tests
zhangchiqing May 2, 2022
4114d56
fix execution tests
zhangchiqing May 3, 2022
24410c1
adding comments
zhangchiqing May 5, 2022
f20898f
fix ingestion tests
zhangchiqing May 5, 2022
31c56b3
fix access tests
zhangchiqing May 5, 2022
d82f6cb
fix access tests
zhangchiqing May 5, 2022
fa8193f
fix access tests
zhangchiqing May 5, 2022
0d01da9
fix integration test
zhangchiqing May 5, 2022
0226b3c
add validation
zhangchiqing May 5, 2022
59c52db
fix consensus integration tests
zhangchiqing May 5, 2022
e279846
fix flakey tests
zhangchiqing May 5, 2022
e8ccf87
adding checks
zhangchiqing May 6, 2022
355775a
fix flakey tests
zhangchiqing May 6, 2022
c7bde01
fix check
zhangchiqing May 6, 2022
709b0ca
fix order
zhangchiqing May 6, 2022
6b1a50c
fix sort
zhangchiqing May 6, 2022
0dd51d4
use crc32 to compute checksum
zhangchiqing May 6, 2022
7451114
use canonical order
zhangchiqing May 6, 2022
1d0b753
fix qc_test
zhangchiqing May 6, 2022
055327a
Apply suggestions from code review
zhangchiqing May 6, 2022
0eb280b
update comments
zhangchiqing May 9, 2022
6d83b4e
use BigEndian.PutUint32
zhangchiqing May 10, 2022
08aff0a
Merge #2362
bors[bot] May 10, 2022
b8c2c9b
improve signer indices logging
zhangchiqing May 12, 2022
5eb12d4
Merge #2408
bors[bot] May 12, 2022
23e7e5d
Merge branch 'master' into leo/merge-master-to-signer-indices-optimiz…
zhangchiqing May 12, 2022
b6de8f8
remove util
zhangchiqing May 12, 2022
3e034ef
Merge branch 'master' into leo/feature-signer-indices-to-master
zhangchiqing May 16, 2022
7249a4e
fixed typos (#2443)
May 18, 2022
f36d7c9
address review comments
zhangchiqing May 18, 2022
fda964a
Merge branch 'master' into leo/feature-signer-indices-to-master
zhangchiqing May 18, 2022
6f2b4ad
lint
zhangchiqing May 18, 2022
63572fc
fix comment
zhangchiqing May 18, 2022
b1aabcc
update tests for validPadding
zhangchiqing May 18, 2022
c2a44a7
refactor validPadding
zhangchiqing May 18, 2022
eb26b6c
adding comments
zhangchiqing May 19, 2022
63c6be2
Merge branch 'master' into leo/feature-signer-indices-to-master
zhangchiqing May 19, 2022
b8c997a
Merge branch 'master' into leo/feature-signer-indices-to-master
zhangchiqing May 20, 2022
22d4293
comments
zhangchiqing May 20, 2022
9de4d61
fix function renaming
zhangchiqing May 20, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 8 additions & 4 deletions cmd/bootstrap/cmd/clusters.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ import (
model "github.com/onflow/flow-go/model/bootstrap"
"github.com/onflow/flow-go/model/cluster"
"github.com/onflow/flow-go/model/flow"
"github.com/onflow/flow-go/model/flow/assignment"
"github.com/onflow/flow-go/model/flow/factory"
"github.com/onflow/flow-go/model/flow/filter"
)

Expand All @@ -23,20 +25,22 @@ func constructClusterAssignment(partnerNodes, internalNodes []model.NodeInfo, se
internals = internals.DeterministicShuffle(seed)

nClusters := flagCollectionClusters
assignments := make(flow.AssignmentList, nClusters)
identifierLists := make([]flow.IdentifierList, nClusters)

// first, round-robin internal nodes into each cluster
for i, node := range internals {
assignments[i%len(assignments)] = append(assignments[i%len(assignments)], node.NodeID)
identifierLists[i%len(identifierLists)] = append(identifierLists[i%len(identifierLists)], node.NodeID)
}

// next, round-robin partner nodes into each cluster
for i, node := range partners {
assignments[i%len(assignments)] = append(assignments[i%len(assignments)], node.NodeID)
identifierLists[i%len(identifierLists)] = append(identifierLists[i%len(identifierLists)], node.NodeID)
}

assignments := assignment.FromIdentifierLists(identifierLists)

collectors := append(partners, internals...)
clusters, err := flow.NewClusterList(assignments, collectors)
clusters, err := factory.NewClusterList(assignments, collectors)
if err != nil {
log.Fatal().Err(err).Msg("could not create cluster list")
}
Expand Down
18 changes: 17 additions & 1 deletion cmd/bootstrap/cmd/seal.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (
"github.com/onflow/flow-go/model/dkg"
"github.com/onflow/flow-go/model/flow"
"github.com/onflow/flow-go/model/flow/order"
"github.com/onflow/flow-go/module/signature"
)

func constructRootResultAndSeal(
Expand Down Expand Up @@ -43,9 +44,24 @@ func constructRootResultAndSeal(
RandomSource: flagBootstrapRandomSeed,
}

qcsWithSignerIDs := make([]*flow.QuorumCertificateWithSignerIDs, 0, len(clusterQCs))
for i, clusterQC := range clusterQCs {
members := assignments[i]
signerIDs, err := signature.DecodeSignerIndicesToIdentifiers(members, clusterQC.SignerIndices)
if err != nil {
log.Fatal().Err(err).Msgf("could not decode signer IDs from clusterQC at index %v", i)
}
qcsWithSignerIDs = append(qcsWithSignerIDs, &flow.QuorumCertificateWithSignerIDs{
View: clusterQC.View,
BlockID: clusterQC.BlockID,
SignerIDs: signerIDs,
SigData: clusterQC.SigData,
})
}

epochCommit := &flow.EpochCommit{
Counter: flagEpochCounter,
ClusterQCs: flow.ClusterQCVoteDatasFromQCs(clusterQCs),
ClusterQCs: flow.ClusterQCVoteDatasFromQCs(qcsWithSignerIDs),
DKGGroupKey: dkgData.PubGroupKey,
DKGParticipantKeys: dkgData.PubKeyShares,
}
Expand Down
2 changes: 1 addition & 1 deletion cmd/bootstrap/run/block.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ func GenerateRootBlock(chainID flow.ChainID, parentID flow.Identifier, height ui
PayloadHash: payload.Hash(),
Timestamp: timestamp,
View: 0,
ParentVoterIDs: nil,
ParentVoterIndices: nil,
ParentVoterSigData: nil,
ProposerID: flow.ZeroID,
ProposerSigData: nil,
Expand Down
4 changes: 3 additions & 1 deletion cmd/bootstrap/run/cluster_qc.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import (
"github.com/onflow/flow-go/model/bootstrap"
"github.com/onflow/flow-go/model/cluster"
"github.com/onflow/flow-go/model/flow"
"github.com/onflow/flow-go/model/flow/order"
"github.com/onflow/flow-go/module/local"
)

Expand All @@ -29,7 +30,8 @@ func GenerateClusterRootQC(signers []bootstrap.NodeInfo, allCommitteeMembers flo
}

// STEP 2: create VoteProcessor
committee, err := committees.NewStaticCommittee(allCommitteeMembers, flow.Identifier{}, nil, nil)
ordered := allCommitteeMembers.Sort(order.Canonical)
committee, err := committees.NewStaticCommittee(ordered, flow.Identifier{}, nil, nil)
if err != nil {
return nil, err
}
Expand Down
3 changes: 2 additions & 1 deletion cmd/bootstrap/run/qc_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import (
"github.com/onflow/flow-go/crypto"
"github.com/onflow/flow-go/model/bootstrap"
"github.com/onflow/flow-go/model/flow"
"github.com/onflow/flow-go/model/flow/order"
"github.com/onflow/flow-go/module/signature"
"github.com/onflow/flow-go/utils/unittest"
)
Expand All @@ -32,7 +33,7 @@ func TestGenerateRootQC(t *testing.T) {
}

func createSignerData(t *testing.T, n int) *ParticipantData {
identities := unittest.IdentityListFixture(n)
identities := unittest.IdentityListFixture(n).Sort(order.Canonical)

networkingKeys := unittest.NetworkingKeys(n)
stakingKeys := unittest.StakingKeys(n)
Expand Down
4 changes: 2 additions & 2 deletions cmd/util/cmd/epochs/cmd/reset_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ func TestReset_LocalSnapshot(t *testing.T) {
unittest.RunWithTempDir(t, func(bootDir string) {

// create a root snapshot
rootSnapshot := unittest.RootSnapshotFixture(unittest.IdentityListFixture(10))
rootSnapshot := unittest.RootSnapshotFixture(unittest.IdentityListFixture(10, unittest.WithAllRoles()))

// write snapshot to correct path in bootDir
err := writeRootSnapshot(bootDir, rootSnapshot)
Expand Down Expand Up @@ -62,7 +62,7 @@ func TestReset_LocalSnapshot(t *testing.T) {
unittest.RunWithTempDir(t, func(bootDir string) {

// create a root snapshot
rootSnapshot := unittest.RootSnapshotFixture(unittest.IdentityListFixture(10))
rootSnapshot := unittest.RootSnapshotFixture(unittest.IdentityListFixture(10, unittest.WithAllRoles()))

// write snapshot to correct path in bootDir
err := writeRootSnapshot(bootDir, rootSnapshot)
Expand Down
38 changes: 17 additions & 21 deletions cmd/util/cmd/exec-data-json-export/block_exporter.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,12 @@ import (
)

type blockSummary struct {
BlockHeight uint64 `json:"block_height"`
BlockID string `json:"block_id"`
ParentBlockID string `json:"parent_block_id"`
ParentVoterIDs []string `json:"parent_voter_ids"`
// ParentVoterSigData []string `json:"parent_voter_sig"`
ProposerID string `json:"proposer_id"`
BlockHeight uint64 `json:"block_height"`
BlockID string `json:"block_id"`
ParentBlockID string `json:"parent_block_id"`
ParentVoterIndices string `json:"parent_voter_indices"`
ParentVoterSigData string `json:"parent_voter_sig"`
ProposerID string `json:"proposer_id"`
// ProposerSigData string `json:"proposer_sig"`
Timestamp time.Time `json:"timestamp"`
CollectionIDs []string `json:"collection_ids"`
Expand Down Expand Up @@ -87,22 +87,18 @@ func ExportBlocks(blockID flow.Identifier, dbPath string, outputPath string) (fl
sealsStates = append(sealsStates, hex.EncodeToString(s.FinalState[:]))
}

pvIDs := make([]string, 0)
for _, i := range header.ParentVoterIDs {
pvIDs = append(pvIDs, hex.EncodeToString(i[:]))
}

b := blockSummary{
BlockID: hex.EncodeToString(activeBlockID[:]),
BlockHeight: header.Height,
ParentBlockID: hex.EncodeToString(header.ParentID[:]),
ParentVoterIDs: pvIDs,
ProposerID: hex.EncodeToString(header.ProposerID[:]),
Timestamp: header.Timestamp,
CollectionIDs: cols,
SealedBlocks: seals,
SealedResults: sealsResults,
SealedFinalStates: sealsStates,
BlockID: hex.EncodeToString(activeBlockID[:]),
BlockHeight: header.Height,
ParentBlockID: hex.EncodeToString(header.ParentID[:]),
ParentVoterIndices: hex.EncodeToString(header.ParentVoterIndices),
ParentVoterSigData: hex.EncodeToString(header.ParentVoterSigData),
ProposerID: hex.EncodeToString(header.ProposerID[:]),
Timestamp: header.Timestamp,
CollectionIDs: cols,
SealedBlocks: seals,
SealedResults: sealsResults,
SealedFinalStates: sealsStates,
}

jsonData, err := json.Marshal(b)
Expand Down
20 changes: 13 additions & 7 deletions consensus/follower_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ import (
"testing"
"time"

"github.com/onflow/flow-go/module/signature"

"github.com/rs/zerolog"
"github.com/stretchr/testify/mock"
"github.com/stretchr/testify/require"
Expand Down Expand Up @@ -68,9 +70,9 @@ func (s *HotStuffFollowerSuite) SetupTest() {

// mock consensus committee
s.committee = &mockhotstuff.Committee{}
s.committee.On("Identities", mock.Anything, mock.Anything).Return(
func(blockID flow.Identifier, selector flow.IdentityFilter) flow.IdentityList {
return identities.Filter(selector)
s.committee.On("Identities", mock.Anything).Return(
func(blockID flow.Identifier) flow.IdentityList {
return identities
},
nil,
)
Expand Down Expand Up @@ -105,10 +107,13 @@ func (s *HotStuffFollowerSuite) SetupTest() {
Height: 21053,
View: 52078,
}

signerIndices, err := signature.EncodeSignersToIndices(identities.NodeIDs(), identities.NodeIDs()[:3])
require.NoError(s.T(), err)
s.rootQC = &flow.QuorumCertificate{
View: s.rootHeader.View,
BlockID: s.rootHeader.ID(),
SignerIDs: identities.NodeIDs()[:3],
View: s.rootHeader.View,
BlockID: s.rootHeader.ID(),
SignerIndices: signerIndices,
}

// we start with the latest finalized block being the root block
Expand Down Expand Up @@ -335,6 +340,7 @@ func (mc *MockConsensus) extendBlock(blockView uint64, parent *flow.Header) *flo
nextBlock := unittest.BlockHeaderWithParentFixture(parent)
nextBlock.View = blockView
nextBlock.ProposerID = mc.identities[int(blockView)%len(mc.identities)].NodeID
nextBlock.ParentVoterIDs = mc.identities.NodeIDs()
signerIndices, _ := signature.EncodeSignersToIndices(mc.identities.NodeIDs(), mc.identities.NodeIDs())
nextBlock.ParentVoterIndices = signerIndices
return &nextBlock
}
2 changes: 1 addition & 1 deletion consensus/hotstuff/blockproducer/block_producer.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ func (bp *BlockProducer) MakeBlockProposal(qc *flow.QuorumCertificate, view uint
// in hotstuff, we use this for view number and signature-related fields
setHotstuffFields := func(header *flow.Header) error {
header.View = view
header.ParentVoterIDs = qc.SignerIDs
header.ParentVoterIndices = qc.SignerIndices
header.ParentVoterSigData = qc.SigData
header.ProposerID = bp.committee.Self()

Expand Down
8 changes: 3 additions & 5 deletions consensus/hotstuff/committee.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import (
)

// Committee accounts for the fact that we might have multiple HotStuff instances
// (collector committees and main consensus committee). Each hostuff instance is supposed to
// (collector committees and main consensus committee). Each HotStuff instance is supposed to
// have a dedicated Committee state.
// A Committee provides subset of the protocol.State, which is restricted to exactly those
// nodes that participate in the current HotStuff instance: the state of all legitimate HotStuff
Expand All @@ -17,14 +17,12 @@ import (
// Given a collector block, some logic is required to find the main consensus block
// for determining the valid collector-HotStuff participants.
type Committee interface {

// Identities returns a IdentityList with legitimate HotStuff participants for the specified block.
// The list of participants is filtered by the provided selector. The returned list of HotStuff participants
// The returned list of HotStuff participants
// * contains nodes that are allowed to sign the specified block (legitimate participants with NON-ZERO WEIGHT)
// * is ordered in the canonical order
// * contains no duplicates.
// The list of all legitimate HotStuff participants for the specified block can be obtained by using `filter.Any`
Identities(blockID flow.Identifier, selector flow.IdentityFilter) (flow.IdentityList, error)
Identities(blockID flow.Identifier) (flow.IdentityList, error)

// Identity returns the full Identity for specified HotStuff participant.
// The node must be a legitimate HotStuff participant with NON-ZERO WEIGHT at the specified block.
Expand Down
16 changes: 9 additions & 7 deletions consensus/hotstuff/committees/cluster_committee.go
Original file line number Diff line number Diff line change
Expand Up @@ -61,8 +61,12 @@ func NewClusterCommittee(
return com, nil
}

func (c *Cluster) Identities(blockID flow.Identifier, selector flow.IdentityFilter) (flow.IdentityList, error) {

// Identities returns the identities of all cluster members that are authorized to
// participate at the given block. The order of the identities is the canonical order.
func (c *Cluster) Identities(blockID flow.Identifier) (flow.IdentityList, error) {
// blockID is a collection block not a block produced by consensus,
// to query the identities from protocol state, we need to use the reference block id from the payload
//
// first retrieve the cluster block payload
payload, err := c.payloads.ByBlockID(blockID)
if err != nil {
Expand All @@ -74,14 +78,12 @@ func (c *Cluster) Identities(blockID flow.Identifier, selector flow.IdentityFilt

// use the initial cluster members for root block
if isRootBlock {
return c.initialClusterMembers.Filter(selector), nil
return c.initialClusterMembers, nil
}

// otherwise use the snapshot given by the reference block
identities, err := c.state.AtBlockID(payload.ReferenceBlockID).Identities(filter.And(
selector,
c.clusterMemberFilter,
))
identities, err := c.state.AtBlockID(payload.ReferenceBlockID).Identities(c.clusterMemberFilter) // remove ejected nodes

return identities, err
}

Expand Down
9 changes: 4 additions & 5 deletions consensus/hotstuff/committees/consensus_committee.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,11 +68,10 @@ func NewConsensusCommittee(state protocol.State, me flow.Identifier) (*Consensus
return com, nil
}

func (c *Consensus) Identities(blockID flow.Identifier, selector flow.IdentityFilter) (flow.IdentityList, error) {
il, err := c.state.AtBlockID(blockID).Identities(filter.And(
filter.IsVotingConsensusCommitteeMember,
selector,
))
// Identities returns the identities of all authorized consensus participants at the given block.
// The order of the identities is the canonical order.
func (c *Consensus) Identities(blockID flow.Identifier) (flow.IdentityList, error) {
il, err := c.state.AtBlockID(blockID).Identities(filter.IsVotingConsensusCommitteeMember)
return il, err
}

Expand Down
Loading