All checks were successful
Test / Create distribution (push) Successful in 1m13s
Test / Sandbox (push) Successful in 3m3s
Test / Hakurei (push) Successful in 4m19s
Test / ShareFS (push) Successful in 4m16s
Test / Sandbox (race detector) (push) Successful in 5m32s
Test / Hakurei (race detector) (push) Successful in 6m44s
Test / Flake checks (push) Successful in 1m22s
This also uses an array type for the buffer since its size now uses the hardcoded value found in the kernel. Signed-off-by: Ophestra <cat@gensokyo.uk>
33 lines
653 B
Go
33 lines
653 B
Go
package netlink
|
|
|
|
import (
|
|
"syscall"
|
|
"testing"
|
|
)
|
|
|
|
func init() { nlPidOnce.Do(func() {}); nlPid = 1 }
|
|
|
|
type payloadTestCase struct {
|
|
name string
|
|
f func(c *conn)
|
|
want []byte
|
|
}
|
|
|
|
// checkPayload runs multiple payloadTestCase against a stub conn and checks
|
|
// the outgoing message written to its buffer page.
|
|
func checkPayload(t *testing.T, testCases []payloadTestCase) {
|
|
t.Helper()
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
c := conn{pos: syscall.NLMSG_HDRLEN}
|
|
tc.f(&c)
|
|
if got := c.pending(); string(got) != string(tc.want) {
|
|
t.Errorf("pending: %#v, want %#v", got, tc.want)
|
|
}
|
|
})
|
|
}
|
|
}
|