| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237 | package scenariosimport (	"crypto/rand"	"sync"	"testing"	"time"	"v2ray.com/core"	"v2ray.com/core/app/log"	"v2ray.com/core/app/proxyman"	"v2ray.com/core/common/net"	"v2ray.com/core/common/protocol"	"v2ray.com/core/common/serial"	"v2ray.com/core/common/uuid"	"v2ray.com/core/proxy/dokodemo"	"v2ray.com/core/proxy/freedom"	"v2ray.com/core/proxy/vmess"	"v2ray.com/core/proxy/vmess/inbound"	"v2ray.com/core/proxy/vmess/outbound"	"v2ray.com/core/testing/servers/tcp"	"v2ray.com/core/testing/servers/udp"	"v2ray.com/core/transport/internet"	. "v2ray.com/ext/assert")func TestVMessDynamicPort(t *testing.T) {	assert := With(t)	tcpServer := tcp.Server{		MsgProcessor: xor,	}	dest, err := tcpServer.Start()	assert(err, IsNil)	defer tcpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := pickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id: userID.String(),							}),						},					},					Detour: &inbound.DetourConfig{						To: "detour",					},				}),			},			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: &net.PortRange{						From: uint32(serverPort + 1),						To:   uint32(serverPort + 100),					},					Listen: net.NewIPOrDomain(net.LocalHostIP),					AllocationStrategy: &proxyman.AllocationStrategy{						Type: proxyman.AllocationStrategy_Random,						Concurrency: &proxyman.AllocationStrategy_AllocationStrategyConcurrency{							Value: 2,						},						Refresh: &proxyman.AllocationStrategy_AllocationStrategyRefresh{							Value: 5,						},					},				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{}),				Tag:           "detour",			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_TCP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIP),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id: userID.String(),									}),								},							},						},					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	for i := 0; i < 10; i++ {		conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{			IP:   []byte{127, 0, 0, 1},			Port: int(clientPort),		})		assert(err, IsNil)		payload := "dokodemo request."		nBytes, err := conn.Write([]byte(payload))		assert(err, IsNil)		assert(nBytes, Equals, len(payload))		response := make([]byte, 1024)		nBytes, err = conn.Read(response)		assert(err, IsNil)		assert(response[:nBytes], Equals, xor([]byte(payload)))		assert(conn.Close(), IsNil)	}	CloseAllServers(servers)}func TestVMessGCM(t *testing.T) {	assert := With(t)	tcpServer := tcp.Server{		MsgProcessor: xor,	}	dest, err := tcpServer.Start()	assert(err, IsNil)	defer tcpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := pickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id:      userID.String(),								AlterId: 64,							}),						},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_TCP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIP),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id:      userID.String(),										AlterId: 64,										SecuritySettings: &protocol.SecurityConfig{											Type: protocol.SecurityType_AES128_GCM,										},									}),								},							},						},					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	var wg sync.WaitGroup	wg.Add(10)	for i := 0; i < 10; i++ {		go func() {			conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{				IP:   []byte{127, 0, 0, 1},				Port: int(clientPort),			})			assert(err, IsNil)			payload := make([]byte, 10240*1024)			rand.Read(payload)			nBytes, err := conn.Write([]byte(payload))			assert(err, IsNil)			assert(nBytes, Equals, len(payload))			response := readFrom(conn, time.Second*20, 10240*1024)			assert(response, Equals, xor([]byte(payload)))			assert(conn.Close(), IsNil)			wg.Done()		}()	}	wg.Wait()	CloseAllServers(servers)}func TestVMessGCMUDP(t *testing.T) {	assert := With(t)	udpServer := udp.Server{		MsgProcessor: xor,	}	dest, err := udpServer.Start()	assert(err, IsNil)	defer udpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := pickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id:      userID.String(),								AlterId: 64,							}),						},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_UDP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIP),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id:      userID.String(),										AlterId: 64,										SecuritySettings: &protocol.SecurityConfig{											Type: protocol.SecurityType_AES128_GCM,										},									}),								},							},						},					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	var wg sync.WaitGroup	wg.Add(10)	for i := 0; i < 10; i++ {		go func() {			conn, err := net.DialUDP("udp", nil, &net.UDPAddr{				IP:   []byte{127, 0, 0, 1},				Port: int(clientPort),			})			assert(err, IsNil)			payload := make([]byte, 1024)			rand.Read(payload)			nBytes, err := conn.Write([]byte(payload))			assert(err, IsNil)			assert(nBytes, Equals, len(payload))			payload1 := make([]byte, 1024)			rand.Read(payload1)			nBytes, err = conn.Write([]byte(payload1))			assert(err, IsNil)			assert(nBytes, Equals, len(payload1))			response := readFrom(conn, time.Second*5, 1024)			assert(response, Equals, xor([]byte(payload)))			response = readFrom(conn, time.Second*5, 1024)			assert(response, Equals, xor([]byte(payload1)))			assert(conn.Close(), IsNil)			wg.Done()		}()	}	wg.Wait()	CloseAllServers(servers)}func TestVMessChacha20(t *testing.T) {	assert := With(t)	tcpServer := tcp.Server{		MsgProcessor: xor,	}	dest, err := tcpServer.Start()	assert(err, IsNil)	defer tcpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := pickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id:      userID.String(),								AlterId: 64,							}),						},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_TCP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIP),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id:      userID.String(),										AlterId: 64,										SecuritySettings: &protocol.SecurityConfig{											Type: protocol.SecurityType_CHACHA20_POLY1305,										},									}),								},							},						},					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	var wg sync.WaitGroup	wg.Add(10)	for i := 0; i < 10; i++ {		go func() {			conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{				IP:   []byte{127, 0, 0, 1},				Port: int(clientPort),			})			assert(err, IsNil)			payload := make([]byte, 10240*1024)			rand.Read(payload)			nBytes, err := conn.Write([]byte(payload))			assert(err, IsNil)			assert(nBytes, Equals, len(payload))			response := readFrom(conn, time.Second*20, 10240*1024)			assert(response, Equals, xor([]byte(payload)))			assert(conn.Close(), IsNil)			wg.Done()		}()	}	wg.Wait()	CloseAllServers(servers)}func TestVMessNone(t *testing.T) {	assert := With(t)	tcpServer := tcp.Server{		MsgProcessor: xor,	}	dest, err := tcpServer.Start()	assert(err, IsNil)	defer tcpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := pickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id:      userID.String(),								AlterId: 64,							}),						},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_TCP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIP),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id:      userID.String(),										AlterId: 64,										SecuritySettings: &protocol.SecurityConfig{											Type: protocol.SecurityType_NONE,										},									}),								},							},						},					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	var wg sync.WaitGroup	wg.Add(10)	for i := 0; i < 10; i++ {		go func() {			defer wg.Done()			conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{				IP:   []byte{127, 0, 0, 1},				Port: int(clientPort),			})			assert(err, IsNil)			payload := make([]byte, 1024*1024)			rand.Read(payload)			nBytes, err := conn.Write(payload)			assert(err, IsNil)			assert(nBytes, Equals, len(payload))			response := readFrom(conn, time.Second*20, 1024*1024)			assert(response, Equals, xor(payload))			assert(conn.Close(), IsNil)		}()	}	wg.Wait()	CloseAllServers(servers)}func TestVMessKCP(t *testing.T) {	assert := With(t)	tcpServer := tcp.Server{		MsgProcessor: xor,	}	dest, err := tcpServer.Start()	assert(err, IsNil)	defer tcpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := udp.PickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),					StreamSettings: &internet.StreamConfig{						Protocol: internet.TransportProtocol_MKCP,					},				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id:      userID.String(),								AlterId: 64,							}),						},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_TCP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIP),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id:      userID.String(),										AlterId: 64,										SecuritySettings: &protocol.SecurityConfig{											Type: protocol.SecurityType_AES128_GCM,										},									}),								},							},						},					},				}),				SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{					StreamSettings: &internet.StreamConfig{						Protocol: internet.TransportProtocol_MKCP,					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	var wg sync.WaitGroup	for i := 0; i < 10; i++ {		wg.Add(1)		go func() {			conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{				IP:   []byte{127, 0, 0, 1},				Port: int(clientPort),			})			assert(err, IsNil)			payload := make([]byte, 10240*1024)			rand.Read(payload)			nBytes, err := conn.Write(payload)			assert(err, IsNil)			assert(nBytes, Equals, len(payload))			response := readFrom(conn, time.Minute, 10240*1024)			assert(response, Equals, xor(payload))			assert(conn.Close(), IsNil)			wg.Done()		}()	}	wg.Wait()	CloseAllServers(servers)}func TestVMessIPv6(t *testing.T) {	t.SkipNow() // No IPv6 on travis-ci.	assert := With(t)	tcpServer := tcp.Server{		MsgProcessor: xor,		Listen:       net.LocalHostIPv6,	}	dest, err := tcpServer.Start()	assert(err, IsNil)	defer tcpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := pickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIPv6),				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id:      userID.String(),								AlterId: 64,							}),						},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIPv6),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_TCP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIPv6),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id:      userID.String(),										AlterId: 64,										SecuritySettings: &protocol.SecurityConfig{											Type: protocol.SecurityType_AES128_GCM,										},									}),								},							},						},					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{		IP:   net.LocalHostIPv6.IP(),		Port: int(clientPort),	})	assert(err, IsNil)	payload := make([]byte, 1024)	rand.Read(payload)	nBytes, err := conn.Write(payload)	assert(err, IsNil)	assert(nBytes, Equals, len(payload))	response := readFrom(conn, time.Second*20, 1024)	assert(response, Equals, xor(payload))	assert(conn.Close(), IsNil)	CloseAllServers(servers)}func TestVMessGCMMux(t *testing.T) {	assert := With(t)	tcpServer := tcp.Server{		MsgProcessor: xor,	}	dest, err := tcpServer.Start()	assert(err, IsNil)	defer tcpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := pickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id:      userID.String(),								AlterId: 64,							}),						},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_TCP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{					MultiplexSettings: &proxyman.MultiplexingConfig{						Enabled:     true,						Concurrency: 4,					},				}),				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIP),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id:      userID.String(),										AlterId: 64,										SecuritySettings: &protocol.SecurityConfig{											Type: protocol.SecurityType_AES128_GCM,										},									}),								},							},						},					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	for range "abcd" {		var wg sync.WaitGroup		const nConnection = 16		wg.Add(nConnection)		for i := 0; i < nConnection; i++ {			go func() {				conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{					IP:   []byte{127, 0, 0, 1},					Port: int(clientPort),				})				assert(err, IsNil)				payload := make([]byte, 10240)				rand.Read(payload)				xorpayload := xor(payload)				nBytes, err := conn.Write(payload)				assert(err, IsNil)				assert(nBytes, Equals, len(payload))				response := readFrom(conn, time.Second*20, 10240)				assert(response, Equals, xorpayload)				assert(conn.Close(), IsNil)				wg.Done()			}()		}		wg.Wait()		time.Sleep(time.Second)	}	CloseAllServers(servers)}func TestVMessGCMMuxUDP(t *testing.T) {	assert := With(t)	tcpServer := tcp.Server{		MsgProcessor: xor,	}	dest, err := tcpServer.Start()	assert(err, IsNil)	defer tcpServer.Close()	udpServer := udp.Server{		MsgProcessor: xor,	}	udpDest, err := udpServer.Start()	assert(err, IsNil)	defer udpServer.Close()	userID := protocol.NewID(uuid.New())	serverPort := pickPort()	serverConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(serverPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&inbound.Config{					User: []*protocol.User{						{							Account: serial.ToTypedMessage(&vmess.Account{								Id:      userID.String(),								AlterId: 64,							}),						},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				ProxySettings: serial.ToTypedMessage(&freedom.Config{}),			},		},	}	clientPort := pickPort()	clientUDPPort := udp.PickPort()	clientConfig := &core.Config{		App: []*serial.TypedMessage{			serial.ToTypedMessage(&log.Config{				ErrorLogLevel: log.LogLevel_Debug,				ErrorLogType:  log.LogType_Console,			}),		},		Inbound: []*proxyman.InboundHandlerConfig{			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(dest.Address),					Port:    uint32(dest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_TCP},					},				}),			},			{				ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{					PortRange: net.SinglePortRange(clientUDPPort),					Listen:    net.NewIPOrDomain(net.LocalHostIP),				}),				ProxySettings: serial.ToTypedMessage(&dokodemo.Config{					Address: net.NewIPOrDomain(udpDest.Address),					Port:    uint32(udpDest.Port),					NetworkList: &net.NetworkList{						Network: []net.Network{net.Network_UDP},					},				}),			},		},		Outbound: []*proxyman.OutboundHandlerConfig{			{				SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{					MultiplexSettings: &proxyman.MultiplexingConfig{						Enabled:     true,						Concurrency: 4,					},				}),				ProxySettings: serial.ToTypedMessage(&outbound.Config{					Receiver: []*protocol.ServerEndpoint{						{							Address: net.NewIPOrDomain(net.LocalHostIP),							Port:    uint32(serverPort),							User: []*protocol.User{								{									Account: serial.ToTypedMessage(&vmess.Account{										Id:      userID.String(),										AlterId: 64,										SecuritySettings: &protocol.SecurityConfig{											Type: protocol.SecurityType_AES128_GCM,										},									}),								},							},						},					},				}),			},		},	}	servers, err := InitializeServerConfigs(serverConfig, clientConfig)	assert(err, IsNil)	for range "abcd" {		var wg sync.WaitGroup		const nConnection = 16		wg.Add(nConnection * 2)		for i := 0; i < nConnection; i++ {			go func() {				conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{					IP:   []byte{127, 0, 0, 1},					Port: int(clientPort),				})				assert(err, IsNil)				payload := make([]byte, 10240)				rand.Read(payload)				xorpayload := xor(payload)				nBytes, err := conn.Write(payload)				assert(err, IsNil)				assert(nBytes, Equals, len(payload))				response := readFrom(conn, time.Second*20, 10240)				assert(response, Equals, xorpayload)				assert(conn.Close(), IsNil)				wg.Done()			}()		}		for i := 0; i < nConnection; i++ {			go func() {				conn, err := net.DialUDP("udp", nil, &net.UDPAddr{					IP:   []byte{127, 0, 0, 1},					Port: int(clientUDPPort),				})				assert(err, IsNil)				conn.SetDeadline(time.Now().Add(time.Second * 10))				payload := make([]byte, 1024)				rand.Read(payload)				xorpayload := xor(payload)				for j := 0; j < 2; j++ {					nBytes, _, err := conn.WriteMsgUDP(payload, nil, nil)					assert(err, IsNil)					assert(nBytes, Equals, len(payload))				}				response := make([]byte, 1024)				oob := make([]byte, 16)				for j := 0; j < 2; j++ {					nBytes, _, _, _, err := conn.ReadMsgUDP(response, oob)					assert(err, IsNil)					assert(nBytes, Equals, 1024)					assert(response, Equals, xorpayload)				}				assert(conn.Close(), IsNil)				wg.Done()			}()		}		wg.Wait()		time.Sleep(time.Second)	}	CloseAllServers(servers)}
 |