consensus: sign and verify consensus messages
This commit is contained in:
parent
765c354793
commit
138c94eda3
2 changed files with 79 additions and 1 deletions
|
@ -179,7 +179,10 @@ func getKeyPair(cfg *config.WalletConfig) (crypto.PrivateKey, crypto.PublicKey)
|
||||||
|
|
||||||
// OnPayload handles Payload receive.
|
// OnPayload handles Payload receive.
|
||||||
func (s *service) OnPayload(cp *Payload) {
|
func (s *service) OnPayload(cp *Payload) {
|
||||||
if s.cache.Has(cp.Hash()) {
|
if !cp.Verify() {
|
||||||
|
s.log.Debug("can't verify payload from #%d", cp.validatorIndex)
|
||||||
|
return
|
||||||
|
} else if s.cache.Has(cp.Hash()) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -224,6 +227,10 @@ func (s *service) broadcast(p payload.ConsensusPayload) {
|
||||||
pr.minerTx = *s.txx.Get(pr.transactionHashes[0]).(*transaction.Transaction)
|
pr.minerTx = *s.txx.Get(pr.transactionHashes[0]).(*transaction.Transaction)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := p.(*Payload).Sign(s.dbft.Priv.(*privateKey)); err != nil {
|
||||||
|
s.log.Warnf("can't sign consensus payload: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
s.cache.Add(p)
|
s.cache.Add(p)
|
||||||
s.Config.Broadcast(p.(*Payload))
|
s.Config.Broadcast(p.(*Payload))
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,45 @@ func TestNewService(t *testing.T) {
|
||||||
require.Equal(t, tx, txx[1])
|
require.Equal(t, tx, txx[1])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestService_OnPayload(t *testing.T) {
|
||||||
|
srv := newTestService(t)
|
||||||
|
|
||||||
|
priv, _ := getTestValidator(1)
|
||||||
|
p := new(Payload)
|
||||||
|
p.SetValidatorIndex(1)
|
||||||
|
p.SetPayload(&prepareRequest{})
|
||||||
|
|
||||||
|
// payload is not signed
|
||||||
|
srv.OnPayload(p)
|
||||||
|
shouldNotReceive(t, srv.messages)
|
||||||
|
require.Nil(t, srv.GetPayload(p.Hash()))
|
||||||
|
|
||||||
|
require.NoError(t, p.Sign(priv))
|
||||||
|
srv.OnPayload(p)
|
||||||
|
shouldReceive(t, srv.messages)
|
||||||
|
require.Equal(t, p, srv.GetPayload(p.Hash()))
|
||||||
|
|
||||||
|
// payload has already been received
|
||||||
|
srv.OnPayload(p)
|
||||||
|
shouldNotReceive(t, srv.messages)
|
||||||
|
}
|
||||||
|
|
||||||
|
func shouldReceive(t *testing.T, ch chan Payload) {
|
||||||
|
select {
|
||||||
|
case <-ch:
|
||||||
|
default:
|
||||||
|
require.Fail(t, "missing expected message")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func shouldNotReceive(t *testing.T, ch chan Payload) {
|
||||||
|
select {
|
||||||
|
case <-ch:
|
||||||
|
require.Fail(t, "unexpected message receive")
|
||||||
|
default:
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func newTestService(t *testing.T) *service {
|
func newTestService(t *testing.T) *service {
|
||||||
srv, err := NewService(Config{
|
srv, err := NewService(Config{
|
||||||
Broadcast: func(*Payload) {},
|
Broadcast: func(*Payload) {},
|
||||||
|
@ -42,6 +81,38 @@ func newTestService(t *testing.T) *service {
|
||||||
return srv.(*service)
|
return srv.(*service)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getTestValidator(i int) (*privateKey, *publicKey) {
|
||||||
|
var wallet *config.WalletConfig
|
||||||
|
switch i {
|
||||||
|
case 0:
|
||||||
|
wallet = &config.WalletConfig{
|
||||||
|
Path: "6PYLmjBYJ4wQTCEfqvnznGJwZeW9pfUcV5m5oreHxqryUgqKpTRAFt9L8Y",
|
||||||
|
Password: "one",
|
||||||
|
}
|
||||||
|
case 1:
|
||||||
|
wallet = &config.WalletConfig{
|
||||||
|
Path: "6PYXHjPaNvW8YknSXaKsTWjf9FRxo1s4naV2jdmSQEgzaqKGX368rndN3L",
|
||||||
|
Password: "two",
|
||||||
|
}
|
||||||
|
case 2:
|
||||||
|
wallet = &config.WalletConfig{
|
||||||
|
Path: "6PYX86vYiHfUbpD95hfN1xgnvcSxy5skxfWYKu3ztjecxk6ikYs2kcWbeh",
|
||||||
|
Password: "three",
|
||||||
|
}
|
||||||
|
case 3:
|
||||||
|
wallet = &config.WalletConfig{
|
||||||
|
Path: "6PYRXVwHSqFSukL3CuXxdQ75VmsKpjeLgQLEjt83FrtHf1gCVphHzdD4nc",
|
||||||
|
Password: "four",
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
priv, pub := getKeyPair(wallet)
|
||||||
|
|
||||||
|
return priv.(*privateKey), pub.(*publicKey)
|
||||||
|
}
|
||||||
|
|
||||||
func newTestChain(t *testing.T) *core.Blockchain {
|
func newTestChain(t *testing.T) *core.Blockchain {
|
||||||
unitTestNetCfg, err := config.Load("../../config", config.ModeUnitTestNet)
|
unitTestNetCfg, err := config.Load("../../config", config.ModeUnitTestNet)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
Loading…
Reference in a new issue