-
-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathmsg_get_cfheaders_test.go
More file actions
92 lines (74 loc) · 2.96 KB
/
msg_get_cfheaders_test.go
File metadata and controls
92 lines (74 loc) · 2.96 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
package wire
import (
"bytes"
"io"
"testing"
"github.com/bsv-blockchain/go-bt/v2/chainhash"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
// TestNewMsgGetCFHeadersSetsFields ensures the constructor initializes all fields.
func TestNewMsgGetCFHeadersSetsFields(t *testing.T) {
stopHash, err := chainhash.NewHashFromStr("0102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f")
require.NoError(t, err)
msg := NewMsgGetCFHeaders(GCSFilterRegular, 5, stopHash)
assert.Equal(t, GCSFilterRegular, msg.FilterType)
assert.Equal(t, uint32(5), msg.StartHeight)
assert.True(t, msg.StopHash.IsEqual(stopHash))
}
// TestMsgGetCFHeadersCommand verifies the command string matches the spec.
func TestMsgGetCFHeadersCommand(t *testing.T) {
msg := NewMsgGetCFHeaders(GCSFilterRegular, 0, &chainhash.Hash{})
assert.Equal(t, CmdGetCFHeaders, msg.Command())
}
// TestMsgGetCFHeadersMaxPayloadLength checks the payload size is fixed.
func TestMsgGetCFHeadersMaxPayloadLength(t *testing.T) {
msg := NewMsgGetCFHeaders(GCSFilterRegular, 0, &chainhash.Hash{})
expected := uint64(1 + 4 + chainhash.HashSize)
assert.Equal(t, expected, msg.MaxPayloadLength(ProtocolVersion))
}
// TestMsgGetCFHeadersEncodeDecode exercises encode/decode round trips.
func TestMsgGetCFHeadersEncodeDecode(t *testing.T) {
stopHash, err := chainhash.NewHashFromStr("ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff")
require.NoError(t, err)
msg := NewMsgGetCFHeaders(GCSFilterRegular, 100, stopHash)
var buf bytes.Buffer
require.NoError(t, msg.BsvEncode(&buf, ProtocolVersion, BaseEncoding))
var expected bytes.Buffer
require.NoError(t, writeElement(&expected, msg.FilterType))
require.NoError(t, writeElement(&expected, &msg.StartHeight))
require.NoError(t, writeElement(&expected, &msg.StopHash))
assert.Equal(t, expected.Bytes(), buf.Bytes())
var decoded MsgGetCFHeaders
require.NoError(t, decoded.Bsvdecode(bytes.NewReader(buf.Bytes()), ProtocolVersion, BaseEncoding))
assert.Equal(t, msg, &decoded)
}
// TestMsgGetCFHeadersWireErrors verifies error paths during encode and decode.
func TestMsgGetCFHeadersWireErrors(t *testing.T) {
stopHash := &chainhash.Hash{}
baseMsg := NewMsgGetCFHeaders(GCSFilterRegular, 1, stopHash)
var baseBuf bytes.Buffer
require.NoError(t, baseMsg.BsvEncode(&baseBuf, ProtocolVersion, BaseEncoding))
encoded := baseBuf.Bytes()
tests := []struct {
name string
max int
writeErr error
readErr error
}{
{"filter type", 0, io.ErrShortWrite, io.EOF},
{"start height", 1, io.ErrShortWrite, io.EOF},
{"stop hash", 5, io.ErrShortWrite, io.EOF},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
w := newFixedWriter(tt.max)
err := baseMsg.BsvEncode(w, ProtocolVersion, BaseEncoding)
require.ErrorIs(t, err, tt.writeErr)
r := newFixedReader(tt.max, encoded)
var msg MsgGetCFHeaders
err = msg.Bsvdecode(r, ProtocolVersion, BaseEncoding)
require.ErrorIs(t, err, tt.readErr)
})
}
}