mirror of
https://github.com/qdm12/gluetun.git
synced 2026-05-06 07:26:39 -04:00
4a78989d9d
- main reason being it's a burden to always define sentinel errors at global scope, wrap them with `%w` instead of using a string directly - only use sentinel errors when it has to be checked using `errors.Is` - replace all usage of these sentinel errors in `fmt.Errorf` with direct strings that were in the sentinel error - exclude the sentinel error definition requirement from .golangci.yml - update unit tests to use ContainersError instead of ErrorIs so it stays as a "not a change detector test" without requiring a sentinel error
297 lines
6.4 KiB
Go
297 lines
6.4 KiB
Go
package pprof
|
|
|
|
import (
|
|
"net/http"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/qdm12/gluetun/internal/httpserver"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func Test_Settings_SetDefaults(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testCases := map[string]struct {
|
|
initial Settings
|
|
expected Settings
|
|
}{
|
|
"empty settings": {
|
|
expected: Settings{
|
|
Enabled: boolPtr(false),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: "localhost:6060",
|
|
ReadHeaderTimeout: 3 * time.Second,
|
|
ReadTimeout: 5 * time.Minute,
|
|
ShutdownTimeout: 3 * time.Second,
|
|
},
|
|
},
|
|
},
|
|
"non empty settings": {
|
|
initial: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":6061",
|
|
ReadHeaderTimeout: time.Second,
|
|
ReadTimeout: time.Second,
|
|
ShutdownTimeout: time.Second,
|
|
},
|
|
},
|
|
expected: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":6061",
|
|
ReadHeaderTimeout: time.Second,
|
|
ReadTimeout: time.Second,
|
|
ShutdownTimeout: time.Second,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
for name, testCase := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testCase.initial.SetDefaults()
|
|
|
|
assert.Equal(t, testCase.expected, testCase.initial)
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_Settings_Copy(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testCases := map[string]struct {
|
|
initial Settings
|
|
expected Settings
|
|
}{
|
|
"empty settings": {},
|
|
"non empty settings": {
|
|
initial: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":6061",
|
|
ShutdownTimeout: time.Second,
|
|
},
|
|
},
|
|
expected: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":6061",
|
|
ShutdownTimeout: time.Second,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
for name, testCase := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
copied := testCase.initial.Copy()
|
|
|
|
assert.Equal(t, testCase.expected, copied)
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_Settings_OverrideWith(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testCases := map[string]struct {
|
|
settings Settings
|
|
other Settings
|
|
expected Settings
|
|
}{
|
|
"override empty with empty": {},
|
|
"override empty with filled": {
|
|
other: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8001",
|
|
},
|
|
},
|
|
expected: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8001",
|
|
},
|
|
},
|
|
},
|
|
"override filled with empty": {
|
|
settings: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8001",
|
|
},
|
|
},
|
|
expected: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8001",
|
|
},
|
|
},
|
|
},
|
|
"override filled with filled": {
|
|
settings: Settings{
|
|
Enabled: boolPtr(false),
|
|
BlockProfileRate: intPtr(1),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8001",
|
|
},
|
|
},
|
|
other: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(2),
|
|
MutexProfileRate: intPtr(3),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8002",
|
|
},
|
|
},
|
|
expected: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(2),
|
|
MutexProfileRate: intPtr(3),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8002",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
for name, testCase := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testCase.settings.OverrideWith(testCase.other)
|
|
|
|
assert.Equal(t, testCase.expected, testCase.settings)
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_Settings_Validate(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testCases := map[string]struct {
|
|
settings Settings
|
|
errMessage string
|
|
}{
|
|
"negative block profile rate": {
|
|
settings: Settings{
|
|
BlockProfileRate: intPtr(-1),
|
|
MutexProfileRate: intPtr(0),
|
|
},
|
|
errMessage: "block profile rate cannot be negative",
|
|
},
|
|
"negative mutex profile rate": {
|
|
settings: Settings{
|
|
BlockProfileRate: intPtr(0),
|
|
MutexProfileRate: intPtr(-1),
|
|
},
|
|
errMessage: "mutex profile rate cannot be negative",
|
|
},
|
|
"http server validation error": {
|
|
settings: Settings{
|
|
BlockProfileRate: intPtr(0),
|
|
MutexProfileRate: intPtr(0),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":x",
|
|
},
|
|
},
|
|
errMessage: "port value is not an integer: x",
|
|
},
|
|
"valid settings": {
|
|
settings: Settings{
|
|
BlockProfileRate: intPtr(0),
|
|
MutexProfileRate: intPtr(0),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8000",
|
|
Handler: http.NewServeMux(),
|
|
Logger: &MockLogger{},
|
|
ReadHeaderTimeout: time.Second,
|
|
ReadTimeout: time.Second,
|
|
ShutdownTimeout: time.Second,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
for name, testCase := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
err := testCase.settings.Validate()
|
|
|
|
if testCase.errMessage != "" {
|
|
assert.EqualError(t, err, testCase.errMessage)
|
|
} else {
|
|
assert.NoError(t, err)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_Settings_String(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testCases := map[string]struct {
|
|
settings Settings
|
|
s string
|
|
}{
|
|
"disabled pprof": {
|
|
settings: Settings{
|
|
Enabled: boolPtr(false),
|
|
},
|
|
},
|
|
"all values": {
|
|
settings: Settings{
|
|
Enabled: boolPtr(true),
|
|
BlockProfileRate: intPtr(2),
|
|
MutexProfileRate: intPtr(1),
|
|
HTTPServer: httpserver.Settings{
|
|
Address: ":8000",
|
|
ShutdownTimeout: time.Second,
|
|
},
|
|
},
|
|
s: `Pprof settings:
|
|
├── Block profile rate: 2
|
|
├── Mutex profile rate: 1
|
|
└── HTTP server settings:
|
|
├── Listening address: :8000
|
|
├── Read header timeout: 0s
|
|
├── Read timeout: 0s
|
|
└── Shutdown timeout: 1s`,
|
|
},
|
|
}
|
|
|
|
for name, testCase := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
s := testCase.settings.String()
|
|
|
|
assert.Equal(t, testCase.s, s)
|
|
})
|
|
}
|
|
}
|