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>main
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