sub2api/backend/internal/repository/ops_repo_replay_cleanup_test.go
2026-05-19 19:37:41 +08:00

45 lines
1.0 KiB
Go

package repository
import (
"reflect"
"strings"
"testing"
"github.com/Wei-Shaw/sub2api/internal/service"
)
func TestOpsErrorLogInsertDoesNotPersistRequestReplayFields(t *testing.T) {
disallowedColumns := []string{
"request_body",
"request_headers",
"request_body_truncated",
"request_body_bytes",
"is_retryable",
"retry_count",
"resolved_retry_id",
}
insertSQL := strings.ToLower(insertOpsErrorLogSQL)
for _, column := range disallowedColumns {
if strings.Contains(insertSQL, column) {
t.Fatalf("ops error log insert still references dropped replay column %q", column)
}
}
inputType := reflect.TypeOf(service.OpsInsertErrorLogInput{})
disallowedFields := []string{
"RequestBodyJSON",
"RequestBodyTruncated",
"RequestBodyBytes",
"RequestHeadersJSON",
"IsRetryable",
"RetryCount",
"ResolvedRetryID",
}
for _, field := range disallowedFields {
if _, ok := inputType.FieldByName(field); ok {
t.Fatalf("OpsInsertErrorLogInput still carries replay field %q", field)
}
}
}