- internal/handler/static_test.go: 21 个测试用例覆盖静态文件服务和路径遍历安全 - internal/handler/router_test.go: 9 个测试用例覆盖路由注册和方法区分 - internal/logging/logging_test.go: 7 个测试用例覆盖日志级别解析 - internal/middleware/middleware_test.go: 4 个测试用例覆盖中间件链逆序包装 - internal/server/server_test.go: 5 个测试用例覆盖服务器创建和停止 - internal/server/vhost_test.go: 18 个测试用例覆盖虚拟主机路由 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
60 lines
1.1 KiB
Go
60 lines
1.1 KiB
Go
package logging
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/rs/zerolog"
|
|
)
|
|
|
|
func TestParseLevel(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
input string
|
|
expected zerolog.Level
|
|
}{
|
|
{
|
|
name: "debug level",
|
|
input: "debug",
|
|
expected: zerolog.DebugLevel,
|
|
},
|
|
{
|
|
name: "info level",
|
|
input: "info",
|
|
expected: zerolog.InfoLevel,
|
|
},
|
|
{
|
|
name: "warn level",
|
|
input: "warn",
|
|
expected: zerolog.WarnLevel,
|
|
},
|
|
{
|
|
name: "error level",
|
|
input: "error",
|
|
expected: zerolog.ErrorLevel,
|
|
},
|
|
{
|
|
name: "unknown level defaults to info",
|
|
input: "unknown",
|
|
expected: zerolog.InfoLevel,
|
|
},
|
|
{
|
|
name: "empty string defaults to info",
|
|
input: "",
|
|
expected: zerolog.InfoLevel,
|
|
},
|
|
{
|
|
name: "uppercase DEBUG is case sensitive",
|
|
input: "DEBUG",
|
|
expected: zerolog.InfoLevel,
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
result := parseLevel(tt.input)
|
|
if result != tt.expected {
|
|
t.Errorf("parseLevel(%q) = %v, want %v", tt.input, result, tt.expected)
|
|
}
|
|
})
|
|
}
|
|
} |