mirror of
https://gitclone.com/github.com/MetaCubeX/Clash.Meta
synced 2024-11-15 13:41:23 +08:00
609d69191a
# Conflicts: # .github/workflows/docker.yml # adapter/outboundgroup/fallback.go # adapter/outboundgroup/loadbalance.go # adapter/outboundgroup/relay.go # adapter/outboundgroup/selector.go # adapter/outboundgroup/urltest.go # config/config.go # go.mod # go.sum # main.go # test/go.mod # test/go.sum
195 lines
4.1 KiB
Go
195 lines
4.1 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/Dreamacro/Clash.Meta/adapter/outbound"
|
|
C "github.com/Dreamacro/Clash.Meta/constant"
|
|
|
|
"github.com/docker/docker/api/types/container"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestClash_SnellObfsHTTP(t *testing.T) {
|
|
cfg := &container.Config{
|
|
Image: ImageSnell,
|
|
ExposedPorts: defaultExposedPorts,
|
|
Cmd: []string{"-c", "/config.conf"},
|
|
}
|
|
hostCfg := &container.HostConfig{
|
|
PortBindings: defaultPortBindings,
|
|
Binds: []string{fmt.Sprintf("%s:/config.conf", C.Path.Resolve("snell-http.conf"))},
|
|
}
|
|
|
|
id, err := startContainer(cfg, hostCfg, "snell-http")
|
|
if err != nil {
|
|
assert.FailNow(t, err.Error())
|
|
}
|
|
|
|
t.Cleanup(func() {
|
|
cleanContainer(id)
|
|
})
|
|
|
|
proxy, err := outbound.NewSnell(outbound.SnellOption{
|
|
Name: "snell",
|
|
Server: localIP.String(),
|
|
Port: 10002,
|
|
Psk: "password",
|
|
ObfsOpts: map[string]any{
|
|
"mode": "http",
|
|
},
|
|
})
|
|
if err != nil {
|
|
assert.FailNow(t, err.Error())
|
|
}
|
|
|
|
time.Sleep(waitTime)
|
|
testSuit(t, proxy)
|
|
}
|
|
|
|
func TestClash_SnellObfsTLS(t *testing.T) {
|
|
cfg := &container.Config{
|
|
Image: ImageSnell,
|
|
ExposedPorts: defaultExposedPorts,
|
|
Cmd: []string{"-c", "/config.conf"},
|
|
}
|
|
hostCfg := &container.HostConfig{
|
|
PortBindings: defaultPortBindings,
|
|
Binds: []string{fmt.Sprintf("%s:/config.conf", C.Path.Resolve("snell-tls.conf"))},
|
|
}
|
|
|
|
id, err := startContainer(cfg, hostCfg, "snell-tls")
|
|
if err != nil {
|
|
assert.FailNow(t, err.Error())
|
|
}
|
|
|
|
t.Cleanup(func() {
|
|
cleanContainer(id)
|
|
})
|
|
|
|
proxy, err := outbound.NewSnell(outbound.SnellOption{
|
|
Name: "snell",
|
|
Server: localIP.String(),
|
|
Port: 10002,
|
|
Psk: "password",
|
|
ObfsOpts: map[string]any{
|
|
"mode": "tls",
|
|
},
|
|
})
|
|
if err != nil {
|
|
assert.FailNow(t, err.Error())
|
|
}
|
|
|
|
time.Sleep(waitTime)
|
|
testSuit(t, proxy)
|
|
}
|
|
|
|
func TestClash_Snell(t *testing.T) {
|
|
cfg := &container.Config{
|
|
Image: ImageSnell,
|
|
ExposedPorts: defaultExposedPorts,
|
|
Cmd: []string{"-c", "/config.conf"},
|
|
}
|
|
hostCfg := &container.HostConfig{
|
|
PortBindings: defaultPortBindings,
|
|
Binds: []string{fmt.Sprintf("%s:/config.conf", C.Path.Resolve("snell.conf"))},
|
|
}
|
|
|
|
id, err := startContainer(cfg, hostCfg, "snell")
|
|
if err != nil {
|
|
assert.FailNow(t, err.Error())
|
|
}
|
|
|
|
t.Cleanup(func() {
|
|
cleanContainer(id)
|
|
})
|
|
|
|
proxy, err := outbound.NewSnell(outbound.SnellOption{
|
|
Name: "snell",
|
|
Server: localIP.String(),
|
|
Port: 10002,
|
|
Psk: "password",
|
|
})
|
|
if err != nil {
|
|
assert.FailNow(t, err.Error())
|
|
}
|
|
|
|
time.Sleep(waitTime)
|
|
testSuit(t, proxy)
|
|
}
|
|
|
|
func TestClash_Snellv3(t *testing.T) {
|
|
cfg := &container.Config{
|
|
Image: ImageSnell,
|
|
ExposedPorts: defaultExposedPorts,
|
|
Cmd: []string{"-c", "/config.conf"},
|
|
}
|
|
hostCfg := &container.HostConfig{
|
|
PortBindings: defaultPortBindings,
|
|
Binds: []string{fmt.Sprintf("%s:/config.conf", C.Path.Resolve("snell.conf"))},
|
|
}
|
|
|
|
id, err := startContainer(cfg, hostCfg, "snell")
|
|
if err != nil {
|
|
assert.FailNow(t, err.Error())
|
|
}
|
|
|
|
t.Cleanup(func() {
|
|
cleanContainer(id)
|
|
})
|
|
|
|
proxy, err := outbound.NewSnell(outbound.SnellOption{
|
|
Name: "snell",
|
|
Server: localIP.String(),
|
|
Port: 10002,
|
|
Psk: "password",
|
|
UDP: true,
|
|
Version: 3,
|
|
})
|
|
if err != nil {
|
|
assert.FailNow(t, err.Error())
|
|
}
|
|
|
|
time.Sleep(waitTime)
|
|
testSuit(t, proxy)
|
|
}
|
|
|
|
func Benchmark_Snell(b *testing.B) {
|
|
cfg := &container.Config{
|
|
Image: ImageSnell,
|
|
ExposedPorts: defaultExposedPorts,
|
|
Cmd: []string{"-c", "/config.conf"},
|
|
}
|
|
hostCfg := &container.HostConfig{
|
|
PortBindings: defaultPortBindings,
|
|
Binds: []string{fmt.Sprintf("%s:/config.conf", C.Path.Resolve("snell-http.conf"))},
|
|
}
|
|
|
|
id, err := startContainer(cfg, hostCfg, "snell-http")
|
|
if err != nil {
|
|
assert.FailNow(b, err.Error())
|
|
}
|
|
|
|
b.Cleanup(func() {
|
|
cleanContainer(id)
|
|
})
|
|
|
|
proxy, err := outbound.NewSnell(outbound.SnellOption{
|
|
Name: "snell",
|
|
Server: localIP.String(),
|
|
Port: 10002,
|
|
Psk: "password",
|
|
ObfsOpts: map[string]any{
|
|
"mode": "http",
|
|
},
|
|
})
|
|
if err != nil {
|
|
assert.FailNow(b, err.Error())
|
|
}
|
|
|
|
time.Sleep(waitTime)
|
|
benchmarkProxy(b, proxy)
|
|
}
|