mirror of
https://github.com/SagerNet/sing-box.git
synced 2025-01-21 08:16:36 +00:00
99 lines
2.5 KiB
Go
99 lines
2.5 KiB
Go
package main
|
|
|
|
import (
|
|
"net/netip"
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
C "github.com/sagernet/sing-box/constant"
|
|
"github.com/sagernet/sing-box/option"
|
|
)
|
|
|
|
func TestWireGuard(t *testing.T) {
|
|
startDockerContainer(t, DockerOptions{
|
|
Image: ImageBoringTun,
|
|
Cap: []string{"MKNOD", "NET_ADMIN", "NET_RAW"},
|
|
Ports: []uint16{serverPort, testPort},
|
|
Bind: map[string]string{
|
|
"wireguard.conf": "/etc/wireguard/wg0.conf",
|
|
},
|
|
Cmd: []string{"wg0"},
|
|
})
|
|
time.Sleep(5 * time.Second)
|
|
startInstance(t, option.Options{
|
|
Inbounds: []option.Inbound{
|
|
{
|
|
Type: C.TypeMixed,
|
|
MixedOptions: option.HTTPMixedInboundOptions{
|
|
ListenOptions: option.ListenOptions{
|
|
Listen: option.ListenAddress(netip.IPv4Unspecified()),
|
|
ListenPort: clientPort,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Outbounds: []option.Outbound{
|
|
{
|
|
Type: C.TypeWireGuard,
|
|
WireGuardOptions: option.WireGuardOutboundOptions{
|
|
ServerOptions: option.ServerOptions{
|
|
Server: "127.0.0.1",
|
|
ServerPort: serverPort,
|
|
},
|
|
LocalAddress: []option.ListenPrefix{option.ListenPrefix(netip.MustParsePrefix("10.0.0.2/32"))},
|
|
PrivateKey: "qGnwlkZljMxeECW8fbwAWdvgntnbK7B8UmMFl3zM0mk=",
|
|
PeerPublicKey: "QsdcBm+oJw2oNv0cIFXLIq1E850lgTBonup4qnKEQBg=",
|
|
},
|
|
},
|
|
},
|
|
})
|
|
testSuitWg(t, clientPort, testPort)
|
|
}
|
|
|
|
func TestWireGuardSystem(t *testing.T) {
|
|
if os.Getuid() != 0 {
|
|
t.Skip("requires root")
|
|
}
|
|
startDockerContainer(t, DockerOptions{
|
|
Image: ImageBoringTun,
|
|
Cap: []string{"MKNOD", "NET_ADMIN", "NET_RAW"},
|
|
Ports: []uint16{serverPort, testPort},
|
|
Bind: map[string]string{
|
|
"wireguard.conf": "/etc/wireguard/wg0.conf",
|
|
},
|
|
Cmd: []string{"wg0"},
|
|
})
|
|
time.Sleep(5 * time.Second)
|
|
startInstance(t, option.Options{
|
|
Inbounds: []option.Inbound{
|
|
{
|
|
Type: C.TypeMixed,
|
|
MixedOptions: option.HTTPMixedInboundOptions{
|
|
ListenOptions: option.ListenOptions{
|
|
Listen: option.ListenAddress(netip.IPv4Unspecified()),
|
|
ListenPort: clientPort,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Outbounds: []option.Outbound{
|
|
{
|
|
Type: C.TypeWireGuard,
|
|
WireGuardOptions: option.WireGuardOutboundOptions{
|
|
InterfaceName: "wg",
|
|
ServerOptions: option.ServerOptions{
|
|
Server: "127.0.0.1",
|
|
ServerPort: serverPort,
|
|
},
|
|
LocalAddress: []option.ListenPrefix{option.ListenPrefix(netip.MustParsePrefix("10.0.0.2/32"))},
|
|
PrivateKey: "qGnwlkZljMxeECW8fbwAWdvgntnbK7B8UmMFl3zM0mk=",
|
|
PeerPublicKey: "QsdcBm+oJw2oNv0cIFXLIq1E850lgTBonup4qnKEQBg=",
|
|
},
|
|
},
|
|
},
|
|
})
|
|
time.Sleep(10 * time.Second)
|
|
testSuitWg(t, clientPort, testPort)
|
|
}
|