(t *testing.T)
| 327 | } |
| 328 | |
| 329 | func TestLogHandler_FieldsEmpty(t *testing.T) { |
| 330 | var buf bytes.Buffer |
| 331 | |
| 332 | opts := &slog.HandlerOptions{ |
| 333 | Level: slog.LevelInfo, |
| 334 | ReplaceAttr: ReplaceAttr, |
| 335 | } |
| 336 | baseHandler := slog.NewJSONHandler(&buf, opts) |
| 337 | |
| 338 | options := &logOptions{} |
| 339 | WithFunctionARN()(options) |
| 340 | WithTenantID()(options) |
| 341 | |
| 342 | handler := &lambdaHandler{ |
| 343 | handler: baseHandler, |
| 344 | fields: options.fields, |
| 345 | } |
| 346 | |
| 347 | lc := &LambdaContext{ |
| 348 | AwsRequestID: "test-request-123", |
| 349 | InvokedFunctionArn: "", |
| 350 | TenantID: "", |
| 351 | } |
| 352 | ctx := NewContext(context.Background(), lc) |
| 353 | |
| 354 | logger := slog.New(handler) |
| 355 | logger.InfoContext(ctx, "test message") |
| 356 | |
| 357 | var logOutput map[string]interface{} |
| 358 | err := json.Unmarshal(buf.Bytes(), &logOutput) |
| 359 | require.NoError(t, err) |
| 360 | |
| 361 | assert.Equal(t, "test-request-123", logOutput["requestId"]) |
| 362 | assert.NotContains(t, logOutput, "functionArn") |
| 363 | assert.NotContains(t, logOutput, "tenantId") |
| 364 | } |
| 365 | |
| 366 | func TestWithFunctionARN(t *testing.T) { |
| 367 | options := &logOptions{} |
nothing calls this directly
no test coverage detected
searching dependent graphs…