1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-05 00:47:51 -05:00
v2fly/transport/internet/quic/quic_test.go

224 lines
4.8 KiB
Go
Raw Normal View History

2018-11-21 10:47:06 -05:00
package quic_test
import (
"context"
"crypto/rand"
"testing"
"time"
2019-02-10 09:02:28 -05:00
"github.com/google/go-cmp/cmp"
2021-02-16 15:31:50 -05:00
"github.com/v2fly/v2ray-core/v4/common"
"github.com/v2fly/v2ray-core/v4/common/buf"
"github.com/v2fly/v2ray-core/v4/common/net"
"github.com/v2fly/v2ray-core/v4/common/protocol"
"github.com/v2fly/v2ray-core/v4/common/protocol/tls/cert"
"github.com/v2fly/v2ray-core/v4/common/serial"
"github.com/v2fly/v2ray-core/v4/testing/servers/udp"
"github.com/v2fly/v2ray-core/v4/transport/internet"
"github.com/v2fly/v2ray-core/v4/transport/internet/headers/wireguard"
"github.com/v2fly/v2ray-core/v4/transport/internet/quic"
"github.com/v2fly/v2ray-core/v4/transport/internet/tls"
2018-11-21 10:47:06 -05:00
)
func TestQuicConnection(t *testing.T) {
port := udp.PickPort()
listener, err := quic.Listen(context.Background(), net.LocalHostIP, port, &internet.MemoryStreamConfig{
ProtocolName: "quic",
ProtocolSettings: &quic.Config{},
SecurityType: "tls",
SecuritySettings: &tls.Config{
Certificate: []*tls.Certificate{
tls.ParseCertificate(
cert.MustGenerate(nil,
cert.DNSNames("www.v2fly.org"),
),
),
},
2018-11-21 10:47:06 -05:00
},
}, func(conn internet.Connection) {
go func() {
defer conn.Close()
b := buf.New()
defer b.Release()
for {
b.Clear()
if _, err := b.ReadFrom(conn); err != nil {
return
}
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b.Bytes()))
2018-11-21 10:47:06 -05:00
}
}()
})
2019-02-02 16:19:30 -05:00
common.Must(err)
2018-11-21 10:47:06 -05:00
defer listener.Close()
time.Sleep(time.Second)
dctx := context.Background()
conn, err := quic.Dial(dctx, net.TCPDestination(net.LocalHostIP, port), &internet.MemoryStreamConfig{
ProtocolName: "quic",
ProtocolSettings: &quic.Config{},
SecurityType: "tls",
SecuritySettings: &tls.Config{
ServerName: "www.v2fly.org",
2018-11-21 10:47:06 -05:00
AllowInsecure: true,
},
})
2019-02-02 16:19:30 -05:00
common.Must(err)
2018-11-21 10:47:06 -05:00
defer conn.Close()
const N = 1024
b1 := make([]byte, N)
common.Must2(rand.Read(b1))
b2 := buf.New()
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b1))
2018-11-21 10:47:06 -05:00
b2.Clear()
common.Must2(b2.ReadFullFrom(conn, N))
2019-02-10 09:02:28 -05:00
if r := cmp.Diff(b2.Bytes(), b1); r != "" {
t.Error(r)
}
2018-11-21 10:47:06 -05:00
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b1))
2018-11-21 10:47:06 -05:00
b2.Clear()
common.Must2(b2.ReadFullFrom(conn, N))
2019-02-10 09:02:28 -05:00
if r := cmp.Diff(b2.Bytes(), b1); r != "" {
t.Error(r)
}
2018-11-21 10:47:06 -05:00
}
2018-11-21 16:02:19 -05:00
func TestQuicConnectionWithoutTLS(t *testing.T) {
port := udp.PickPort()
listener, err := quic.Listen(context.Background(), net.LocalHostIP, port, &internet.MemoryStreamConfig{
ProtocolName: "quic",
ProtocolSettings: &quic.Config{},
}, func(conn internet.Connection) {
go func() {
defer conn.Close()
b := buf.New()
defer b.Release()
for {
b.Clear()
if _, err := b.ReadFrom(conn); err != nil {
return
}
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b.Bytes()))
2018-11-21 16:02:19 -05:00
}
}()
})
2019-02-02 16:19:30 -05:00
common.Must(err)
2018-11-21 16:02:19 -05:00
defer listener.Close()
time.Sleep(time.Second)
dctx := context.Background()
conn, err := quic.Dial(dctx, net.TCPDestination(net.LocalHostIP, port), &internet.MemoryStreamConfig{
ProtocolName: "quic",
ProtocolSettings: &quic.Config{},
})
2019-02-02 16:19:30 -05:00
common.Must(err)
2018-11-21 16:02:19 -05:00
defer conn.Close()
const N = 1024
b1 := make([]byte, N)
common.Must2(rand.Read(b1))
b2 := buf.New()
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b1))
2018-11-21 16:02:19 -05:00
b2.Clear()
common.Must2(b2.ReadFullFrom(conn, N))
2019-02-10 09:02:28 -05:00
if r := cmp.Diff(b2.Bytes(), b1); r != "" {
t.Error(r)
}
2018-11-21 16:02:19 -05:00
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b1))
2018-11-21 16:02:19 -05:00
b2.Clear()
common.Must2(b2.ReadFullFrom(conn, N))
2019-02-10 09:02:28 -05:00
if r := cmp.Diff(b2.Bytes(), b1); r != "" {
t.Error(r)
}
2018-11-21 16:02:19 -05:00
}
func TestQuicConnectionAuthHeader(t *testing.T) {
port := udp.PickPort()
listener, err := quic.Listen(context.Background(), net.LocalHostIP, port, &internet.MemoryStreamConfig{
ProtocolName: "quic",
ProtocolSettings: &quic.Config{
Header: serial.ToTypedMessage(&wireguard.WireguardConfig{}),
Key: "abcd",
Security: &protocol.SecurityConfig{
Type: protocol.SecurityType_AES128_GCM,
},
},
}, func(conn internet.Connection) {
go func() {
defer conn.Close()
b := buf.New()
defer b.Release()
for {
b.Clear()
if _, err := b.ReadFrom(conn); err != nil {
return
}
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b.Bytes()))
2018-11-21 16:02:19 -05:00
}
}()
})
2019-02-02 16:19:30 -05:00
common.Must(err)
2018-11-21 16:02:19 -05:00
defer listener.Close()
time.Sleep(time.Second)
dctx := context.Background()
conn, err := quic.Dial(dctx, net.TCPDestination(net.LocalHostIP, port), &internet.MemoryStreamConfig{
ProtocolName: "quic",
ProtocolSettings: &quic.Config{
Header: serial.ToTypedMessage(&wireguard.WireguardConfig{}),
Key: "abcd",
Security: &protocol.SecurityConfig{
Type: protocol.SecurityType_AES128_GCM,
},
},
})
2019-02-02 16:19:30 -05:00
common.Must(err)
2018-11-21 16:02:19 -05:00
defer conn.Close()
const N = 1024
b1 := make([]byte, N)
common.Must2(rand.Read(b1))
b2 := buf.New()
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b1))
2018-11-21 16:02:19 -05:00
b2.Clear()
common.Must2(b2.ReadFullFrom(conn, N))
2019-02-10 09:02:28 -05:00
if r := cmp.Diff(b2.Bytes(), b1); r != "" {
t.Error(r)
}
2018-11-21 16:02:19 -05:00
2019-02-10 09:02:28 -05:00
common.Must2(conn.Write(b1))
2018-11-21 16:02:19 -05:00
b2.Clear()
common.Must2(b2.ReadFullFrom(conn, N))
2019-02-10 09:02:28 -05:00
if r := cmp.Diff(b2.Bytes(), b1); r != "" {
t.Error(r)
}
2018-11-21 16:02:19 -05:00
}