summaryrefslogtreecommitdiff
path: root/internal/engine/healthcheck_test.go
diff options
context:
space:
mode:
authorsergei <sergei@em-sysadmin.xyz>2026-04-14 06:23:55 +0400
committersergei <sergei@em-sysadmin.xyz>2026-04-14 06:23:55 +0400
commit3d51aa455006903345f554a2dd90034993796114 (patch)
tree62a7be2faf047f5eb7886feebc3b815556f03d7f /internal/engine/healthcheck_test.go
downloadvpnem-main.tar.gz
vpnem-main.tar.bz2
vpnem-main.zip
vpnem: VPN infrastructure with load-balanced multi-protocol nodesHEADmain
- Multi-protocol VPS nodes (VLESS-REALITY + Hysteria2 + SOCKS5) - Smart load balancing via recommendation API - Windows/Linux client (Go + Wails + sing-box) - Server API with RealIP detection and connection tracking - Auto-deployment via vpnui control plane - Silent Windows installer with UAC elevation - Load-based server recommendation (no sticky sessions) - Best Server one-click connection workflow
Diffstat (limited to 'internal/engine/healthcheck_test.go')
-rw-r--r--internal/engine/healthcheck_test.go38
1 files changed, 38 insertions, 0 deletions
diff --git a/internal/engine/healthcheck_test.go b/internal/engine/healthcheck_test.go
new file mode 100644
index 0000000..1d55ed0
--- /dev/null
+++ b/internal/engine/healthcheck_test.go
@@ -0,0 +1,38 @@
+package engine
+
+import (
+ "errors"
+ "testing"
+
+ "vpnem/internal/config"
+)
+
+func TestModeRequiresExitIP(t *testing.T) {
+ proxyMode := config.Mode{Name: "Full", Final: "proxy"}
+ directMode := config.Mode{Name: "Combo", Final: "direct"}
+
+ if !ModeRequiresExitIP(proxyMode) {
+ t.Fatal("expected proxy-final mode to require exit IP")
+ }
+ if ModeRequiresExitIP(directMode) {
+ t.Fatal("did not expect direct-final mode to require exit IP")
+ }
+}
+
+func TestDeepCheckRequiresRestart(t *testing.T) {
+ proxyMode := config.Mode{Name: "Full", Final: "proxy"}
+ directMode := config.Mode{Name: "Combo", Final: "direct"}
+
+ if !DeepCheckRequiresRestart(proxyMode, "", nil) {
+ t.Fatal("expected proxy-final mode without exit IP to restart")
+ }
+ if DeepCheckRequiresRestart(proxyMode, "89.124.96.166", errors.New("probe failed")) {
+ t.Fatal("did not expect proxy-final mode with exit IP to restart")
+ }
+ if !DeepCheckRequiresRestart(directMode, "", errors.New("probe failed")) {
+ t.Fatal("expected direct-final mode with failed blocked probe to restart")
+ }
+ if DeepCheckRequiresRestart(directMode, "", nil) {
+ t.Fatal("did not expect direct-final mode with successful blocked probe to restart")
+ }
+}