Files
MHSanaei e4b881e58a feat(panel): surface dev-build version in UI, bot, and CLI
A dev build now shows its `dev+<commit>` identity instead of a misleading stable-looking version in the sidebar badge, dashboard card, update modal, Telegram status report, startup log, and `x-ui -v`. Adds a shared formatPanelVersion helper (single v prefix; dev labels shown verbatim) and fixes the mobile-tag double-v.

Renames the version getters for clarity: config.GetVersion to GetBaseVersion (raw embedded version), config.GetReportedVersion to GetPanelVersion (advertised/displayed), and the xray process GetVersion to GetXrayVersion.
2026-06-25 02:36:41 +02:00

82 lines
2.4 KiB
Go

package config
import (
"os"
"testing"
)
func TestGetPanelVersion(t *testing.T) {
orig := buildCommit
t.Cleanup(func() { buildCommit = orig })
buildCommit = ""
if got := GetPanelVersion(); got != GetBaseVersion() {
t.Fatalf("stable build: GetPanelVersion = %q, want %q", got, GetBaseVersion())
}
buildCommit = "1d1128cf"
if got := GetPanelVersion(); got != "dev+1d1128cf" {
t.Fatalf("dev build: GetPanelVersion = %q, want %q", got, "dev+1d1128cf")
}
buildCommit = "1d1128cf945c4615efa05cf41ba7fa766e2ee428"
if got := GetPanelVersion(); got != "dev+1d1128cf" {
t.Fatalf("dev build (full sha): GetPanelVersion = %q, want %q", got, "dev+1d1128cf")
}
}
func TestGetPortOverride(t *testing.T) {
tests := []struct {
name string
value string
set bool
wantPort int
configured bool
wantErr bool
}{
{name: "unset"},
{name: "empty", value: "", set: true},
{name: "whitespace", value: " ", set: true},
{name: "minimum", value: "1", set: true, wantPort: 1, configured: true},
{name: "default panel port", value: "2053", set: true, wantPort: 2053, configured: true},
{name: "surrounding whitespace", value: " 8080 ", set: true, wantPort: 8080, configured: true},
{name: "maximum", value: "65535", set: true, wantPort: 65535, configured: true},
{name: "zero", value: "0", set: true, configured: true, wantErr: true},
{name: "above maximum", value: "65536", set: true, configured: true, wantErr: true},
{name: "negative", value: "-1", set: true, configured: true, wantErr: true},
{name: "non-numeric", value: "abc", set: true, configured: true, wantErr: true},
{name: "decimal", value: "8080.0", set: true, configured: true, wantErr: true},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if tt.set {
t.Setenv("XUI_PORT", tt.value)
} else {
original, existed := os.LookupEnv("XUI_PORT")
if err := os.Unsetenv("XUI_PORT"); err != nil {
t.Fatalf("unset XUI_PORT: %v", err)
}
t.Cleanup(func() {
if existed {
_ = os.Setenv("XUI_PORT", original)
} else {
_ = os.Unsetenv("XUI_PORT")
}
})
}
port, configured, err := GetPortOverride()
if port != tt.wantPort {
t.Errorf("port = %d, want %d", port, tt.wantPort)
}
if configured != tt.configured {
t.Errorf("configured = %t, want %t", configured, tt.configured)
}
if (err != nil) != tt.wantErr {
t.Errorf("error = %v, wantErr %t", err, tt.wantErr)
}
})
}
}