Skip to content
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
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
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
}


Comment thread
edwardmack marked this conversation as resolved.
Outdated
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{BlockAnnounceMsgType}, enc...), nil
}

//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)
}
}
Comment thread
edwardmack marked this conversation as resolved.
Outdated

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()
Comment thread
edwardmack marked this conversation as 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)
}
}