| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- package service
- import (
- "testing"
- "github.com/mhsanaei/3x-ui/v3/internal/database/model"
- wgutil "github.com/mhsanaei/3x-ui/v3/internal/util/wireguard"
- )
- func TestAllocateWireguardAddress(t *testing.T) {
- tests := []struct {
- name string
- used []string
- base string
- want string
- err bool
- }{
- {name: "empty starts at .2", used: nil, base: "10.0.0.0/24", want: "10.0.0.2/32"},
- {name: "skips used", used: []string{"10.0.0.2/32"}, base: "10.0.0.0/24", want: "10.0.0.3/32"},
- {name: "fills gap", used: []string{"10.0.0.3/32", "10.0.0.4/32"}, base: "10.0.0.0/24", want: "10.0.0.2/32"},
- {name: "ignores catch-all", used: []string{"0.0.0.0/0", "::/0"}, base: "10.0.0.0/24", want: "10.0.0.2/32"},
- {name: "default base when empty", used: nil, base: "", want: "10.0.0.2/32"},
- {name: "exhausted /30", used: []string{"10.9.0.2/32", "10.9.0.3/32"}, base: "10.9.0.0/30", err: true},
- }
- for _, tt := range tests {
- t.Run(tt.name, func(t *testing.T) {
- got, err := allocateWireguardAddress(tt.used, tt.base)
- if tt.err {
- if err == nil {
- t.Fatalf("expected error, got %q", got)
- }
- return
- }
- if err != nil {
- t.Fatalf("unexpected error: %v", err)
- }
- if got != tt.want {
- t.Fatalf("got %q, want %q", got, tt.want)
- }
- })
- }
- }
- func TestDefaultWireguardClientsGeneratesKeypair(t *testing.T) {
- clients := []model.Client{{Email: "a@wg"}}
- ifaces := []any{map[string]any{"email": "a@wg"}}
- if err := defaultWireguardClients(nil, clients, ifaces); err != nil {
- t.Fatalf("defaultWireguardClients: %v", err)
- }
- c := clients[0]
- if c.PrivateKey == "" || c.PublicKey == "" {
- t.Fatalf("keypair not generated: priv=%q pub=%q", c.PrivateKey, c.PublicKey)
- }
- if len(c.AllowedIPs) != 1 || c.AllowedIPs[0] != "10.0.0.2/32" {
- t.Fatalf("allowedIPs not allocated: %v", c.AllowedIPs)
- }
- m := ifaces[0].(map[string]any)
- if m["privateKey"] != c.PrivateKey || m["publicKey"] != c.PublicKey {
- t.Fatalf("interface map not updated: %v", m)
- }
- }
- func TestDefaultWireguardClientsDerivesPublicKey(t *testing.T) {
- priv, _, err := wgutil.GenerateWireguardKeypair()
- if err != nil {
- t.Fatal(err)
- }
- wantPub, err := wgutil.PublicKeyFromPrivate(priv)
- if err != nil {
- t.Fatal(err)
- }
- clients := []model.Client{{Email: "b@wg", PrivateKey: priv}}
- ifaces := []any{map[string]any{"email": "b@wg"}}
- if err := defaultWireguardClients(nil, clients, ifaces); err != nil {
- t.Fatalf("defaultWireguardClients: %v", err)
- }
- if clients[0].PublicKey != wantPub {
- t.Fatalf("derived public key = %q, want %q", clients[0].PublicKey, wantPub)
- }
- }
- func TestDefaultWireguardClientsPreservesProvided(t *testing.T) {
- clients := []model.Client{{
- Email: "c@wg",
- PrivateKey: "keep-priv",
- PublicKey: "keep-pub",
- AllowedIPs: []string{"10.0.0.50/32"},
- }}
- ifaces := []any{map[string]any{"email": "c@wg"}}
- if err := defaultWireguardClients(nil, clients, ifaces); err != nil {
- t.Fatalf("defaultWireguardClients: %v", err)
- }
- if clients[0].PrivateKey != "keep-priv" || clients[0].PublicKey != "keep-pub" {
- t.Fatalf("provided keys were rotated: %+v", clients[0])
- }
- if clients[0].AllowedIPs[0] != "10.0.0.50/32" {
- t.Fatalf("provided allowedIPs changed: %v", clients[0].AllowedIPs)
- }
- }
- func TestDefaultWireguardClientsAllocatesDistinctIPs(t *testing.T) {
- clients := []model.Client{{Email: "x@wg"}, {Email: "y@wg"}}
- ifaces := []any{map[string]any{"email": "x@wg"}, map[string]any{"email": "y@wg"}}
- if err := defaultWireguardClients(nil, clients, ifaces); err != nil {
- t.Fatalf("defaultWireguardClients: %v", err)
- }
- if clients[0].AllowedIPs[0] == clients[1].AllowedIPs[0] {
- t.Fatalf("two clients got the same address: %v", clients[0].AllowedIPs)
- }
- }
|