1
0
Files
nex/backend/pkg/logger/gorm_test.go
lanyuanxiaoyao 280099b89c refactor: 后端日志系统重构
- 新增模块化日志器(pkg/logger/module.go)
- 新增 GORM 日志适配器
- 统一日志入口,移除所有 zap.L() 全局 logger 调用
- 字段标准化
- 启动阶段使用结构化日志
- 更新所有相关测试
2026-04-23 18:37:51 +08:00

132 lines
2.7 KiB
Go

package logger
import (
"context"
"testing"
"time"
"github.com/stretchr/testify/assert"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
"gorm.io/gorm"
gormlogger "gorm.io/gorm/logger"
)
func TestNewGormLogger(t *testing.T) {
logger := zap.NewNop()
gormLogger := NewGormLogger(logger)
assert.NotNil(t, gormLogger)
assert.NotNil(t, gormLogger.logger)
assert.Equal(t, zap.DebugLevel, gormLogger.level)
}
func TestGormLogger_LogMode(t *testing.T) {
logger := zap.NewNop()
gormLogger := NewGormLogger(logger)
tests := []struct {
name string
level gormlogger.LogLevel
expectedLevel zapcore.Level
}{
{"Silent", gormlogger.Silent, zapcore.PanicLevel},
{"Error", gormlogger.Error, zapcore.ErrorLevel},
{"Warn", gormlogger.Warn, zapcore.WarnLevel},
{"Info", gormlogger.Info, zapcore.DebugLevel},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
newLogger := gormLogger.LogMode(tt.level)
assert.NotNil(t, newLogger)
})
}
}
func TestGormLogger_Trace(t *testing.T) {
logger := zap.NewNop()
gormLogger := NewGormLogger(logger)
ctx := context.Background()
begin := time.Now()
fc := func() (string, int64) {
return "SELECT * FROM users", 10
}
gormLogger.Trace(ctx, begin, fc, nil)
}
func TestGormLogger_TraceWithError(t *testing.T) {
logger := zap.NewNop()
gormLogger := NewGormLogger(logger)
ctx := context.Background()
begin := time.Now()
fc := func() (string, int64) {
return "SELECT * FROM users", 0
}
gormLogger.Trace(ctx, begin, fc, gorm.ErrRecordNotFound)
}
func TestGormLogger_Info(t *testing.T) {
logger := zap.NewNop()
gormLogger := NewGormLogger(logger)
ctx := context.Background()
gormLogger.Info(ctx, "test info message")
}
func TestGormLogger_Warn(t *testing.T) {
logger := zap.NewNop()
gormLogger := NewGormLogger(logger)
ctx := context.Background()
gormLogger.Warn(ctx, "test warn message")
}
func TestGormLogger_Error(t *testing.T) {
logger := zap.NewNop()
gormLogger := NewGormLogger(logger)
ctx := context.Background()
gormLogger.Error(ctx, "test error message")
}
func TestGormLogger_FormatSQL(t *testing.T) {
logger := zap.NewNop()
gormLogger := NewGormLogger(logger)
tests := []struct {
name string
input string
expected string
}{
{
name: "simple query",
input: "SELECT * FROM users",
expected: "SELECT * FROM users",
},
{
name: "query with extra spaces",
input: "SELECT * FROM users",
expected: "SELECT * FROM users",
},
{
name: "query with newlines",
input: "SELECT\n*\nFROM\nusers",
expected: "SELECT * FROM users",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
result := gormLogger.formatSQL(tt.input)
assert.Equal(t, tt.expected, result)
})
}
}