| // Copyright 2011 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| |
| package net |
| |
| import ( |
| "os" |
| "reflect" |
| "runtime" |
| "syscall" |
| "testing" |
| ) |
| |
| type listenerFile interface { |
| Listener |
| File() (f *os.File, err error) |
| } |
| |
| type packetConnFile interface { |
| PacketConn |
| File() (f *os.File, err error) |
| } |
| |
| type connFile interface { |
| Conn |
| File() (f *os.File, err error) |
| } |
| |
| func testFileListener(t *testing.T, net, laddr string) { |
| if net == "tcp" { |
| laddr += ":0" // any available port |
| } |
| l, err := Listen(net, laddr) |
| if err != nil { |
| t.Fatalf("Listen failed: %v", err) |
| } |
| defer l.Close() |
| lf := l.(listenerFile) |
| f, err := lf.File() |
| if err != nil { |
| t.Fatalf("File failed: %v", err) |
| } |
| c, err := FileListener(f) |
| if err != nil { |
| t.Fatalf("FileListener failed: %v", err) |
| } |
| if !reflect.DeepEqual(l.Addr(), c.Addr()) { |
| t.Fatalf("Addrs not equal: %#v != %#v", l.Addr(), c.Addr()) |
| } |
| if err := c.Close(); err != nil { |
| t.Fatalf("Close failed: %v", err) |
| } |
| if err := f.Close(); err != nil { |
| t.Fatalf("Close failed: %v", err) |
| } |
| } |
| |
| func TestFileListener(t *testing.T) { |
| if runtime.GOOS == "windows" || runtime.GOOS == "plan9" { |
| return |
| } |
| testFileListener(t, "tcp", "127.0.0.1") |
| testFileListener(t, "tcp", "127.0.0.1") |
| if supportsIPv6 && supportsIPv4map { |
| testFileListener(t, "tcp", "[::ffff:127.0.0.1]") |
| testFileListener(t, "tcp", "127.0.0.1") |
| testFileListener(t, "tcp", "[::ffff:127.0.0.1]") |
| } |
| if syscall.OS == "linux" { |
| testFileListener(t, "unix", "@gotest/net") |
| testFileListener(t, "unixpacket", "@gotest/net") |
| } |
| } |
| |
| func testFilePacketConn(t *testing.T, pcf packetConnFile, listen bool) { |
| f, err := pcf.File() |
| if err != nil { |
| t.Fatalf("File failed: %v", err) |
| } |
| c, err := FilePacketConn(f) |
| if err != nil { |
| t.Fatalf("FilePacketConn failed: %v", err) |
| } |
| if !reflect.DeepEqual(pcf.LocalAddr(), c.LocalAddr()) { |
| t.Fatalf("LocalAddrs not equal: %#v != %#v", pcf.LocalAddr(), c.LocalAddr()) |
| } |
| if listen { |
| if _, err := c.WriteTo([]byte{}, c.LocalAddr()); err != nil { |
| t.Fatalf("WriteTo failed: %v", err) |
| } |
| } |
| if err := c.Close(); err != nil { |
| t.Fatalf("Close failed: %v", err) |
| } |
| if err := f.Close(); err != nil { |
| t.Fatalf("Close failed: %v", err) |
| } |
| } |
| |
| func testFilePacketConnListen(t *testing.T, net, laddr string) { |
| l, err := ListenPacket(net, laddr) |
| if err != nil { |
| t.Fatalf("Listen failed: %v", err) |
| } |
| testFilePacketConn(t, l.(packetConnFile), true) |
| if err := l.Close(); err != nil { |
| t.Fatalf("Close failed: %v", err) |
| } |
| } |
| |
| func testFilePacketConnDial(t *testing.T, net, raddr string) { |
| c, err := Dial(net, raddr) |
| if err != nil { |
| t.Fatalf("Dial failed: %v", err) |
| } |
| testFilePacketConn(t, c.(packetConnFile), false) |
| if err := c.Close(); err != nil { |
| t.Fatalf("Close failed: %v", err) |
| } |
| } |
| |
| func TestFilePacketConn(t *testing.T) { |
| if runtime.GOOS == "windows" || runtime.GOOS == "plan9" { |
| return |
| } |
| testFilePacketConnListen(t, "udp", "127.0.0.1:0") |
| testFilePacketConnDial(t, "udp", "127.0.0.1:12345") |
| if supportsIPv6 { |
| testFilePacketConnListen(t, "udp", "[::1]:0") |
| } |
| if supportsIPv6 && supportsIPv4map { |
| testFilePacketConnDial(t, "udp", "[::ffff:127.0.0.1]:12345") |
| } |
| if syscall.OS == "linux" { |
| testFilePacketConnListen(t, "unixgram", "@gotest1/net") |
| } |
| } |