All checks were successful
Test / Create distribution (push) Successful in 1m16s
Test / Sandbox (push) Successful in 3m14s
Test / Hakurei (push) Successful in 4m19s
Test / ShareFS (push) Successful in 4m19s
Test / Sandbox (race detector) (push) Successful in 5m36s
Test / Hakurei (race detector) (push) Successful in 6m43s
Test / Flake checks (push) Successful in 1m25s
This also gets rid of the cached pid value for port since that prevents multiple sockets from being open at once. Signed-off-by: Ophestra <cat@gensokyo.uk>
32 lines
624 B
Go
32 lines
624 B
Go
package netlink
|
|
|
|
import (
|
|
"syscall"
|
|
"testing"
|
|
)
|
|
|
|
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()
|
|
t.Helper()
|
|
|
|
c := conn{port: 1, 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)
|
|
}
|
|
})
|
|
}
|
|
}
|