mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-01-19 05:45:21 +01:00
825 lines
20 KiB
Go
825 lines
20 KiB
Go
package lnwire
|
|
|
|
import (
|
|
"bytes"
|
|
"compress/zlib"
|
|
"encoding/binary"
|
|
"reflect"
|
|
"testing"
|
|
)
|
|
|
|
// prefixWithMsgType takes []byte and adds a wire protocol prefix
|
|
// to make the []byte into an actual message to be used in fuzzing.
|
|
func prefixWithMsgType(data []byte, prefix MessageType) []byte {
|
|
var prefixBytes [2]byte
|
|
binary.BigEndian.PutUint16(prefixBytes[:], uint16(prefix))
|
|
data = append(prefixBytes[:], data...)
|
|
|
|
return data
|
|
}
|
|
|
|
// harness performs the actual fuzz testing of the appropriate wire message.
|
|
// This function will check that the passed-in message passes wire length
|
|
// checks, is a valid message once deserialized, and passes a sequence of
|
|
// serialization and deserialization checks.
|
|
func harness(t *testing.T, data []byte) {
|
|
t.Helper()
|
|
|
|
// Create a reader with the byte array.
|
|
r := bytes.NewReader(data)
|
|
|
|
// Check that the created message is not greater than the maximum
|
|
// message size.
|
|
if len(data) > MaxSliceLength {
|
|
return
|
|
}
|
|
|
|
msg, err := ReadMessage(r, 0)
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
// We will serialize the message into a new bytes buffer.
|
|
var b bytes.Buffer
|
|
if _, err := WriteMessage(&b, msg, 0); err != nil {
|
|
// Could not serialize message into bytes buffer, panic
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Deserialize the message from the serialized bytes buffer, and then
|
|
// assert that the original message is equal to the newly deserialized
|
|
// message.
|
|
newMsg, err := ReadMessage(&b, 0)
|
|
if err != nil {
|
|
// Could not deserialize message from bytes buffer, panic
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if !reflect.DeepEqual(msg, newMsg) {
|
|
// Deserialized message and original message are not deeply
|
|
// equal.
|
|
t.Fatal("original message and deserialized message are not " +
|
|
"deeply equal")
|
|
}
|
|
}
|
|
|
|
func FuzzAcceptChannel(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
data = prefixWithMsgType(data, MsgAcceptChannel)
|
|
// Create a reader with the byte array.
|
|
r := bytes.NewReader(data)
|
|
|
|
// Make sure byte array length (excluding 2 bytes for message
|
|
// type) is less than max payload size for the wire message.
|
|
payloadLen := uint32(len(data)) - 2
|
|
if payloadLen > MaxMsgBody {
|
|
return
|
|
}
|
|
|
|
msg, err := ReadMessage(r, 0)
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
// We will serialize the message into a new bytes buffer.
|
|
var b bytes.Buffer
|
|
if _, err := WriteMessage(&b, msg, 0); err != nil {
|
|
// Could not serialize message into bytes buffer, panic
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Deserialize the message from the serialized bytes buffer, and
|
|
// then assert that the original message is equal to the newly
|
|
// deserialized message.
|
|
newMsg, err := ReadMessage(&b, 0)
|
|
if err != nil {
|
|
// Could not deserialize message from bytes buffer,
|
|
// panic
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Now compare every field instead of using reflect.DeepEqual.
|
|
// For UpfrontShutdownScript, we only compare bytes. This
|
|
// probably takes up more branches than necessary, but that's
|
|
// fine for now.
|
|
var shouldPanic bool
|
|
first, ok := msg.(*AcceptChannel)
|
|
if !ok {
|
|
t.Fatal("message was not AcceptChannel")
|
|
}
|
|
second, ok := newMsg.(*AcceptChannel)
|
|
if !ok {
|
|
t.Fatal("new message was not AcceptChannel")
|
|
}
|
|
|
|
if !bytes.Equal(first.PendingChannelID[:],
|
|
second.PendingChannelID[:]) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.DustLimit != second.DustLimit {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.MaxValueInFlight != second.MaxValueInFlight {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.ChannelReserve != second.ChannelReserve {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.HtlcMinimum != second.HtlcMinimum {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.MinAcceptDepth != second.MinAcceptDepth {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.CsvDelay != second.CsvDelay {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.MaxAcceptedHTLCs != second.MaxAcceptedHTLCs {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.FundingKey.IsEqual(second.FundingKey) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.RevocationPoint.IsEqual(second.RevocationPoint) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.PaymentPoint.IsEqual(second.PaymentPoint) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.DelayedPaymentPoint.IsEqual(
|
|
second.DelayedPaymentPoint) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.HtlcPoint.IsEqual(second.HtlcPoint) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.FirstCommitmentPoint.IsEqual(
|
|
second.FirstCommitmentPoint) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !bytes.Equal(first.UpfrontShutdownScript,
|
|
second.UpfrontShutdownScript) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if shouldPanic {
|
|
t.Fatal("original message and deseralized message " +
|
|
"are not equal")
|
|
}
|
|
})
|
|
}
|
|
|
|
func FuzzAnnounceSignatures(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgAnnounceSignatures.
|
|
data = prefixWithMsgType(data, MsgAnnounceSignatures)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzChannelAnnouncement(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgChannelAnnouncement.
|
|
data = prefixWithMsgType(data, MsgChannelAnnouncement)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzChannelReestablish(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgChannelReestablish.
|
|
data = prefixWithMsgType(data, MsgChannelReestablish)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzChannelUpdate(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgChannelUpdate.
|
|
data = prefixWithMsgType(data, MsgChannelUpdate)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzClosingSigned(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgClosingSigned.
|
|
data = prefixWithMsgType(data, MsgClosingSigned)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzCommitSig(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgCommitSig.
|
|
data = prefixWithMsgType(data, MsgCommitSig)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzError(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgError.
|
|
data = prefixWithMsgType(data, MsgError)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzWarning(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgWarning.
|
|
data = prefixWithMsgType(data, MsgWarning)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzFundingCreated(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgFundingCreated.
|
|
data = prefixWithMsgType(data, MsgFundingCreated)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzFundingLocked(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgFundingLocked.
|
|
data = prefixWithMsgType(data, MsgFundingLocked)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzFundingSigned(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgFundingSigned.
|
|
data = prefixWithMsgType(data, MsgFundingSigned)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzGossipTimestampRange(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgGossipTimestampRange.
|
|
data = prefixWithMsgType(data, MsgGossipTimestampRange)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzInit(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgInit.
|
|
data = prefixWithMsgType(data, MsgInit)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzNodeAnnouncement(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgNodeAnnouncement.
|
|
data = prefixWithMsgType(data, MsgNodeAnnouncement)
|
|
|
|
// We have to do this here instead of in harness so that
|
|
// reflect.DeepEqual isn't called. Address (de)serialization
|
|
// messes up the fuzzing assertions.
|
|
|
|
// Create a reader with the byte array.
|
|
r := bytes.NewReader(data)
|
|
|
|
// Make sure byte array length (excluding 2 bytes for message
|
|
// type) is less than max payload size for the wire message.
|
|
payloadLen := uint32(len(data)) - 2
|
|
if payloadLen > MaxMsgBody {
|
|
return
|
|
}
|
|
|
|
msg, err := ReadMessage(r, 0)
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
// We will serialize the message into a new bytes buffer.
|
|
var b bytes.Buffer
|
|
if _, err := WriteMessage(&b, msg, 0); err != nil {
|
|
// Could not serialize message into bytes buffer, panic
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Deserialize the message from the serialized bytes buffer, and
|
|
// then assert that the original message is equal to the newly
|
|
// deserialized message.
|
|
newMsg, err := ReadMessage(&b, 0)
|
|
if err != nil {
|
|
// Could not deserialize message from bytes buffer,
|
|
// panic
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Now compare every field instead of using reflect.DeepEqual
|
|
// for the Addresses field.
|
|
var shouldPanic bool
|
|
first, ok := msg.(*NodeAnnouncement)
|
|
if !ok {
|
|
t.Fatal("message was not NodeAnnouncement")
|
|
}
|
|
second, ok := newMsg.(*NodeAnnouncement)
|
|
if !ok {
|
|
t.Fatal("new message was not NodeAnnouncement")
|
|
}
|
|
|
|
if !bytes.Equal(first.Signature[:], second.Signature[:]) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !reflect.DeepEqual(first.Features, second.Features) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.Timestamp != second.Timestamp {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !bytes.Equal(first.NodeID[:], second.NodeID[:]) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !reflect.DeepEqual(first.RGBColor, second.RGBColor) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !bytes.Equal(first.Alias[:], second.Alias[:]) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if len(first.Addresses) != len(second.Addresses) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
for i := range first.Addresses {
|
|
if first.Addresses[i].String() !=
|
|
second.Addresses[i].String() {
|
|
|
|
shouldPanic = true
|
|
break
|
|
}
|
|
}
|
|
|
|
if !reflect.DeepEqual(first.ExtraOpaqueData,
|
|
second.ExtraOpaqueData) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if shouldPanic {
|
|
t.Fatal("original message and deserialized message " +
|
|
"are not equal")
|
|
}
|
|
})
|
|
}
|
|
|
|
func FuzzOpenChannel(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgOpenChannel.
|
|
data = prefixWithMsgType(data, MsgOpenChannel)
|
|
|
|
// We have to do this here instead of in harness so that
|
|
// reflect.DeepEqual isn't called. Because of the
|
|
// UpfrontShutdownScript encoding, the first message and second
|
|
// message aren't deeply equal since the first has a nil slice
|
|
// and the other has an empty slice.
|
|
|
|
// Create a reader with the byte array.
|
|
r := bytes.NewReader(data)
|
|
|
|
// Make sure byte array length (excluding 2 bytes for message
|
|
// type) is less than max payload size for the wire message.
|
|
payloadLen := uint32(len(data)) - 2
|
|
if payloadLen > MaxMsgBody {
|
|
return
|
|
}
|
|
|
|
msg, err := ReadMessage(r, 0)
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
// We will serialize the message into a new bytes buffer.
|
|
var b bytes.Buffer
|
|
if _, err := WriteMessage(&b, msg, 0); err != nil {
|
|
// Could not serialize message into bytes buffer, panic
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Deserialize the message from the serialized bytes buffer, and
|
|
// then assert that the original message is equal to the newly
|
|
// deserialized message.
|
|
newMsg, err := ReadMessage(&b, 0)
|
|
if err != nil {
|
|
// Could not deserialize message from bytes buffer,
|
|
// panic
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Now compare every field instead of using reflect.DeepEqual.
|
|
// For UpfrontShutdownScript, we only compare bytes. This
|
|
// probably takes up more branches than necessary, but that's
|
|
// fine for now.
|
|
var shouldPanic bool
|
|
first, ok := msg.(*OpenChannel)
|
|
if !ok {
|
|
t.Fatal("message was not OpenChannel")
|
|
}
|
|
second, ok := newMsg.(*OpenChannel)
|
|
if !ok {
|
|
t.Fatal("new message was not OpenChannel")
|
|
}
|
|
|
|
if !first.ChainHash.IsEqual(&second.ChainHash) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !bytes.Equal(first.PendingChannelID[:],
|
|
second.PendingChannelID[:]) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.FundingAmount != second.FundingAmount {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.PushAmount != second.PushAmount {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.DustLimit != second.DustLimit {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.MaxValueInFlight != second.MaxValueInFlight {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.ChannelReserve != second.ChannelReserve {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.HtlcMinimum != second.HtlcMinimum {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.FeePerKiloWeight != second.FeePerKiloWeight {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.CsvDelay != second.CsvDelay {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.MaxAcceptedHTLCs != second.MaxAcceptedHTLCs {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.FundingKey.IsEqual(second.FundingKey) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.RevocationPoint.IsEqual(second.RevocationPoint) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.PaymentPoint.IsEqual(second.PaymentPoint) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.DelayedPaymentPoint.IsEqual(
|
|
second.DelayedPaymentPoint) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.HtlcPoint.IsEqual(second.HtlcPoint) {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !first.FirstCommitmentPoint.IsEqual(
|
|
second.FirstCommitmentPoint) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if first.ChannelFlags != second.ChannelFlags {
|
|
shouldPanic = true
|
|
}
|
|
|
|
if !bytes.Equal(first.UpfrontShutdownScript,
|
|
second.UpfrontShutdownScript) {
|
|
|
|
shouldPanic = true
|
|
}
|
|
|
|
if shouldPanic {
|
|
t.Fatal("original message and deserialized message " +
|
|
"are not equal")
|
|
}
|
|
})
|
|
}
|
|
|
|
func FuzzPing(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgPing.
|
|
data = prefixWithMsgType(data, MsgPing)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzPong(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgPong.
|
|
data = prefixWithMsgType(data, MsgPong)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzQueryChannelRange(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgQueryChannelRange.
|
|
data = prefixWithMsgType(data, MsgQueryChannelRange)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzZlibQueryShortChanIDs(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
var buf bytes.Buffer
|
|
zlibWriter := zlib.NewWriter(&buf)
|
|
_, err := zlibWriter.Write(data)
|
|
if err != nil {
|
|
// Zlib bug?
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if err := zlibWriter.Close(); err != nil {
|
|
// Zlib bug?
|
|
t.Fatal(err)
|
|
}
|
|
|
|
compressedPayload := buf.Bytes()
|
|
|
|
chainhash := []byte("00000000000000000000000000000000")
|
|
numBytesInBody := len(compressedPayload) + 1
|
|
zlibByte := []byte("\x01")
|
|
|
|
bodyBytes := make([]byte, 2)
|
|
binary.BigEndian.PutUint16(bodyBytes, uint16(numBytesInBody))
|
|
|
|
payload := chainhash
|
|
payload = append(payload, bodyBytes...)
|
|
payload = append(payload, zlibByte...)
|
|
payload = append(payload, compressedPayload...)
|
|
|
|
// Prefix with MsgQueryShortChanIDs.
|
|
payload = prefixWithMsgType(payload, MsgQueryShortChanIDs)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, payload)
|
|
})
|
|
}
|
|
|
|
func FuzzQueryShortChanIDs(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgQueryShortChanIDs.
|
|
data = prefixWithMsgType(data, MsgQueryShortChanIDs)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzZlibReplyChannelRange(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
var buf bytes.Buffer
|
|
zlibWriter := zlib.NewWriter(&buf)
|
|
_, err := zlibWriter.Write(data)
|
|
if err != nil {
|
|
// Zlib bug?
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if err := zlibWriter.Close(); err != nil {
|
|
// Zlib bug?
|
|
t.Fatal(err)
|
|
}
|
|
|
|
compressedPayload := buf.Bytes()
|
|
|
|
// Initialize some []byte vars which will prefix our payload
|
|
chainhash := []byte("00000000000000000000000000000000")
|
|
firstBlockHeight := []byte("\x00\x00\x00\x00")
|
|
numBlocks := []byte("\x00\x00\x00\x00")
|
|
completeByte := []byte("\x00")
|
|
|
|
numBytesInBody := len(compressedPayload) + 1
|
|
zlibByte := []byte("\x01")
|
|
|
|
bodyBytes := make([]byte, 2)
|
|
binary.BigEndian.PutUint16(bodyBytes, uint16(numBytesInBody))
|
|
|
|
payload := chainhash
|
|
payload = append(payload, firstBlockHeight...)
|
|
payload = append(payload, numBlocks...)
|
|
payload = append(payload, completeByte...)
|
|
payload = append(payload, bodyBytes...)
|
|
payload = append(payload, zlibByte...)
|
|
payload = append(payload, compressedPayload...)
|
|
|
|
// Prefix with MsgReplyChannelRange.
|
|
payload = prefixWithMsgType(payload, MsgReplyChannelRange)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, payload)
|
|
})
|
|
}
|
|
|
|
func FuzzReplyChannelRange(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgReplyChannelRange.
|
|
data = prefixWithMsgType(data, MsgReplyChannelRange)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzReplyShortChanIDsEnd(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgReplyShortChanIDsEnd.
|
|
data = prefixWithMsgType(data, MsgReplyShortChanIDsEnd)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzRevokeAndAck(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgRevokeAndAck.
|
|
data = prefixWithMsgType(data, MsgRevokeAndAck)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzShutdown(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgShutdown.
|
|
data = prefixWithMsgType(data, MsgShutdown)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzUpdateAddHTLC(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgUpdateAddHTLC.
|
|
data = prefixWithMsgType(data, MsgUpdateAddHTLC)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzUpdateFailHTLC(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgUpdateFailHTLC.
|
|
data = prefixWithMsgType(data, MsgUpdateFailHTLC)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzUpdateFailMalformedHTLC(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgUpdateFailMalformedHTLC.
|
|
data = prefixWithMsgType(data, MsgUpdateFailMalformedHTLC)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzUpdateFee(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgUpdateFee.
|
|
data = prefixWithMsgType(data, MsgUpdateFee)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzUpdateFulfillHTLC(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte) {
|
|
// Prefix with MsgUpdateFulFillHTLC.
|
|
data = prefixWithMsgType(data, MsgUpdateFulfillHTLC)
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|
|
|
|
func FuzzCustomMessage(f *testing.F) {
|
|
f.Fuzz(func(t *testing.T, data []byte, customMessageType uint16) {
|
|
if customMessageType < uint16(CustomTypeStart) {
|
|
customMessageType += uint16(CustomTypeStart)
|
|
}
|
|
|
|
// Prefix with CustomMessage.
|
|
data = prefixWithMsgType(data, MessageType(customMessageType))
|
|
|
|
// Pass the message into our general fuzz harness for wire
|
|
// messages!
|
|
harness(t, data)
|
|
})
|
|
}
|