(t *testing.T)
| 452 | } |
| 453 | |
| 454 | func TestPoolAfterRelease(t *testing.T) { |
| 455 | t.Parallel() |
| 456 | |
| 457 | ctx, cancel := context.WithTimeout(context.Background(), 120*time.Second) |
| 458 | defer cancel() |
| 459 | |
| 460 | func() { |
| 461 | pool, err := pgxpool.New(ctx, os.Getenv("PGX_TEST_DATABASE")) |
| 462 | require.NoError(t, err) |
| 463 | defer pool.Close() |
| 464 | }() |
| 465 | |
| 466 | config, err := pgxpool.ParseConfig(os.Getenv("PGX_TEST_DATABASE")) |
| 467 | require.NoError(t, err) |
| 468 | |
| 469 | afterReleaseCount := 0 |
| 470 | |
| 471 | config.AfterRelease = func(c *pgx.Conn) bool { |
| 472 | afterReleaseCount++ |
| 473 | return afterReleaseCount%2 == 1 |
| 474 | } |
| 475 | |
| 476 | db, err := pgxpool.NewWithConfig(ctx, config) |
| 477 | require.NoError(t, err) |
| 478 | defer db.Close() |
| 479 | |
| 480 | connPIDs := map[uint32]struct{}{} |
| 481 | |
| 482 | for range 10 { |
| 483 | conn, err := db.Acquire(ctx) |
| 484 | assert.NoError(t, err) |
| 485 | connPIDs[conn.Conn().PgConn().PID()] = struct{}{} |
| 486 | conn.Release() |
| 487 | waitForReleaseToComplete() |
| 488 | } |
| 489 | |
| 490 | assert.EqualValues(t, 5, len(connPIDs)) |
| 491 | } |
| 492 | |
| 493 | func TestPoolBeforeClose(t *testing.T) { |
| 494 | t.Parallel() |
nothing calls this directly
no test coverage detected