mirror of https://github.com/tailscale/tailscale/
net/memnet: allow listener address reuse (#17342)
Listen address reuse is allowed as soon as the previous listener is closed. There is no attempt made to emulate more complex address reuse logic. Updates tailscale/corp#28078 Change-Id: I56be1c4848e7b3f9fc97fd4ef13a2de9dcfab0f2 Signed-off-by: Brian Palmer <brianp@tailscale.com>pull/17312/head
parent
bdb69d1b1f
commit
54e50230a1
@ -0,0 +1,23 @@
|
||||
// Copyright (c) Tailscale Inc & AUTHORS
|
||||
// SPDX-License-Identifier: BSD-3-Clause
|
||||
|
||||
package memnet
|
||||
|
||||
import "testing"
|
||||
|
||||
func TestListenAddressReuse(t *testing.T) {
|
||||
var nw Network
|
||||
ln1, err := nw.Listen("tcp", "127.0.0.1:80")
|
||||
if err != nil {
|
||||
t.Fatalf("listen failed: %v", err)
|
||||
}
|
||||
if _, err := nw.Listen("tcp", "127.0.0.1:80"); err == nil {
|
||||
t.Errorf("listen on in-use address succeeded")
|
||||
}
|
||||
if err := ln1.Close(); err != nil {
|
||||
t.Fatalf("close failed: %v", err)
|
||||
}
|
||||
if _, err := nw.Listen("tcp", "127.0.0.1:80"); err != nil {
|
||||
t.Errorf("listen on same address after close failed: %v", err)
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue