2016-03-01 22:57:46 +00:00
|
|
|
// Copyright 2012 The Go Authors. All rights reserved.
|
2012-01-27 01:31:42 +09:00
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
2018-03-04 12:18:32 +01:00
|
|
|
// +build !js
|
|
|
|
|
|
2012-01-27 01:31:42 +09:00
|
|
|
package net
|
|
|
|
|
|
|
|
|
|
import (
|
2016-04-14 12:17:44 +09:00
|
|
|
"internal/testenv"
|
2012-11-28 06:36:05 +09:00
|
|
|
"reflect"
|
2012-01-27 01:31:42 +09:00
|
|
|
"runtime"
|
|
|
|
|
"testing"
|
2014-10-10 09:21:32 +11:00
|
|
|
"time"
|
2012-01-27 01:31:42 +09:00
|
|
|
)
|
|
|
|
|
|
2016-04-13 06:19:53 +09:00
|
|
|
func BenchmarkUDP6LinkLocalUnicast(b *testing.B) {
|
|
|
|
|
testHookUninstaller.Do(uninstallTestHooks)
|
|
|
|
|
|
2017-04-14 17:43:42 +09:00
|
|
|
if !supportsIPv6() {
|
2016-04-13 06:19:53 +09:00
|
|
|
b.Skip("IPv6 is not supported")
|
|
|
|
|
}
|
|
|
|
|
ifi := loopbackInterface()
|
|
|
|
|
if ifi == nil {
|
|
|
|
|
b.Skip("loopback interface not found")
|
|
|
|
|
}
|
|
|
|
|
lla := ipv6LinkLocalUnicastAddr(ifi)
|
|
|
|
|
if lla == "" {
|
|
|
|
|
b.Skip("IPv6 link-local unicast address not found")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
c1, err := ListenPacket("udp6", JoinHostPort(lla+"%"+ifi.Name, "0"))
|
|
|
|
|
if err != nil {
|
|
|
|
|
b.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
defer c1.Close()
|
|
|
|
|
c2, err := ListenPacket("udp6", JoinHostPort(lla+"%"+ifi.Name, "0"))
|
|
|
|
|
if err != nil {
|
|
|
|
|
b.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
defer c2.Close()
|
|
|
|
|
|
|
|
|
|
var buf [1]byte
|
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
|
if _, err := c1.WriteTo(buf[:], c2.LocalAddr()); err != nil {
|
|
|
|
|
b.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
if _, _, err := c2.ReadFrom(buf[:]); err != nil {
|
|
|
|
|
b.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2015-04-05 17:00:14 +09:00
|
|
|
type resolveUDPAddrTest struct {
|
|
|
|
|
network string
|
|
|
|
|
litAddrOrName string
|
|
|
|
|
addr *UDPAddr
|
|
|
|
|
err error
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var resolveUDPAddrTests = []resolveUDPAddrTest{
|
|
|
|
|
{"udp", "127.0.0.1:0", &UDPAddr{IP: IPv4(127, 0, 0, 1), Port: 0}, nil},
|
|
|
|
|
{"udp4", "127.0.0.1:65535", &UDPAddr{IP: IPv4(127, 0, 0, 1), Port: 65535}, nil},
|
|
|
|
|
|
|
|
|
|
{"udp", "[::1]:0", &UDPAddr{IP: ParseIP("::1"), Port: 0}, nil},
|
|
|
|
|
{"udp6", "[::1]:65535", &UDPAddr{IP: ParseIP("::1"), Port: 65535}, nil},
|
|
|
|
|
|
|
|
|
|
{"udp", "[::1%en0]:1", &UDPAddr{IP: ParseIP("::1"), Port: 1, Zone: "en0"}, nil},
|
|
|
|
|
{"udp6", "[::1%911]:2", &UDPAddr{IP: ParseIP("::1"), Port: 2, Zone: "911"}, nil},
|
|
|
|
|
|
|
|
|
|
{"", "127.0.0.1:0", &UDPAddr{IP: IPv4(127, 0, 0, 1), Port: 0}, nil}, // Go 1.0 behavior
|
|
|
|
|
{"", "[::1]:0", &UDPAddr{IP: ParseIP("::1"), Port: 0}, nil}, // Go 1.0 behavior
|
|
|
|
|
|
|
|
|
|
{"udp", ":12345", &UDPAddr{Port: 12345}, nil},
|
|
|
|
|
|
|
|
|
|
{"http", "127.0.0.1:0", nil, UnknownNetworkError("http")},
|
2016-12-20 17:39:54 +09:00
|
|
|
|
|
|
|
|
{"udp", "127.0.0.1:domain", &UDPAddr{IP: ParseIP("127.0.0.1"), Port: 53}, nil},
|
|
|
|
|
{"udp", "[::ffff:127.0.0.1]:domain", &UDPAddr{IP: ParseIP("::ffff:127.0.0.1"), Port: 53}, nil},
|
|
|
|
|
{"udp", "[2001:db8::1]:domain", &UDPAddr{IP: ParseIP("2001:db8::1"), Port: 53}, nil},
|
|
|
|
|
{"udp4", "127.0.0.1:domain", &UDPAddr{IP: ParseIP("127.0.0.1"), Port: 53}, nil},
|
|
|
|
|
{"udp4", "[::ffff:127.0.0.1]:domain", &UDPAddr{IP: ParseIP("127.0.0.1"), Port: 53}, nil},
|
|
|
|
|
{"udp6", "[2001:db8::1]:domain", &UDPAddr{IP: ParseIP("2001:db8::1"), Port: 53}, nil},
|
|
|
|
|
|
|
|
|
|
{"udp4", "[2001:db8::1]:domain", nil, &AddrError{Err: errNoSuitableAddress.Error(), Addr: "2001:db8::1"}},
|
|
|
|
|
{"udp6", "127.0.0.1:domain", nil, &AddrError{Err: errNoSuitableAddress.Error(), Addr: "127.0.0.1"}},
|
|
|
|
|
{"udp6", "[::ffff:127.0.0.1]:domain", nil, &AddrError{Err: errNoSuitableAddress.Error(), Addr: "::ffff:127.0.0.1"}},
|
2015-04-05 17:00:14 +09:00
|
|
|
}
|
|
|
|
|
|
2012-11-28 06:36:05 +09:00
|
|
|
func TestResolveUDPAddr(t *testing.T) {
|
2015-04-05 17:00:14 +09:00
|
|
|
origTestHookLookupIP := testHookLookupIP
|
|
|
|
|
defer func() { testHookLookupIP = origTestHookLookupIP }()
|
|
|
|
|
testHookLookupIP = lookupLocalhost
|
|
|
|
|
|
2016-12-20 17:39:54 +09:00
|
|
|
for _, tt := range resolveUDPAddrTests {
|
2015-04-05 17:00:14 +09:00
|
|
|
addr, err := ResolveUDPAddr(tt.network, tt.litAddrOrName)
|
2016-12-20 17:39:54 +09:00
|
|
|
if !reflect.DeepEqual(addr, tt.addr) || !reflect.DeepEqual(err, tt.err) {
|
|
|
|
|
t.Errorf("ResolveUDPAddr(%q, %q) = %#v, %v, want %#v, %v", tt.network, tt.litAddrOrName, addr, err, tt.addr, tt.err)
|
2015-04-05 17:00:14 +09:00
|
|
|
continue
|
2012-11-28 06:36:05 +09:00
|
|
|
}
|
2016-12-20 17:39:54 +09:00
|
|
|
if err == nil {
|
|
|
|
|
addr2, err := ResolveUDPAddr(addr.Network(), addr.String())
|
|
|
|
|
if !reflect.DeepEqual(addr2, tt.addr) || err != tt.err {
|
|
|
|
|
t.Errorf("(%q, %q): ResolveUDPAddr(%q, %q) = %#v, %v, want %#v, %v", tt.network, tt.litAddrOrName, addr.Network(), addr.String(), addr2, err, tt.addr, tt.err)
|
|
|
|
|
}
|
2012-11-28 06:36:05 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2012-01-27 01:31:42 +09:00
|
|
|
func TestWriteToUDP(t *testing.T) {
|
2012-03-06 15:41:17 +09:00
|
|
|
switch runtime.GOOS {
|
|
|
|
|
case "plan9":
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Skipf("not supported on %s", runtime.GOOS)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
|
2015-02-04 18:05:53 -08:00
|
|
|
c, err := ListenPacket("udp", "127.0.0.1:0")
|
2012-01-27 01:31:42 +09:00
|
|
|
if err != nil {
|
2015-02-04 18:05:53 -08:00
|
|
|
t.Fatal(err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
2015-02-04 18:05:53 -08:00
|
|
|
defer c.Close()
|
2012-01-27 01:31:42 +09:00
|
|
|
|
2015-02-04 18:05:53 -08:00
|
|
|
testWriteToConn(t, c.LocalAddr().String())
|
|
|
|
|
testWriteToPacketConn(t, c.LocalAddr().String())
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testWriteToConn(t *testing.T, raddr string) {
|
|
|
|
|
c, err := Dial("udp", raddr)
|
|
|
|
|
if err != nil {
|
2015-02-04 18:05:53 -08:00
|
|
|
t.Fatal(err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
defer c.Close()
|
|
|
|
|
|
|
|
|
|
ra, err := ResolveUDPAddr("udp", raddr)
|
|
|
|
|
if err != nil {
|
2015-02-04 18:05:53 -08:00
|
|
|
t.Fatal(err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
|
2015-05-01 12:38:42 +09:00
|
|
|
b := []byte("CONNECTED-MODE SOCKET")
|
|
|
|
|
_, err = c.(*UDPConn).WriteToUDP(b, ra)
|
2012-01-27 01:31:42 +09:00
|
|
|
if err == nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal("should fail")
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
if err != nil && err.(*OpError).Err != ErrWriteToConnected {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatalf("should fail as ErrWriteToConnected: %v", err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
2015-05-01 12:38:42 +09:00
|
|
|
_, err = c.(*UDPConn).WriteTo(b, ra)
|
2012-01-27 01:31:42 +09:00
|
|
|
if err == nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal("should fail")
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
if err != nil && err.(*OpError).Err != ErrWriteToConnected {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatalf("should fail as ErrWriteToConnected: %v", err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
2015-05-01 12:38:42 +09:00
|
|
|
_, err = c.Write(b)
|
2012-01-27 01:31:42 +09:00
|
|
|
if err != nil {
|
2015-02-04 18:05:53 -08:00
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
2015-05-01 12:38:42 +09:00
|
|
|
_, _, err = c.(*UDPConn).WriteMsgUDP(b, nil, ra)
|
2015-02-04 18:05:53 -08:00
|
|
|
if err == nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal("should fail")
|
2015-02-04 18:05:53 -08:00
|
|
|
}
|
|
|
|
|
if err != nil && err.(*OpError).Err != ErrWriteToConnected {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatalf("should fail as ErrWriteToConnected: %v", err)
|
2015-02-04 18:05:53 -08:00
|
|
|
}
|
2015-05-01 12:38:42 +09:00
|
|
|
_, _, err = c.(*UDPConn).WriteMsgUDP(b, nil, nil)
|
2019-10-08 19:19:13 +00:00
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testWriteToPacketConn(t *testing.T, raddr string) {
|
|
|
|
|
c, err := ListenPacket("udp", "127.0.0.1:0")
|
|
|
|
|
if err != nil {
|
2015-02-04 18:05:53 -08:00
|
|
|
t.Fatal(err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
defer c.Close()
|
|
|
|
|
|
|
|
|
|
ra, err := ResolveUDPAddr("udp", raddr)
|
|
|
|
|
if err != nil {
|
2015-02-04 18:05:53 -08:00
|
|
|
t.Fatal(err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
|
|
|
|
|
2015-05-01 12:38:42 +09:00
|
|
|
b := []byte("UNCONNECTED-MODE SOCKET")
|
|
|
|
|
_, err = c.(*UDPConn).WriteToUDP(b, ra)
|
2012-01-27 01:31:42 +09:00
|
|
|
if err != nil {
|
2015-02-04 18:05:53 -08:00
|
|
|
t.Fatal(err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
2015-05-01 12:38:42 +09:00
|
|
|
_, err = c.WriteTo(b, ra)
|
2012-01-27 01:31:42 +09:00
|
|
|
if err != nil {
|
2015-02-04 18:05:53 -08:00
|
|
|
t.Fatal(err)
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
2015-05-01 12:38:42 +09:00
|
|
|
_, err = c.(*UDPConn).Write(b)
|
2012-01-27 01:31:42 +09:00
|
|
|
if err == nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal("should fail")
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
2015-05-01 12:38:42 +09:00
|
|
|
_, _, err = c.(*UDPConn).WriteMsgUDP(b, nil, nil)
|
2015-02-04 18:05:53 -08:00
|
|
|
if err == nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal("should fail")
|
2015-02-04 18:05:53 -08:00
|
|
|
}
|
|
|
|
|
if err != nil && err.(*OpError).Err != errMissingAddress {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatalf("should fail as errMissingAddress: %v", err)
|
2015-02-04 18:05:53 -08:00
|
|
|
}
|
2015-05-01 12:38:42 +09:00
|
|
|
_, _, err = c.(*UDPConn).WriteMsgUDP(b, nil, ra)
|
2019-10-08 19:19:13 +00:00
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
2015-02-04 18:05:53 -08:00
|
|
|
}
|
2012-01-27 01:31:42 +09:00
|
|
|
}
|
2012-11-13 12:56:28 +09:00
|
|
|
|
|
|
|
|
var udpConnLocalNameTests = []struct {
|
|
|
|
|
net string
|
|
|
|
|
laddr *UDPAddr
|
|
|
|
|
}{
|
|
|
|
|
{"udp4", &UDPAddr{IP: IPv4(127, 0, 0, 1)}},
|
|
|
|
|
{"udp4", &UDPAddr{}},
|
|
|
|
|
{"udp4", nil},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestUDPConnLocalName(t *testing.T) {
|
2016-04-14 12:17:44 +09:00
|
|
|
testenv.MustHaveExternalNetwork(t)
|
2012-11-13 12:56:28 +09:00
|
|
|
|
|
|
|
|
for _, tt := range udpConnLocalNameTests {
|
|
|
|
|
c, err := ListenUDP(tt.net, tt.laddr)
|
|
|
|
|
if err != nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal(err)
|
2012-11-13 12:56:28 +09:00
|
|
|
}
|
|
|
|
|
defer c.Close()
|
|
|
|
|
la := c.LocalAddr()
|
|
|
|
|
if a, ok := la.(*UDPAddr); !ok || a.Port == 0 {
|
2013-03-23 22:32:19 +09:00
|
|
|
t.Fatalf("got %v; expected a proper address with non-zero port number", la)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestUDPConnLocalAndRemoteNames(t *testing.T) {
|
|
|
|
|
for _, laddr := range []string{"", "127.0.0.1:0"} {
|
|
|
|
|
c1, err := ListenPacket("udp", "127.0.0.1:0")
|
|
|
|
|
if err != nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal(err)
|
2013-03-23 22:32:19 +09:00
|
|
|
}
|
|
|
|
|
defer c1.Close()
|
|
|
|
|
|
|
|
|
|
var la *UDPAddr
|
|
|
|
|
if laddr != "" {
|
|
|
|
|
var err error
|
|
|
|
|
if la, err = ResolveUDPAddr("udp", laddr); err != nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal(err)
|
2013-03-23 22:32:19 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
c2, err := DialUDP("udp", la, c1.LocalAddr().(*UDPAddr))
|
|
|
|
|
if err != nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal(err)
|
2013-03-23 22:32:19 +09:00
|
|
|
}
|
|
|
|
|
defer c2.Close()
|
|
|
|
|
|
|
|
|
|
var connAddrs = [4]struct {
|
|
|
|
|
got Addr
|
|
|
|
|
ok bool
|
|
|
|
|
}{
|
|
|
|
|
{c1.LocalAddr(), true},
|
|
|
|
|
{c1.(*UDPConn).RemoteAddr(), false},
|
|
|
|
|
{c2.LocalAddr(), true},
|
|
|
|
|
{c2.RemoteAddr(), true},
|
|
|
|
|
}
|
|
|
|
|
for _, ca := range connAddrs {
|
|
|
|
|
if a, ok := ca.got.(*UDPAddr); ok != ca.ok || ok && a.Port == 0 {
|
|
|
|
|
t.Fatalf("got %v; expected a proper address with non-zero port number", ca.got)
|
|
|
|
|
}
|
2012-11-13 12:56:28 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
|
|
|
|
|
func TestIPv6LinkLocalUnicastUDP(t *testing.T) {
|
2016-04-14 12:17:44 +09:00
|
|
|
testenv.MustHaveExternalNetwork(t)
|
|
|
|
|
|
2017-04-14 17:43:42 +09:00
|
|
|
if !supportsIPv6() {
|
2015-05-14 10:18:10 +09:00
|
|
|
t.Skip("IPv6 is not supported")
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
}
|
|
|
|
|
|
2015-05-14 10:18:10 +09:00
|
|
|
for i, tt := range ipv6LinkLocalUnicastUDPTests {
|
|
|
|
|
c1, err := ListenPacket(tt.network, tt.address)
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
if err != nil {
|
|
|
|
|
// It might return "LookupHost returned no
|
|
|
|
|
// suitable address" error on some platforms.
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Log(err)
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
continue
|
|
|
|
|
}
|
2015-05-14 10:18:10 +09:00
|
|
|
ls, err := (&packetListener{PacketConn: c1}).newLocalServer()
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
defer ls.teardown()
|
|
|
|
|
ch := make(chan error, 1)
|
|
|
|
|
handler := func(ls *localPacketServer, c PacketConn) { packetTransponder(c, ch) }
|
|
|
|
|
if err := ls.buildup(handler); err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
if la, ok := c1.LocalAddr().(*UDPAddr); !ok || !tt.nameLookup && la.Zone == "" {
|
|
|
|
|
t.Fatalf("got %v; expected a proper address with zone identifier", la)
|
|
|
|
|
}
|
|
|
|
|
|
2015-05-14 10:18:10 +09:00
|
|
|
c2, err := Dial(tt.network, ls.PacketConn.LocalAddr().String())
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
if err != nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal(err)
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
}
|
|
|
|
|
defer c2.Close()
|
|
|
|
|
if la, ok := c2.LocalAddr().(*UDPAddr); !ok || !tt.nameLookup && la.Zone == "" {
|
|
|
|
|
t.Fatalf("got %v; expected a proper address with zone identifier", la)
|
|
|
|
|
}
|
|
|
|
|
if ra, ok := c2.RemoteAddr().(*UDPAddr); !ok || !tt.nameLookup && ra.Zone == "" {
|
|
|
|
|
t.Fatalf("got %v; expected a proper address with zone identifier", ra)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if _, err := c2.Write([]byte("UDP OVER IPV6 LINKLOCAL TEST")); err != nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal(err)
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
}
|
|
|
|
|
b := make([]byte, 32)
|
2015-05-14 10:18:10 +09:00
|
|
|
if _, err := c2.Read(b); err != nil {
|
2015-05-01 12:38:42 +09:00
|
|
|
t.Fatal(err)
|
2015-05-14 10:18:10 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for err := range ch {
|
|
|
|
|
t.Errorf("#%d: %v", i, err)
|
net: support IPv6 scoped addressing zone
This CL provides IPv6 scoped addressing zone support as defined
in RFC 4007 for internet protocol family connection setups.
Follwoing types and functions allow a literal IPv6 address with
zone identifer as theirs parameter.
pkg net, func Dial(string, string) (Conn, error)
pkg net, func DialOpt(string, ...DialOption) (Conn, error)
pkg net, func DialTimeout(string, string, time.Duration) (Conn, error)
pkg net, func Listen(string, string) (Listener, error)
pkg net, func ListenPacket(string, string) (PacketConn, error)
pkg net, func ResolveIPAddr(string, string) (*IPAddr, error)
pkg net, func ResolveTCPAddr(string, string) (*TCPAddr, error)
pkg net, func ResolveUDPAddr(string, string) (*UDPAddr, error)
pkg net, type IPAddr struct, Zone string
pkg net, type TCPAddr struct, Zone string
pkg net, type UDPAddr struct, Zone string
Also follwoing methods return a literal IPv6 address with zone
identifier string if possible.
pkg net, method (*IPAddr) String() string
pkg net, method (*TCPAddr) String() string
pkg net, method (*UDPAddr) String() string
Fixes #4234.
Fixes #4501.
Update #5081.
R=rsc, iant
CC=golang-dev
https://golang.org/cl/6816116
2013-03-23 09:57:40 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2015-04-20 23:15:00 +09:00
|
|
|
|
|
|
|
|
func TestUDPZeroBytePayload(t *testing.T) {
|
|
|
|
|
switch runtime.GOOS {
|
2019-10-08 19:19:13 +00:00
|
|
|
case "plan9":
|
2015-04-20 23:15:00 +09:00
|
|
|
t.Skipf("not supported on %s", runtime.GOOS)
|
2020-09-16 16:59:58 -04:00
|
|
|
case "darwin", "ios":
|
2019-01-02 19:57:11 -08:00
|
|
|
testenv.SkipFlaky(t, 29225)
|
2015-04-20 23:15:00 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
c, err := newLocalPacketListener("udp")
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
defer c.Close()
|
|
|
|
|
|
|
|
|
|
for _, genericRead := range []bool{false, true} {
|
|
|
|
|
n, err := c.WriteTo(nil, c.LocalAddr())
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
if n != 0 {
|
|
|
|
|
t.Errorf("got %d; want 0", n)
|
|
|
|
|
}
|
net: don't accept timeouts in TestUDPZeroBytePayload
Before this CL we accepted timeouts in TestUDPZeroBytePayload to avoid
flakiness and because, according to CL 9194, the test didn't work on
some platforms. On Windows, before CL 132781, the read would always
timeout, and so since the test accepted timeouts it would pass
incorrectly. CL 132781 fixed Windows, and changed the test to not
accept timeouts in the ReadFrom case.
However, the timeout was short, and so on a loaded system the Read
might timeout not due to an error in the code, but just because the
read was not delivered. So ignoring timeouts made the test flaky, as
reported in issue #29225.
This CL tries to get to a better state by increasing the timeout to a
large value and not permitting timeouts at all. If there are systems
where the test fails, we will need to explicitly skip the test on
those systems.
Fixes #29225
Change-Id: I26863369898a69cac866b34fcb5b6ffbffab31f6
Reviewed-on: https://go-review.googlesource.com/c/154759
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Alex Brainman <alex.brainman@gmail.com>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
2018-12-18 15:10:38 -08:00
|
|
|
c.SetReadDeadline(time.Now().Add(30 * time.Second))
|
2015-04-20 23:15:00 +09:00
|
|
|
var b [1]byte
|
net: don't accept timeouts in TestUDPZeroBytePayload
Before this CL we accepted timeouts in TestUDPZeroBytePayload to avoid
flakiness and because, according to CL 9194, the test didn't work on
some platforms. On Windows, before CL 132781, the read would always
timeout, and so since the test accepted timeouts it would pass
incorrectly. CL 132781 fixed Windows, and changed the test to not
accept timeouts in the ReadFrom case.
However, the timeout was short, and so on a loaded system the Read
might timeout not due to an error in the code, but just because the
read was not delivered. So ignoring timeouts made the test flaky, as
reported in issue #29225.
This CL tries to get to a better state by increasing the timeout to a
large value and not permitting timeouts at all. If there are systems
where the test fails, we will need to explicitly skip the test on
those systems.
Fixes #29225
Change-Id: I26863369898a69cac866b34fcb5b6ffbffab31f6
Reviewed-on: https://go-review.googlesource.com/c/154759
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Alex Brainman <alex.brainman@gmail.com>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
2018-12-18 15:10:38 -08:00
|
|
|
var name string
|
2015-04-20 23:15:00 +09:00
|
|
|
if genericRead {
|
|
|
|
|
_, err = c.(Conn).Read(b[:])
|
net: don't accept timeouts in TestUDPZeroBytePayload
Before this CL we accepted timeouts in TestUDPZeroBytePayload to avoid
flakiness and because, according to CL 9194, the test didn't work on
some platforms. On Windows, before CL 132781, the read would always
timeout, and so since the test accepted timeouts it would pass
incorrectly. CL 132781 fixed Windows, and changed the test to not
accept timeouts in the ReadFrom case.
However, the timeout was short, and so on a loaded system the Read
might timeout not due to an error in the code, but just because the
read was not delivered. So ignoring timeouts made the test flaky, as
reported in issue #29225.
This CL tries to get to a better state by increasing the timeout to a
large value and not permitting timeouts at all. If there are systems
where the test fails, we will need to explicitly skip the test on
those systems.
Fixes #29225
Change-Id: I26863369898a69cac866b34fcb5b6ffbffab31f6
Reviewed-on: https://go-review.googlesource.com/c/154759
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Alex Brainman <alex.brainman@gmail.com>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
2018-12-18 15:10:38 -08:00
|
|
|
name = "Read"
|
2015-04-20 23:15:00 +09:00
|
|
|
} else {
|
|
|
|
|
_, _, err = c.ReadFrom(b[:])
|
net: don't accept timeouts in TestUDPZeroBytePayload
Before this CL we accepted timeouts in TestUDPZeroBytePayload to avoid
flakiness and because, according to CL 9194, the test didn't work on
some platforms. On Windows, before CL 132781, the read would always
timeout, and so since the test accepted timeouts it would pass
incorrectly. CL 132781 fixed Windows, and changed the test to not
accept timeouts in the ReadFrom case.
However, the timeout was short, and so on a loaded system the Read
might timeout not due to an error in the code, but just because the
read was not delivered. So ignoring timeouts made the test flaky, as
reported in issue #29225.
This CL tries to get to a better state by increasing the timeout to a
large value and not permitting timeouts at all. If there are systems
where the test fails, we will need to explicitly skip the test on
those systems.
Fixes #29225
Change-Id: I26863369898a69cac866b34fcb5b6ffbffab31f6
Reviewed-on: https://go-review.googlesource.com/c/154759
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Alex Brainman <alex.brainman@gmail.com>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
2018-12-18 15:10:38 -08:00
|
|
|
name = "ReadFrom"
|
|
|
|
|
}
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Errorf("%s of zero byte packet failed: %v", name, err)
|
2015-04-20 23:15:00 +09:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestUDPZeroByteBuffer(t *testing.T) {
|
|
|
|
|
switch runtime.GOOS {
|
2019-10-08 19:19:13 +00:00
|
|
|
case "plan9":
|
2015-04-20 23:15:00 +09:00
|
|
|
t.Skipf("not supported on %s", runtime.GOOS)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
c, err := newLocalPacketListener("udp")
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
defer c.Close()
|
|
|
|
|
|
2015-05-01 12:38:42 +09:00
|
|
|
b := []byte("UDP ZERO BYTE BUFFER TEST")
|
2015-04-20 23:15:00 +09:00
|
|
|
for _, genericRead := range []bool{false, true} {
|
|
|
|
|
n, err := c.WriteTo(b, c.LocalAddr())
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
if n != len(b) {
|
|
|
|
|
t.Errorf("got %d; want %d", n, len(b))
|
|
|
|
|
}
|
|
|
|
|
c.SetReadDeadline(time.Now().Add(100 * time.Millisecond))
|
|
|
|
|
if genericRead {
|
|
|
|
|
_, err = c.(Conn).Read(nil)
|
|
|
|
|
} else {
|
|
|
|
|
_, _, err = c.ReadFrom(nil)
|
|
|
|
|
}
|
|
|
|
|
switch err {
|
|
|
|
|
case nil: // ReadFrom succeeds
|
|
|
|
|
default: // Read may timeout, it depends on the platform
|
2018-02-07 02:17:50 +01:00
|
|
|
if nerr, ok := err.(Error); (!ok || !nerr.Timeout()) && runtime.GOOS != "windows" { // Windows returns WSAEMSGSIZE
|
2015-04-20 23:15:00 +09:00
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-02-07 02:17:50 +01:00
|
|
|
|
|
|
|
|
func TestUDPReadSizeError(t *testing.T) {
|
|
|
|
|
switch runtime.GOOS {
|
2019-10-08 19:19:13 +00:00
|
|
|
case "plan9":
|
2018-02-07 02:17:50 +01:00
|
|
|
t.Skipf("not supported on %s", runtime.GOOS)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
c1, err := newLocalPacketListener("udp")
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
defer c1.Close()
|
|
|
|
|
|
|
|
|
|
c2, err := Dial("udp", c1.LocalAddr().String())
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
defer c2.Close()
|
|
|
|
|
|
|
|
|
|
b1 := []byte("READ SIZE ERROR TEST")
|
|
|
|
|
for _, genericRead := range []bool{false, true} {
|
|
|
|
|
n, err := c2.Write(b1)
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
if n != len(b1) {
|
|
|
|
|
t.Errorf("got %d; want %d", n, len(b1))
|
|
|
|
|
}
|
|
|
|
|
c1.SetReadDeadline(time.Now().Add(100 * time.Millisecond))
|
|
|
|
|
b2 := make([]byte, len(b1)-1)
|
|
|
|
|
if genericRead {
|
|
|
|
|
n, err = c1.(Conn).Read(b2)
|
|
|
|
|
} else {
|
|
|
|
|
n, _, err = c1.ReadFrom(b2)
|
|
|
|
|
}
|
|
|
|
|
switch err {
|
|
|
|
|
case nil: // ReadFrom succeeds
|
|
|
|
|
default: // Read may timeout, it depends on the platform
|
|
|
|
|
if nerr, ok := err.(Error); (!ok || !nerr.Timeout()) && runtime.GOOS != "windows" { // Windows returns WSAEMSGSIZE
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if n != len(b1)-1 {
|
|
|
|
|
t.Fatalf("got %d; want %d", n, len(b1)-1)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|