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 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126
|
package proto
import (
"encoding/binary"
"errors"
"fmt"
"testing"
"github.com/pion/stun"
)
type attr interface {
stun.Getter
stun.Setter
}
type attrs []struct {
g attr
t stun.AttrType
}
func (a attrs) pick(v byte) struct {
g attr
t stun.AttrType
} {
idx := int(v) % len(a)
return a[idx]
}
func FuzzSetters(f *testing.F) {
f.Fuzz(func(t *testing.T, attrType byte, value []byte) {
var (
m1 = &stun.Message{
Raw: make([]byte, 0, 2048),
}
m2 = &stun.Message{
Raw: make([]byte, 0, 2048),
}
m3 = &stun.Message{
Raw: make([]byte, 0, 2048),
}
)
attributes := attrs{
{new(ChannelNumber), stun.AttrChannelNumber},
{new(Lifetime), stun.AttrLifetime},
{new(XORPeerAddress), stun.AttrXORPeerAddress},
{new(Data), stun.AttrData},
{new(XORRelayedAddress), stun.AttrXORRelayedAddress},
{new(EvenPort), stun.AttrEvenPort},
{new(RequestedTransport), stun.AttrRequestedTransport},
{new(DontFragment), stun.AttrDontFragment},
{new(ReservationToken), stun.AttrReservationToken},
{new(ConnectionID), stun.AttrConnectionID},
{new(RequestedAddressFamily), stun.AttrRequestedAddressFamily},
}
attr := attributes.pick(attrType)
m1.WriteHeader()
m1.Add(attr.t, value)
if err := attr.g.GetFrom(m1); err != nil {
if errors.Is(err, stun.ErrAttributeNotFound) {
fmt.Println("unexpected 404") // nolint
panic(err) // nolint
}
return
}
m2.WriteHeader()
if err := attr.g.AddTo(m2); err != nil {
fmt.Println("failed to add attribute to m2") // nolint
panic(err) // nolint
}
m3.WriteHeader()
v, err := m2.Get(attr.t)
if err != nil {
panic(err) // nolint
}
m3.Add(attr.t, v)
if !m2.Equal(m3) {
fmt.Println(m2, "not equal", m3) // nolint
panic("not equal") // nolint
}
})
}
func FuzzChannelData(f *testing.F) {
d := &ChannelData{}
f.Fuzz(func(t *testing.T, data []byte) {
d.Reset()
if len(data) > channelDataHeaderSize {
// Make sure the channel id is in the proper range
if b := binary.BigEndian.Uint16(data[0:4]); b > 20000 {
binary.BigEndian.PutUint16(data[0:4], MinChannelNumber-1)
} else if b > 40000 {
binary.BigEndian.PutUint16(data[0:4], MinChannelNumber+(MaxChannelNumber-MinChannelNumber)%b)
}
}
d.Raw = append(d.Raw, data...)
if d.Decode() != nil {
return
}
d.Encode()
if !d.Number.Valid() {
return
}
d2 := &ChannelData{}
d2.Raw = d.Raw
if err := d2.Decode(); err != nil {
panic(err) //nolint
}
})
}
func FuzzIsChannelData(f *testing.F) {
f.Fuzz(func(t *testing.T, data []byte) {
IsChannelData(data)
})
}
|