net_test.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581
  1. // Copyright 2009 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. //go:build !js
  5. package net
  6. import (
  7. "errors"
  8. "fmt"
  9. "io"
  10. "net/internal/socktest"
  11. "os"
  12. "runtime"
  13. "testing"
  14. "time"
  15. )
  16. func TestCloseRead(t *testing.T) {
  17. switch runtime.GOOS {
  18. case "plan9":
  19. t.Skipf("not supported on %s", runtime.GOOS)
  20. }
  21. t.Parallel()
  22. for _, network := range []string{"tcp", "unix", "unixpacket"} {
  23. network := network
  24. t.Run(network, func(t *testing.T) {
  25. if !testableNetwork(network) {
  26. t.Skipf("network %s is not testable on the current platform", network)
  27. }
  28. t.Parallel()
  29. ln := newLocalListener(t, network)
  30. switch network {
  31. case "unix", "unixpacket":
  32. defer os.Remove(ln.Addr().String())
  33. }
  34. defer ln.Close()
  35. c, err := Dial(ln.Addr().Network(), ln.Addr().String())
  36. if err != nil {
  37. t.Fatal(err)
  38. }
  39. switch network {
  40. case "unix", "unixpacket":
  41. defer os.Remove(c.LocalAddr().String())
  42. }
  43. defer c.Close()
  44. switch c := c.(type) {
  45. case *TCPConn:
  46. err = c.CloseRead()
  47. case *UnixConn:
  48. err = c.CloseRead()
  49. }
  50. if err != nil {
  51. if perr := parseCloseError(err, true); perr != nil {
  52. t.Error(perr)
  53. }
  54. t.Fatal(err)
  55. }
  56. var b [1]byte
  57. n, err := c.Read(b[:])
  58. if n != 0 || err == nil {
  59. t.Fatalf("got (%d, %v); want (0, error)", n, err)
  60. }
  61. })
  62. }
  63. }
  64. func TestCloseWrite(t *testing.T) {
  65. switch runtime.GOOS {
  66. case "plan9":
  67. t.Skipf("not supported on %s", runtime.GOOS)
  68. }
  69. t.Parallel()
  70. deadline, _ := t.Deadline()
  71. if !deadline.IsZero() {
  72. // Leave 10% headroom on the deadline to report errors and clean up.
  73. deadline = deadline.Add(-time.Until(deadline) / 10)
  74. }
  75. for _, network := range []string{"tcp", "unix", "unixpacket"} {
  76. network := network
  77. t.Run(network, func(t *testing.T) {
  78. if !testableNetwork(network) {
  79. t.Skipf("network %s is not testable on the current platform", network)
  80. }
  81. t.Parallel()
  82. handler := func(ls *localServer, ln Listener) {
  83. c, err := ln.Accept()
  84. if err != nil {
  85. t.Error(err)
  86. return
  87. }
  88. if !deadline.IsZero() {
  89. c.SetDeadline(deadline)
  90. }
  91. defer c.Close()
  92. var b [1]byte
  93. n, err := c.Read(b[:])
  94. if n != 0 || err != io.EOF {
  95. t.Errorf("got (%d, %v); want (0, io.EOF)", n, err)
  96. return
  97. }
  98. switch c := c.(type) {
  99. case *TCPConn:
  100. err = c.CloseWrite()
  101. case *UnixConn:
  102. err = c.CloseWrite()
  103. }
  104. if err != nil {
  105. if perr := parseCloseError(err, true); perr != nil {
  106. t.Error(perr)
  107. }
  108. t.Error(err)
  109. return
  110. }
  111. n, err = c.Write(b[:])
  112. if err == nil {
  113. t.Errorf("got (%d, %v); want (any, error)", n, err)
  114. return
  115. }
  116. }
  117. ls := newLocalServer(t, network)
  118. defer ls.teardown()
  119. if err := ls.buildup(handler); err != nil {
  120. t.Fatal(err)
  121. }
  122. c, err := Dial(ls.Listener.Addr().Network(), ls.Listener.Addr().String())
  123. if err != nil {
  124. t.Fatal(err)
  125. }
  126. if !deadline.IsZero() {
  127. c.SetDeadline(deadline)
  128. }
  129. switch network {
  130. case "unix", "unixpacket":
  131. defer os.Remove(c.LocalAddr().String())
  132. }
  133. defer c.Close()
  134. switch c := c.(type) {
  135. case *TCPConn:
  136. err = c.CloseWrite()
  137. case *UnixConn:
  138. err = c.CloseWrite()
  139. }
  140. if err != nil {
  141. if perr := parseCloseError(err, true); perr != nil {
  142. t.Error(perr)
  143. }
  144. t.Fatal(err)
  145. }
  146. var b [1]byte
  147. n, err := c.Read(b[:])
  148. if n != 0 || err != io.EOF {
  149. t.Fatalf("got (%d, %v); want (0, io.EOF)", n, err)
  150. }
  151. n, err = c.Write(b[:])
  152. if err == nil {
  153. t.Fatalf("got (%d, %v); want (any, error)", n, err)
  154. }
  155. })
  156. }
  157. }
  158. func TestConnClose(t *testing.T) {
  159. t.Parallel()
  160. for _, network := range []string{"tcp", "unix", "unixpacket"} {
  161. network := network
  162. t.Run(network, func(t *testing.T) {
  163. if !testableNetwork(network) {
  164. t.Skipf("network %s is not testable on the current platform", network)
  165. }
  166. t.Parallel()
  167. ln := newLocalListener(t, network)
  168. switch network {
  169. case "unix", "unixpacket":
  170. defer os.Remove(ln.Addr().String())
  171. }
  172. defer ln.Close()
  173. c, err := Dial(ln.Addr().Network(), ln.Addr().String())
  174. if err != nil {
  175. t.Fatal(err)
  176. }
  177. switch network {
  178. case "unix", "unixpacket":
  179. defer os.Remove(c.LocalAddr().String())
  180. }
  181. defer c.Close()
  182. if err := c.Close(); err != nil {
  183. if perr := parseCloseError(err, false); perr != nil {
  184. t.Error(perr)
  185. }
  186. t.Fatal(err)
  187. }
  188. var b [1]byte
  189. n, err := c.Read(b[:])
  190. if n != 0 || err == nil {
  191. t.Fatalf("got (%d, %v); want (0, error)", n, err)
  192. }
  193. })
  194. }
  195. }
  196. func TestListenerClose(t *testing.T) {
  197. t.Parallel()
  198. for _, network := range []string{"tcp", "unix", "unixpacket"} {
  199. network := network
  200. t.Run(network, func(t *testing.T) {
  201. if !testableNetwork(network) {
  202. t.Skipf("network %s is not testable on the current platform", network)
  203. }
  204. t.Parallel()
  205. ln := newLocalListener(t, network)
  206. switch network {
  207. case "unix", "unixpacket":
  208. defer os.Remove(ln.Addr().String())
  209. }
  210. if err := ln.Close(); err != nil {
  211. if perr := parseCloseError(err, false); perr != nil {
  212. t.Error(perr)
  213. }
  214. t.Fatal(err)
  215. }
  216. c, err := ln.Accept()
  217. if err == nil {
  218. c.Close()
  219. t.Fatal("should fail")
  220. }
  221. // Note: we cannot ensure that a subsequent Dial does not succeed, because
  222. // we do not in general have any guarantee that ln.Addr is not immediately
  223. // reused. (TCP sockets enter a TIME_WAIT state when closed, but that only
  224. // applies to existing connections for the port — it does not prevent the
  225. // port itself from being used for entirely new connections in the
  226. // meantime.)
  227. })
  228. }
  229. }
  230. func TestPacketConnClose(t *testing.T) {
  231. t.Parallel()
  232. for _, network := range []string{"udp", "unixgram"} {
  233. network := network
  234. t.Run(network, func(t *testing.T) {
  235. if !testableNetwork(network) {
  236. t.Skipf("network %s is not testable on the current platform", network)
  237. }
  238. t.Parallel()
  239. c := newLocalPacketListener(t, network)
  240. switch network {
  241. case "unixgram":
  242. defer os.Remove(c.LocalAddr().String())
  243. }
  244. defer c.Close()
  245. if err := c.Close(); err != nil {
  246. if perr := parseCloseError(err, false); perr != nil {
  247. t.Error(perr)
  248. }
  249. t.Fatal(err)
  250. }
  251. var b [1]byte
  252. n, _, err := c.ReadFrom(b[:])
  253. if n != 0 || err == nil {
  254. t.Fatalf("got (%d, %v); want (0, error)", n, err)
  255. }
  256. })
  257. }
  258. }
  259. func TestListenCloseListen(t *testing.T) {
  260. const maxTries = 10
  261. for tries := 0; tries < maxTries; tries++ {
  262. ln := newLocalListener(t, "tcp")
  263. addr := ln.Addr().String()
  264. // TODO: This is racy. The selected address could be reused in between this
  265. // Close and the subsequent Listen.
  266. if err := ln.Close(); err != nil {
  267. if perr := parseCloseError(err, false); perr != nil {
  268. t.Error(perr)
  269. }
  270. t.Fatal(err)
  271. }
  272. ln, err := Listen("tcp", addr)
  273. if err == nil {
  274. // Success. (This test didn't always make it here earlier.)
  275. ln.Close()
  276. return
  277. }
  278. t.Errorf("failed on try %d/%d: %v", tries+1, maxTries, err)
  279. }
  280. t.Fatalf("failed to listen/close/listen on same address after %d tries", maxTries)
  281. }
  282. // See golang.org/issue/6163, golang.org/issue/6987.
  283. func TestAcceptIgnoreAbortedConnRequest(t *testing.T) {
  284. switch runtime.GOOS {
  285. case "plan9":
  286. t.Skipf("%s does not have full support of socktest", runtime.GOOS)
  287. }
  288. syserr := make(chan error)
  289. go func() {
  290. defer close(syserr)
  291. for _, err := range abortedConnRequestErrors {
  292. syserr <- err
  293. }
  294. }()
  295. sw.Set(socktest.FilterAccept, func(so *socktest.Status) (socktest.AfterFilter, error) {
  296. if err, ok := <-syserr; ok {
  297. return nil, err
  298. }
  299. return nil, nil
  300. })
  301. defer sw.Set(socktest.FilterAccept, nil)
  302. operr := make(chan error, 1)
  303. handler := func(ls *localServer, ln Listener) {
  304. defer close(operr)
  305. c, err := ln.Accept()
  306. if err != nil {
  307. if perr := parseAcceptError(err); perr != nil {
  308. operr <- perr
  309. }
  310. operr <- err
  311. return
  312. }
  313. c.Close()
  314. }
  315. ls := newLocalServer(t, "tcp")
  316. defer ls.teardown()
  317. if err := ls.buildup(handler); err != nil {
  318. t.Fatal(err)
  319. }
  320. c, err := Dial(ls.Listener.Addr().Network(), ls.Listener.Addr().String())
  321. if err != nil {
  322. t.Fatal(err)
  323. }
  324. c.Close()
  325. for err := range operr {
  326. t.Error(err)
  327. }
  328. }
  329. func TestZeroByteRead(t *testing.T) {
  330. t.Parallel()
  331. for _, network := range []string{"tcp", "unix", "unixpacket"} {
  332. network := network
  333. t.Run(network, func(t *testing.T) {
  334. if !testableNetwork(network) {
  335. t.Skipf("network %s is not testable on the current platform", network)
  336. }
  337. t.Parallel()
  338. ln := newLocalListener(t, network)
  339. connc := make(chan Conn, 1)
  340. go func() {
  341. defer ln.Close()
  342. c, err := ln.Accept()
  343. if err != nil {
  344. t.Error(err)
  345. }
  346. connc <- c // might be nil
  347. }()
  348. c, err := Dial(network, ln.Addr().String())
  349. if err != nil {
  350. t.Fatal(err)
  351. }
  352. defer c.Close()
  353. sc := <-connc
  354. if sc == nil {
  355. return
  356. }
  357. defer sc.Close()
  358. if runtime.GOOS == "windows" {
  359. // A zero byte read on Windows caused a wait for readability first.
  360. // Rather than change that behavior, satisfy it in this test.
  361. // See Issue 15735.
  362. go io.WriteString(sc, "a")
  363. }
  364. n, err := c.Read(nil)
  365. if n != 0 || err != nil {
  366. t.Errorf("%s: zero byte client read = %v, %v; want 0, nil", network, n, err)
  367. }
  368. if runtime.GOOS == "windows" {
  369. // Same as comment above.
  370. go io.WriteString(c, "a")
  371. }
  372. n, err = sc.Read(nil)
  373. if n != 0 || err != nil {
  374. t.Errorf("%s: zero byte server read = %v, %v; want 0, nil", network, n, err)
  375. }
  376. })
  377. }
  378. }
  379. // withTCPConnPair sets up a TCP connection between two peers, then
  380. // runs peer1 and peer2 concurrently. withTCPConnPair returns when
  381. // both have completed.
  382. func withTCPConnPair(t *testing.T, peer1, peer2 func(c *TCPConn) error) {
  383. ln := newLocalListener(t, "tcp")
  384. defer ln.Close()
  385. errc := make(chan error, 2)
  386. go func() {
  387. c1, err := ln.Accept()
  388. if err != nil {
  389. errc <- err
  390. return
  391. }
  392. defer c1.Close()
  393. errc <- peer1(c1.(*TCPConn))
  394. }()
  395. go func() {
  396. c2, err := Dial("tcp", ln.Addr().String())
  397. if err != nil {
  398. errc <- err
  399. return
  400. }
  401. defer c2.Close()
  402. errc <- peer2(c2.(*TCPConn))
  403. }()
  404. for i := 0; i < 2; i++ {
  405. if err := <-errc; err != nil {
  406. t.Fatal(err)
  407. }
  408. }
  409. }
  410. // Tests that a blocked Read is interrupted by a concurrent SetReadDeadline
  411. // modifying that Conn's read deadline to the past.
  412. // See golang.org/cl/30164 which documented this. The net/http package
  413. // depends on this.
  414. func TestReadTimeoutUnblocksRead(t *testing.T) {
  415. serverDone := make(chan struct{})
  416. server := func(cs *TCPConn) error {
  417. defer close(serverDone)
  418. errc := make(chan error, 1)
  419. go func() {
  420. defer close(errc)
  421. go func() {
  422. // TODO: find a better way to wait
  423. // until we're blocked in the cs.Read
  424. // call below. Sleep is lame.
  425. time.Sleep(100 * time.Millisecond)
  426. // Interrupt the upcoming Read, unblocking it:
  427. cs.SetReadDeadline(time.Unix(123, 0)) // time in the past
  428. }()
  429. var buf [1]byte
  430. n, err := cs.Read(buf[:1])
  431. if n != 0 || err == nil {
  432. errc <- fmt.Errorf("Read = %v, %v; want 0, non-nil", n, err)
  433. }
  434. }()
  435. select {
  436. case err := <-errc:
  437. return err
  438. case <-time.After(5 * time.Second):
  439. buf := make([]byte, 2<<20)
  440. buf = buf[:runtime.Stack(buf, true)]
  441. println("Stacks at timeout:\n", string(buf))
  442. return errors.New("timeout waiting for Read to finish")
  443. }
  444. }
  445. // Do nothing in the client. Never write. Just wait for the
  446. // server's half to be done.
  447. client := func(*TCPConn) error {
  448. <-serverDone
  449. return nil
  450. }
  451. withTCPConnPair(t, client, server)
  452. }
  453. // Issue 17695: verify that a blocked Read is woken up by a Close.
  454. func TestCloseUnblocksRead(t *testing.T) {
  455. t.Parallel()
  456. server := func(cs *TCPConn) error {
  457. // Give the client time to get stuck in a Read:
  458. time.Sleep(20 * time.Millisecond)
  459. cs.Close()
  460. return nil
  461. }
  462. client := func(ss *TCPConn) error {
  463. n, err := ss.Read([]byte{0})
  464. if n != 0 || err != io.EOF {
  465. return fmt.Errorf("Read = %v, %v; want 0, EOF", n, err)
  466. }
  467. return nil
  468. }
  469. withTCPConnPair(t, client, server)
  470. }
  471. // Issue 24808: verify that ECONNRESET is not temporary for read.
  472. func TestNotTemporaryRead(t *testing.T) {
  473. t.Parallel()
  474. ln := newLocalListener(t, "tcp")
  475. serverDone := make(chan struct{})
  476. dialed := make(chan struct{})
  477. go func() {
  478. defer close(serverDone)
  479. cs, err := ln.Accept()
  480. if err != nil {
  481. return
  482. }
  483. <-dialed
  484. cs.(*TCPConn).SetLinger(0)
  485. cs.Close()
  486. ln.Close()
  487. }()
  488. defer func() { <-serverDone }()
  489. ss, err := Dial("tcp", ln.Addr().String())
  490. if err != nil {
  491. t.Fatal(err)
  492. }
  493. defer ss.Close()
  494. close(dialed)
  495. _, err = ss.Read([]byte{0})
  496. if err == nil {
  497. t.Fatal("Read succeeded unexpectedly")
  498. } else if err == io.EOF {
  499. // This happens on Plan 9, but for some reason (prior to CL 385314) it was
  500. // accepted everywhere else too.
  501. if runtime.GOOS == "plan9" {
  502. return
  503. }
  504. // TODO: during an open development cycle, try making this a failure
  505. // and see whether it causes the test to become flaky anywhere else.
  506. return
  507. }
  508. if ne, ok := err.(Error); !ok {
  509. t.Errorf("Read error does not implement net.Error: %v", err)
  510. } else if ne.Temporary() {
  511. t.Errorf("Read error is unexpectedly temporary: %v", err)
  512. }
  513. }
  514. // The various errors should implement the Error interface.
  515. func TestErrors(t *testing.T) {
  516. var (
  517. _ Error = &OpError{}
  518. _ Error = &ParseError{}
  519. _ Error = &AddrError{}
  520. _ Error = UnknownNetworkError("")
  521. _ Error = InvalidAddrError("")
  522. _ Error = &timeoutError{}
  523. _ Error = &DNSConfigError{}
  524. _ Error = &DNSError{}
  525. )
  526. // ErrClosed was introduced as type error, so we can't check
  527. // it using a declaration.
  528. if _, ok := ErrClosed.(Error); !ok {
  529. t.Fatal("ErrClosed does not implement Error")
  530. }
  531. }