mirror of
https://github.com/tailscale/tailscale.git
synced 2025-01-10 10:03:43 +00:00
8fe504241d
Setting a user timeout will be a more practical tuning knob for a number of endpoints, this provides a way to set it. Updates tailscale/corp#17587 Signed-off-by: James Tucker <james@tailscale.com>
47 lines
1.1 KiB
Go
47 lines
1.1 KiB
Go
// Copyright (c) Tailscale Inc & AUTHORS
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
package ktimeout
|
|
|
|
import (
|
|
"net"
|
|
"testing"
|
|
"time"
|
|
|
|
"golang.org/x/net/nettest"
|
|
"golang.org/x/sys/unix"
|
|
"tailscale.com/util/must"
|
|
)
|
|
|
|
func TestSetUserTimeout(t *testing.T) {
|
|
l := must.Get(nettest.NewLocalListener("tcp"))
|
|
defer l.Close()
|
|
|
|
var err error
|
|
if e := must.Get(l.(*net.TCPListener).SyscallConn()).Control(func(fd uintptr) {
|
|
err = SetUserTimeout(fd, 0)
|
|
}); e != nil {
|
|
t.Fatal(e)
|
|
}
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
v := must.Get(unix.GetsockoptInt(int(must.Get(l.(*net.TCPListener).File()).Fd()), unix.SOL_TCP, unix.TCP_USER_TIMEOUT))
|
|
if v != 0 {
|
|
t.Errorf("TCP_USER_TIMEOUT: got %v; want 0", v)
|
|
}
|
|
|
|
if e := must.Get(l.(*net.TCPListener).SyscallConn()).Control(func(fd uintptr) {
|
|
err = SetUserTimeout(fd, 30*time.Second)
|
|
}); e != nil {
|
|
t.Fatal(e)
|
|
}
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
v = must.Get(unix.GetsockoptInt(int(must.Get(l.(*net.TCPListener).File()).Fd()), unix.SOL_TCP, unix.TCP_USER_TIMEOUT))
|
|
if v != 30000 {
|
|
t.Errorf("TCP_USER_TIMEOUT: got %v; want 30000", v)
|
|
}
|
|
}
|