package consensus import ( "testing" "github.com/harmony-one/harmony/p2p/p2pimpl" consensus_proto "github.com/harmony-one/harmony/api/consensus" "github.com/harmony-one/harmony/crypto" "github.com/harmony-one/harmony/crypto/pki" "github.com/harmony-one/harmony/p2p" ) func TestConstructAnnounceMessage(test *testing.T) { leader := p2p.Peer{IP: "1", Port: "2"} validator := p2p.Peer{IP: "3", Port: "5"} host := p2pimpl.NewHost(leader) consensus := New(host, "0", []p2p.Peer{leader, validator}, leader) consensus.blockHash = [32]byte{} msg := consensus.constructAnnounceMessage() if len(msg) != 105 { test.Errorf("Annouce message is not constructed in the correct size: %d", len(msg)) } } func TestConstructChallengeMessage(test *testing.T) { leaderPriKey := crypto.Ed25519Curve.Scalar() priKeyInBytes := crypto.HashSha256("12") leaderPriKey.UnmarshalBinary(priKeyInBytes[:]) leaderPubKey := pki.GetPublicKeyFromScalar(leaderPriKey) leader := p2p.Peer{IP: "1", Port: "2", PubKey: leaderPubKey} validatorPriKey := crypto.Ed25519Curve.Scalar() priKeyInBytes = crypto.HashSha256("12") validatorPriKey.UnmarshalBinary(priKeyInBytes[:]) validatorPubKey := pki.GetPublicKeyFromScalar(leaderPriKey) validator := p2p.Peer{IP: "3", Port: "5", PubKey: validatorPubKey} host := p2pimpl.NewHost(leader) consensus := New(host, "0", []p2p.Peer{leader, validator}, leader) consensus.blockHash = [32]byte{} (*consensus.commitments)[0] = leaderPubKey (*consensus.commitments)[1] = validatorPubKey consensus.bitmap.SetKey(leaderPubKey, true) consensus.bitmap.SetKey(validatorPubKey, true) msg, _, _ := consensus.constructChallengeMessage(consensus_proto.MessageType_CHALLENGE) if len(msg) != 205 { test.Errorf("Challenge message is not constructed in the correct size: %d", len(msg)) } }