45 lines
1.0 KiB
Go
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)
|
|
}
|
|
}
|
|
}
|