}
for _, tt := range fileConnTests {
- if !testableNetwork(tt.network) {
- t.Logf("skipping %s test", tt.network)
- continue
- }
+ t.Run(tt.network, func(t *testing.T) {
+ if !testableNetwork(tt.network) {
+ t.Skipf("skipping %s test", tt.network)
+ }
- var network, address string
- switch tt.network {
- case "udp":
- c := newLocalPacketListener(t, tt.network)
- defer c.Close()
- network = c.LocalAddr().Network()
- address = c.LocalAddr().String()
- default:
- handler := func(ls *localServer, ln Listener) {
- c, err := ln.Accept()
- if err != nil {
- return
- }
+ var network, address string
+ switch tt.network {
+ case "udp":
+ c := newLocalPacketListener(t, tt.network)
defer c.Close()
- var b [1]byte
- c.Read(b[:])
+ network = c.LocalAddr().Network()
+ address = c.LocalAddr().String()
+ default:
+ handler := func(ls *localServer, ln Listener) {
+ c, err := ln.Accept()
+ if err != nil {
+ return
+ }
+ defer c.Close()
+ var b [1]byte
+ c.Read(b[:])
+ }
+ ls := newLocalServer(t, tt.network)
+ defer ls.teardown()
+ if err := ls.buildup(handler); err != nil {
+ t.Fatal(err)
+ }
+ network = ls.Listener.Addr().Network()
+ address = ls.Listener.Addr().String()
}
- ls := newLocalServer(t, tt.network)
- defer ls.teardown()
- if err := ls.buildup(handler); err != nil {
+
+ c1, err := Dial(network, address)
+ if err != nil {
+ if perr := parseDialError(err); perr != nil {
+ t.Error(perr)
+ }
t.Fatal(err)
}
- network = ls.Listener.Addr().Network()
- address = ls.Listener.Addr().String()
- }
+ addr := c1.LocalAddr()
- c1, err := Dial(network, address)
- if err != nil {
- if perr := parseDialError(err); perr != nil {
- t.Error(perr)
+ var f *os.File
+ switch c1 := c1.(type) {
+ case *TCPConn:
+ f, err = c1.File()
+ case *UDPConn:
+ f, err = c1.File()
+ case *UnixConn:
+ f, err = c1.File()
}
- t.Fatal(err)
- }
- addr := c1.LocalAddr()
-
- var f *os.File
- switch c1 := c1.(type) {
- case *TCPConn:
- f, err = c1.File()
- case *UDPConn:
- f, err = c1.File()
- case *UnixConn:
- f, err = c1.File()
- }
- if err := c1.Close(); err != nil {
- if perr := parseCloseError(err, false); perr != nil {
- t.Error(perr)
+ if err := c1.Close(); err != nil {
+ if perr := parseCloseError(err, false); perr != nil {
+ t.Error(perr)
+ }
+ t.Error(err)
}
- t.Error(err)
- }
- if err != nil {
- if perr := parseCommonError(err); perr != nil {
- t.Error(perr)
+ if err != nil {
+ if perr := parseCommonError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Fatal(err)
}
- t.Fatal(err)
- }
- c2, err := FileConn(f)
- if err := f.Close(); err != nil {
- t.Error(err)
- }
- if err != nil {
- if perr := parseCommonError(err); perr != nil {
- t.Error(perr)
+ c2, err := FileConn(f)
+ if err := f.Close(); err != nil {
+ t.Error(err)
}
- t.Fatal(err)
- }
- defer c2.Close()
+ if err != nil {
+ if perr := parseCommonError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Fatal(err)
+ }
+ defer c2.Close()
- if _, err := c2.Write([]byte("FILECONN TEST")); err != nil {
- if perr := parseWriteError(err); perr != nil {
- t.Error(perr)
+ if _, err := c2.Write([]byte("FILECONN TEST")); err != nil {
+ if perr := parseWriteError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Fatal(err)
}
- t.Fatal(err)
- }
- if !reflect.DeepEqual(c2.LocalAddr(), addr) {
- t.Fatalf("got %#v; want %#v", c2.LocalAddr(), addr)
- }
+ if !reflect.DeepEqual(c2.LocalAddr(), addr) {
+ t.Fatalf("got %#v; want %#v", c2.LocalAddr(), addr)
+ }
+ })
}
}
}
for _, tt := range fileListenerTests {
- if !testableNetwork(tt.network) {
- t.Logf("skipping %s test", tt.network)
- continue
- }
+ t.Run(tt.network, func(t *testing.T) {
+ if !testableNetwork(tt.network) {
+ t.Skipf("skipping %s test", tt.network)
+ }
- ln1 := newLocalListener(t, tt.network)
- switch tt.network {
- case "unix", "unixpacket":
- defer os.Remove(ln1.Addr().String())
- }
- addr := ln1.Addr()
+ ln1 := newLocalListener(t, tt.network)
+ switch tt.network {
+ case "unix", "unixpacket":
+ defer os.Remove(ln1.Addr().String())
+ }
+ addr := ln1.Addr()
- var (
- f *os.File
- err error
- )
- switch ln1 := ln1.(type) {
- case *TCPListener:
- f, err = ln1.File()
- case *UnixListener:
- f, err = ln1.File()
- }
- switch tt.network {
- case "unix", "unixpacket":
- defer ln1.Close() // UnixListener.Close calls syscall.Unlink internally
- default:
- if err := ln1.Close(); err != nil {
- t.Error(err)
+ var (
+ f *os.File
+ err error
+ )
+ switch ln1 := ln1.(type) {
+ case *TCPListener:
+ f, err = ln1.File()
+ case *UnixListener:
+ f, err = ln1.File()
}
- }
- if err != nil {
- if perr := parseCommonError(err); perr != nil {
- t.Error(perr)
+ switch tt.network {
+ case "unix", "unixpacket":
+ defer ln1.Close() // UnixListener.Close calls syscall.Unlink internally
+ default:
+ if err := ln1.Close(); err != nil {
+ t.Error(err)
+ }
+ }
+ if err != nil {
+ if perr := parseCommonError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Fatal(err)
}
- t.Fatal(err)
- }
- ln2, err := FileListener(f)
- if err := f.Close(); err != nil {
- t.Error(err)
- }
- if err != nil {
- if perr := parseCommonError(err); perr != nil {
- t.Error(perr)
+ ln2, err := FileListener(f)
+ if err := f.Close(); err != nil {
+ t.Error(err)
}
- t.Fatal(err)
- }
- defer ln2.Close()
+ if err != nil {
+ if perr := parseCommonError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Fatal(err)
+ }
+ defer ln2.Close()
- var wg sync.WaitGroup
- wg.Add(1)
- go func() {
- defer wg.Done()
- c, err := Dial(ln2.Addr().Network(), ln2.Addr().String())
+ var wg sync.WaitGroup
+ wg.Add(1)
+ go func() {
+ defer wg.Done()
+ c, err := Dial(ln2.Addr().Network(), ln2.Addr().String())
+ if err != nil {
+ if perr := parseDialError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Error(err)
+ return
+ }
+ c.Close()
+ }()
+ c, err := ln2.Accept()
if err != nil {
- if perr := parseDialError(err); perr != nil {
+ if perr := parseAcceptError(err); perr != nil {
t.Error(perr)
}
- t.Error(err)
- return
+ t.Fatal(err)
}
c.Close()
- }()
- c, err := ln2.Accept()
- if err != nil {
- if perr := parseAcceptError(err); perr != nil {
- t.Error(perr)
+ wg.Wait()
+ if !reflect.DeepEqual(ln2.Addr(), addr) {
+ t.Fatalf("got %#v; want %#v", ln2.Addr(), addr)
}
- t.Fatal(err)
- }
- c.Close()
- wg.Wait()
- if !reflect.DeepEqual(ln2.Addr(), addr) {
- t.Fatalf("got %#v; want %#v", ln2.Addr(), addr)
- }
+ })
}
}
}
for _, tt := range filePacketConnTests {
- if !testableNetwork(tt.network) {
- t.Logf("skipping %s test", tt.network)
- continue
- }
+ t.Run(tt.network, func(t *testing.T) {
+ if !testableNetwork(tt.network) {
+ t.Skipf("skipping %s test", tt.network)
+ }
- c1 := newLocalPacketListener(t, tt.network)
- switch tt.network {
- case "unixgram":
- defer os.Remove(c1.LocalAddr().String())
- }
- addr := c1.LocalAddr()
+ c1 := newLocalPacketListener(t, tt.network)
+ switch tt.network {
+ case "unixgram":
+ defer os.Remove(c1.LocalAddr().String())
+ }
+ addr := c1.LocalAddr()
- var (
- f *os.File
- err error
- )
- switch c1 := c1.(type) {
- case *UDPConn:
- f, err = c1.File()
- case *UnixConn:
- f, err = c1.File()
- }
- if err := c1.Close(); err != nil {
- if perr := parseCloseError(err, false); perr != nil {
- t.Error(perr)
+ var (
+ f *os.File
+ err error
+ )
+ switch c1 := c1.(type) {
+ case *UDPConn:
+ f, err = c1.File()
+ case *UnixConn:
+ f, err = c1.File()
}
- t.Error(err)
- }
- if err != nil {
- if perr := parseCommonError(err); perr != nil {
- t.Error(perr)
+ if err := c1.Close(); err != nil {
+ if perr := parseCloseError(err, false); perr != nil {
+ t.Error(perr)
+ }
+ t.Error(err)
+ }
+ if err != nil {
+ if perr := parseCommonError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Fatal(err)
}
- t.Fatal(err)
- }
- c2, err := FilePacketConn(f)
- if err := f.Close(); err != nil {
- t.Error(err)
- }
- if err != nil {
- if perr := parseCommonError(err); perr != nil {
- t.Error(perr)
+ c2, err := FilePacketConn(f)
+ if err := f.Close(); err != nil {
+ t.Error(err)
}
- t.Fatal(err)
- }
- defer c2.Close()
+ if err != nil {
+ if perr := parseCommonError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Fatal(err)
+ }
+ defer c2.Close()
- if _, err := c2.WriteTo([]byte("FILEPACKETCONN TEST"), addr); err != nil {
- if perr := parseWriteError(err); perr != nil {
- t.Error(perr)
+ if _, err := c2.WriteTo([]byte("FILEPACKETCONN TEST"), addr); err != nil {
+ if perr := parseWriteError(err); perr != nil {
+ t.Error(perr)
+ }
+ t.Fatal(err)
}
- t.Fatal(err)
- }
- if !reflect.DeepEqual(c2.LocalAddr(), addr) {
- t.Fatalf("got %#v; want %#v", c2.LocalAddr(), addr)
- }
+ if !reflect.DeepEqual(c2.LocalAddr(), addr) {
+ t.Fatalf("got %#v; want %#v", c2.LocalAddr(), addr)
+ }
+ })
}
}