Home | History | Annotate | Download | only in net
      1 // Copyright 2012 The Go Authors.  All rights reserved.
      2 // Use of this source code is governed by a BSD-style
      3 // license that can be found in the LICENSE file.
      4 
      5 // This file implements API tests across platforms and will never have a build
      6 // tag.
      7 
      8 package net
      9 
     10 import (
     11 	"os"
     12 	"runtime"
     13 	"testing"
     14 	"time"
     15 )
     16 
     17 // The full stack test cases for IPConn have been moved to the
     18 // following:
     19 //	golang.org/x/net/ipv4
     20 //	golang.org/x/net/ipv6
     21 //	golang.org/x/net/icmp
     22 
     23 func TestTCPListenerSpecificMethods(t *testing.T) {
     24 	switch runtime.GOOS {
     25 	case "plan9":
     26 		t.Skipf("not supported on %s", runtime.GOOS)
     27 	}
     28 
     29 	la, err := ResolveTCPAddr("tcp4", "127.0.0.1:0")
     30 	if err != nil {
     31 		t.Fatal(err)
     32 	}
     33 	ln, err := ListenTCP("tcp4", la)
     34 	if err != nil {
     35 		t.Fatal(err)
     36 	}
     37 	defer ln.Close()
     38 	ln.Addr()
     39 	ln.SetDeadline(time.Now().Add(30 * time.Nanosecond))
     40 
     41 	if c, err := ln.Accept(); err != nil {
     42 		if !err.(Error).Timeout() {
     43 			t.Fatal(err)
     44 		}
     45 	} else {
     46 		c.Close()
     47 	}
     48 	if c, err := ln.AcceptTCP(); err != nil {
     49 		if !err.(Error).Timeout() {
     50 			t.Fatal(err)
     51 		}
     52 	} else {
     53 		c.Close()
     54 	}
     55 
     56 	if f, err := ln.File(); err != nil {
     57 		condFatalf(t, "%v", err)
     58 	} else {
     59 		f.Close()
     60 	}
     61 }
     62 
     63 func TestTCPConnSpecificMethods(t *testing.T) {
     64 	la, err := ResolveTCPAddr("tcp4", "127.0.0.1:0")
     65 	if err != nil {
     66 		t.Fatal(err)
     67 	}
     68 	ln, err := ListenTCP("tcp4", la)
     69 	if err != nil {
     70 		t.Fatal(err)
     71 	}
     72 	ch := make(chan error, 1)
     73 	handler := func(ls *localServer, ln Listener) { transponder(ls.Listener, ch) }
     74 	ls, err := (&streamListener{Listener: ln}).newLocalServer()
     75 	if err != nil {
     76 		t.Fatal(err)
     77 	}
     78 	defer ls.teardown()
     79 	if err := ls.buildup(handler); err != nil {
     80 		t.Fatal(err)
     81 	}
     82 
     83 	ra, err := ResolveTCPAddr("tcp4", ls.Listener.Addr().String())
     84 	if err != nil {
     85 		t.Fatal(err)
     86 	}
     87 	c, err := DialTCP("tcp4", nil, ra)
     88 	if err != nil {
     89 		t.Fatal(err)
     90 	}
     91 	defer c.Close()
     92 	c.SetKeepAlive(false)
     93 	c.SetKeepAlivePeriod(3 * time.Second)
     94 	c.SetLinger(0)
     95 	c.SetNoDelay(false)
     96 	c.LocalAddr()
     97 	c.RemoteAddr()
     98 	c.SetDeadline(time.Now().Add(someTimeout))
     99 	c.SetReadDeadline(time.Now().Add(someTimeout))
    100 	c.SetWriteDeadline(time.Now().Add(someTimeout))
    101 
    102 	if _, err := c.Write([]byte("TCPCONN TEST")); err != nil {
    103 		t.Fatal(err)
    104 	}
    105 	rb := make([]byte, 128)
    106 	if _, err := c.Read(rb); err != nil {
    107 		t.Fatal(err)
    108 	}
    109 
    110 	for err := range ch {
    111 		t.Error(err)
    112 	}
    113 }
    114 
    115 func TestUDPConnSpecificMethods(t *testing.T) {
    116 	la, err := ResolveUDPAddr("udp4", "127.0.0.1:0")
    117 	if err != nil {
    118 		t.Fatal(err)
    119 	}
    120 	c, err := ListenUDP("udp4", la)
    121 	if err != nil {
    122 		t.Fatal(err)
    123 	}
    124 	defer c.Close()
    125 	c.LocalAddr()
    126 	c.RemoteAddr()
    127 	c.SetDeadline(time.Now().Add(someTimeout))
    128 	c.SetReadDeadline(time.Now().Add(someTimeout))
    129 	c.SetWriteDeadline(time.Now().Add(someTimeout))
    130 	c.SetReadBuffer(2048)
    131 	c.SetWriteBuffer(2048)
    132 
    133 	wb := []byte("UDPCONN TEST")
    134 	rb := make([]byte, 128)
    135 	if _, err := c.WriteToUDP(wb, c.LocalAddr().(*UDPAddr)); err != nil {
    136 		t.Fatal(err)
    137 	}
    138 	if _, _, err := c.ReadFromUDP(rb); err != nil {
    139 		t.Fatal(err)
    140 	}
    141 	if _, _, err := c.WriteMsgUDP(wb, nil, c.LocalAddr().(*UDPAddr)); err != nil {
    142 		condFatalf(t, "%v", err)
    143 	}
    144 	if _, _, _, _, err := c.ReadMsgUDP(rb, nil); err != nil {
    145 		condFatalf(t, "%v", err)
    146 	}
    147 
    148 	if f, err := c.File(); err != nil {
    149 		condFatalf(t, "%v", err)
    150 	} else {
    151 		f.Close()
    152 	}
    153 
    154 	defer func() {
    155 		if p := recover(); p != nil {
    156 			t.Fatalf("panicked: %v", p)
    157 		}
    158 	}()
    159 
    160 	c.WriteToUDP(wb, nil)
    161 	c.WriteMsgUDP(wb, nil, nil)
    162 }
    163 
    164 func TestIPConnSpecificMethods(t *testing.T) {
    165 	if os.Getuid() != 0 {
    166 		t.Skip("must be root")
    167 	}
    168 
    169 	la, err := ResolveIPAddr("ip4", "127.0.0.1")
    170 	if err != nil {
    171 		t.Fatal(err)
    172 	}
    173 	c, err := ListenIP("ip4:icmp", la)
    174 	if err != nil {
    175 		t.Fatal(err)
    176 	}
    177 	defer c.Close()
    178 	c.LocalAddr()
    179 	c.RemoteAddr()
    180 	c.SetDeadline(time.Now().Add(someTimeout))
    181 	c.SetReadDeadline(time.Now().Add(someTimeout))
    182 	c.SetWriteDeadline(time.Now().Add(someTimeout))
    183 	c.SetReadBuffer(2048)
    184 	c.SetWriteBuffer(2048)
    185 
    186 	if f, err := c.File(); err != nil {
    187 		condFatalf(t, "%v", err)
    188 	} else {
    189 		f.Close()
    190 	}
    191 
    192 	defer func() {
    193 		if p := recover(); p != nil {
    194 			t.Fatalf("panicked: %v", p)
    195 		}
    196 	}()
    197 
    198 	wb := []byte("IPCONN TEST")
    199 	c.WriteToIP(wb, nil)
    200 	c.WriteMsgIP(wb, nil, nil)
    201 }
    202 
    203 func TestUnixListenerSpecificMethods(t *testing.T) {
    204 	if !testableNetwork("unix") {
    205 		t.Skip("unix test")
    206 	}
    207 
    208 	addr := testUnixAddr()
    209 	la, err := ResolveUnixAddr("unix", addr)
    210 	if err != nil {
    211 		t.Fatal(err)
    212 	}
    213 	ln, err := ListenUnix("unix", la)
    214 	if err != nil {
    215 		t.Fatal(err)
    216 	}
    217 	defer ln.Close()
    218 	defer os.Remove(addr)
    219 	ln.Addr()
    220 	ln.SetDeadline(time.Now().Add(30 * time.Nanosecond))
    221 
    222 	if c, err := ln.Accept(); err != nil {
    223 		if !err.(Error).Timeout() {
    224 			t.Fatal(err)
    225 		}
    226 	} else {
    227 		c.Close()
    228 	}
    229 	if c, err := ln.AcceptUnix(); err != nil {
    230 		if !err.(Error).Timeout() {
    231 			t.Fatal(err)
    232 		}
    233 	} else {
    234 		c.Close()
    235 	}
    236 
    237 	if f, err := ln.File(); err != nil {
    238 		t.Fatal(err)
    239 	} else {
    240 		f.Close()
    241 	}
    242 }
    243 
    244 func TestUnixConnSpecificMethods(t *testing.T) {
    245 	if !testableNetwork("unixgram") {
    246 		t.Skip("unixgram test")
    247 	}
    248 
    249 	addr1, addr2, addr3 := testUnixAddr(), testUnixAddr(), testUnixAddr()
    250 
    251 	a1, err := ResolveUnixAddr("unixgram", addr1)
    252 	if err != nil {
    253 		t.Fatal(err)
    254 	}
    255 	c1, err := DialUnix("unixgram", a1, nil)
    256 	if err != nil {
    257 		t.Fatal(err)
    258 	}
    259 	defer c1.Close()
    260 	defer os.Remove(addr1)
    261 	c1.LocalAddr()
    262 	c1.RemoteAddr()
    263 	c1.SetDeadline(time.Now().Add(someTimeout))
    264 	c1.SetReadDeadline(time.Now().Add(someTimeout))
    265 	c1.SetWriteDeadline(time.Now().Add(someTimeout))
    266 	c1.SetReadBuffer(2048)
    267 	c1.SetWriteBuffer(2048)
    268 
    269 	a2, err := ResolveUnixAddr("unixgram", addr2)
    270 	if err != nil {
    271 		t.Fatal(err)
    272 	}
    273 	c2, err := DialUnix("unixgram", a2, nil)
    274 	if err != nil {
    275 		t.Fatal(err)
    276 	}
    277 	defer c2.Close()
    278 	defer os.Remove(addr2)
    279 	c2.LocalAddr()
    280 	c2.RemoteAddr()
    281 	c2.SetDeadline(time.Now().Add(someTimeout))
    282 	c2.SetReadDeadline(time.Now().Add(someTimeout))
    283 	c2.SetWriteDeadline(time.Now().Add(someTimeout))
    284 	c2.SetReadBuffer(2048)
    285 	c2.SetWriteBuffer(2048)
    286 
    287 	a3, err := ResolveUnixAddr("unixgram", addr3)
    288 	if err != nil {
    289 		t.Fatal(err)
    290 	}
    291 	c3, err := ListenUnixgram("unixgram", a3)
    292 	if err != nil {
    293 		t.Fatal(err)
    294 	}
    295 	defer c3.Close()
    296 	defer os.Remove(addr3)
    297 	c3.LocalAddr()
    298 	c3.RemoteAddr()
    299 	c3.SetDeadline(time.Now().Add(someTimeout))
    300 	c3.SetReadDeadline(time.Now().Add(someTimeout))
    301 	c3.SetWriteDeadline(time.Now().Add(someTimeout))
    302 	c3.SetReadBuffer(2048)
    303 	c3.SetWriteBuffer(2048)
    304 
    305 	wb := []byte("UNIXCONN TEST")
    306 	rb1 := make([]byte, 128)
    307 	rb2 := make([]byte, 128)
    308 	rb3 := make([]byte, 128)
    309 	if _, _, err := c1.WriteMsgUnix(wb, nil, a2); err != nil {
    310 		t.Fatal(err)
    311 	}
    312 	if _, _, _, _, err := c2.ReadMsgUnix(rb2, nil); err != nil {
    313 		t.Fatal(err)
    314 	}
    315 	if _, err := c2.WriteToUnix(wb, a1); err != nil {
    316 		t.Fatal(err)
    317 	}
    318 	if _, _, err := c1.ReadFromUnix(rb1); err != nil {
    319 		t.Fatal(err)
    320 	}
    321 	if _, err := c3.WriteToUnix(wb, a1); err != nil {
    322 		t.Fatal(err)
    323 	}
    324 	if _, _, err := c1.ReadFromUnix(rb1); err != nil {
    325 		t.Fatal(err)
    326 	}
    327 	if _, err := c2.WriteToUnix(wb, a3); err != nil {
    328 		t.Fatal(err)
    329 	}
    330 	if _, _, err := c3.ReadFromUnix(rb3); err != nil {
    331 		t.Fatal(err)
    332 	}
    333 
    334 	if f, err := c1.File(); err != nil {
    335 		t.Fatal(err)
    336 	} else {
    337 		f.Close()
    338 	}
    339 
    340 	defer func() {
    341 		if p := recover(); p != nil {
    342 			t.Fatalf("panicked: %v", p)
    343 		}
    344 	}()
    345 
    346 	c1.WriteToUnix(wb, nil)
    347 	c1.WriteMsgUnix(wb, nil, nil)
    348 	c3.WriteToUnix(wb, nil)
    349 	c3.WriteMsgUnix(wb, nil, nil)
    350 }
    351