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
|
package sctp // nolint:dupl
import (
"testing"
"github.com/stretchr/testify/assert"
)
func testParamECNCapabale() []byte {
return []byte{0x80, 0x0, 0x0, 0x4}
}
func TestParamECNCapabale_Success(t *testing.T) {
tt := []struct {
binary []byte
parsed *paramECNCapable
}{
{
testParamECNCapabale(),
¶mECNCapable{
paramHeader: paramHeader{
typ: ecnCapable,
len: 4,
raw: []byte{},
},
},
},
}
for i, tc := range tt {
actual := ¶mECNCapable{}
_, err := actual.unmarshal(tc.binary)
if err != nil {
t.Fatalf("failed to unmarshal #%d: %v", i, err)
}
assert.Equal(t, tc.parsed, actual)
b, err := actual.marshal()
if err != nil {
t.Fatalf("failed to marshal: %v", err)
}
assert.Equal(t, tc.binary, b)
}
}
func TestParamECNCapabale_Failure(t *testing.T) {
tt := []struct {
name string
binary []byte
}{
{"param too short", []byte{0x0, 0xd, 0x0}},
}
for i, tc := range tt {
actual := ¶mECNCapable{}
_, err := actual.unmarshal(tc.binary)
if err == nil {
t.Errorf("expected unmarshal #%d: '%s' to fail.", i, tc.name)
}
}
}
|