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

p2p, add Block Announce Network Message #296

Merged
merged 8 commits into from
Sep 18, 2019
28 changes: 28 additions & 0 deletions p2p/message.go
Original file line number Diff line number Diff line change
Expand Up @@ -256,6 +256,33 @@ func (bm *BlockRequestMessage) Decode(r io.Reader) error {
return nil
}


edwardmack marked this conversation as resolved.
Show resolved Hide resolved
type BlockHeaderMessage common.BlockHeader

// string formats a BlockHeaderMessage as a string
func (bhm *BlockHeaderMessage) String() string {
return fmt.Sprintf("BlockHeaderMessage ParentHash=0x%x Number=%d StateRoot=0x%x ExtrinsicsRoot=0x%x Digest=0x%x",
bhm.ParentHash,
bhm.Number,
bhm.StateRoot,
bhm.ExtrinsicsRoot,
bhm.Digest)
}

func (bhm *BlockHeaderMessage) Encode() ([]byte, error) {
enc, err := scale.Encode(bhm)
if err != nil {
return enc, err
}
return append([]byte{BlockAnnounceMsg}, enc...), nil
edwardmack marked this conversation as resolved.
Show resolved Hide resolved
}

//Decodes the message into a BlockHeaderMessage, it assumes the type byte has been removed
func (bhm *BlockHeaderMessage) Decode(msg []byte) error {
_, err := scale.Decode(msg, bhm)
return err
}

type BlockResponseMessage struct {
Id uint64
Data []byte // TODO: change this to BlockData type
Expand Down Expand Up @@ -333,4 +360,5 @@ func readHash(r io.Reader) (common.Hash, error) {
h := [32]byte{}
copy(h[:], buf)
return common.Hash(h), nil

}
96 changes: 90 additions & 6 deletions p2p/message_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ package p2p

import (
"bytes"
"math/big"
"reflect"
"testing"

Expand Down Expand Up @@ -340,11 +341,12 @@ func TestEncodeBlockRequestMessage_NoOptionals(t *testing.T) {

func TestDecodeBlockRequestMessage_NoOptionals(t *testing.T) {
encMsg, err := common.HexToBytes("0x0107000000000000000100dcd1346701ca8396496e52aa2785b1748deb6db09551b72159dcb3e08991025b000100")

if err != nil {
t.Fatal(err)
}
}
edwardmack marked this conversation as resolved.
Show resolved Hide resolved

buf := &bytes.Buffer{}
buf := &bytes.Buffer{}
buf.Write(encMsg)

m, err := DecodeMessage(buf)
Expand All @@ -371,13 +373,14 @@ func TestDecodeBlockRequestMessage_NoOptionals(t *testing.T) {
t.Fatalf("Fail: got %v expected %v", bm, expected)
}
}

func TestEncodeBlockResponseMessage(t *testing.T) {
expected, err := common.HexToBytes("0x02070000000000000000")

if err != nil {
t.Fatal(err)
}

bm := &BlockResponseMessage{
Id: 7,
Data: []byte{0},
Expand All @@ -392,13 +395,13 @@ func TestEncodeBlockResponseMessage(t *testing.T) {
t.Fatalf("Fail: got %x expected %x", encMsg, expected)
}
}

func TestDecodeBlockResponseMessage(t *testing.T) {
encMsg, err := common.HexToBytes("0x070000000000000000")
if err != nil {
t.Fatal(err)
}

buf := &bytes.Buffer{}
buf.Write(encMsg)

Expand All @@ -417,3 +420,84 @@ func TestDecodeBlockResponseMessage(t *testing.T) {
t.Fatalf("Fail: got %v expected %v", m, expected)
}
}

func TestEncodeBlockAnnounceMessage(t *testing.T) {
// this value is a concatenation of:
// message type: byte(3)
// ParentHash: Hash: 0x4545454545454545454545454545454545454545454545454545454545454545
// Number: *big.Int // block number: 1
// StateRoot: Hash: 0xb3266de137d20a5d0ff3a6401eb57127525fd9b2693701f0bf5a8a853fa3ebe0
// ExtrinsicsRoot: Hash: 0x03170a2e7597b7b7e3d84c05391d139a62b157e78786d8c082f29dcf4c111314
// Digest: []byte

// mtparenthash bnstateroot extrinsicsroot di
expected, err := common.HexToBytes("0x03454545454545454545454545454545454545454545454545454545454545454504b3266de137d20a5d0ff3a6401eb57127525fd9b2693701f0bf5a8a853fa3ebe003170a2e7597b7b7e3d84c05391d139a62b157e78786d8c082f29dcf4c11131400")
if err != nil {
t.Fatal(err)
}

parentHash, err := common.HexToHash("0x4545454545454545454545454545454545454545454545454545454545454545")
if err != nil {
t.Fatal(err)
}
stateRoot, err := common.HexToHash("0xb3266de137d20a5d0ff3a6401eb57127525fd9b2693701f0bf5a8a853fa3ebe0")
if err != nil {
t.Fatal(err)
}
extrinsicsRoot, err := common.HexToHash("0x03170a2e7597b7b7e3d84c05391d139a62b157e78786d8c082f29dcf4c111314")
if err != nil {
t.Fatal(err)
}

bhm := &BlockHeaderMessage{
ParentHash: parentHash,
Number: big.NewInt(1),
StateRoot: stateRoot,
ExtrinsicsRoot: extrinsicsRoot,
Digest: []byte{},
}
encMsg, err := bhm.Encode()
edwardmack marked this conversation as resolved.
Show resolved Hide resolved
if err != nil {
t.Fatal(err)
}
if !bytes.Equal(encMsg, expected) {
t.Fatalf("Fail: got %x expected %x", encMsg, expected)
}
}

func TestDecodeBlockAnnounceMessage(t *testing.T) {
announceMessage, err := common.HexToBytes("0x454545454545454545454545454545454545454545454545454545454545454504b3266de137d20a5d0ff3a6401eb57127525fd9b2693701f0bf5a8a853fa3ebe003170a2e7597b7b7e3d84c05391d139a62b157e78786d8c082f29dcf4c11131400")
if err != nil {
t.Fatal(err)
}

bhm := new(BlockHeaderMessage)
err = bhm.Decode(announceMessage)
if err != nil {
t.Fatal(err)
}

parentHash, err := common.HexToHash("0x4545454545454545454545454545454545454545454545454545454545454545")
if err != nil {
t.Fatal(err)
}
stateRoot, err := common.HexToHash("0xb3266de137d20a5d0ff3a6401eb57127525fd9b2693701f0bf5a8a853fa3ebe0")
if err != nil {
t.Fatal(err)
}
extrinsicsRoot, err := common.HexToHash("0x03170a2e7597b7b7e3d84c05391d139a62b157e78786d8c082f29dcf4c111314")
if err != nil {
t.Fatal(err)
}
expected := &BlockHeaderMessage{
ParentHash: parentHash,
Number: big.NewInt(1),
StateRoot: stateRoot,
ExtrinsicsRoot: extrinsicsRoot,
Digest: []byte{},
}

if !reflect.DeepEqual(bhm, expected) {
t.Fatalf("Fail: got %v expected %v", bhm, expected)
}
}