Files
MHSanaei fa1a19c03c style: adopt golangci-lint v2 and resolve all findings
Add .golangci.yml (v2): the standard linters plus bodyclose, errorlint, noctx, misspell, rowserrcheck, sqlclosecheck, unconvert, usestdlibvars, with gofumpt + goimports formatters. Enable the std-error-handling exclusion preset for idiomatic Close/Remove/Setenv ignores; scope-exclude SA1019 (parser.ParseDir in tools/openapigen) and ST1005 (intentional capitalized user-facing error copy that tests assert verbatim). No inline nolint directives were introduced.

Resolve all 217 findings behavior-preserving: gofumpt/goimports formatting, explicit blank assignment on intentionally ignored errors, errors.Is/errors.As and %w wrapping, context-aware stdlib calls (CommandContext/QueryContext/NewRequestWithContext/Dialer), staticcheck simplifications, removed redundant conversions, http.StatusOK and http.MethodGet, inlined the go:fix intPtr helper, and deferred sql rows Close. Add a golangci CI job mirroring the existing Go jobs.
2026-06-27 15:42:22 +02:00

43 lines
855 B
Go

package common
import (
"os"
"testing"
"time"
"github.com/op/go-logging"
"github.com/mhsanaei/3x-ui/v3/internal/logger"
)
func TestMain(m *testing.M) {
logger.InitLogger(logging.ERROR)
os.Exit(m.Run())
}
func TestGoRecover_RunsFn(t *testing.T) {
done := make(chan struct{})
GoRecover("test-run", func() { close(done) })
select {
case <-done:
case <-time.After(2 * time.Second):
t.Fatal("fn did not run")
}
}
func TestGoRecover_RecoversPanic(t *testing.T) {
done := make(chan struct{})
// If GoRecover did not recover, this panic would crash the test binary.
GoRecover("test-panic", func() {
defer close(done)
panic("boom")
})
select {
case <-done:
case <-time.After(2 * time.Second):
t.Fatal("goroutine did not complete")
}
// Let the deferred recover+log run before the test ends.
time.Sleep(50 * time.Millisecond)
}