https://github.com/jackc/pgx/pull/1795
(t *testing.T)
| 618 | |
| 619 | // https://github.com/jackc/pgx/pull/1795 |
| 620 | func TestDeallocateInAbortedTransaction(t *testing.T) { |
| 621 | t.Parallel() |
| 622 | |
| 623 | ctx, cancel := context.WithTimeout(context.Background(), 120*time.Second) |
| 624 | defer cancel() |
| 625 | |
| 626 | pgxtest.RunWithQueryExecModes(ctx, t, defaultConnTestRunner, nil, func(ctx context.Context, t testing.TB, conn *pgx.Conn) { |
| 627 | tx, err := conn.Begin(ctx) |
| 628 | require.NoError(t, err) |
| 629 | |
| 630 | sql := "select $1::text" |
| 631 | sd, err := tx.Prepare(ctx, sql, sql) |
| 632 | require.NoError(t, err) |
| 633 | require.Equal(t, "stmt_2510cc7db17de3f42758a2a29c8b9ef8305d007b997ebdd6", sd.Name) |
| 634 | |
| 635 | var s string |
| 636 | err = tx.QueryRow(ctx, sql, "hello").Scan(&s) |
| 637 | require.NoError(t, err) |
| 638 | require.Equal(t, "hello", s) |
| 639 | |
| 640 | _, err = tx.Exec(ctx, "select 1/0") // abort transaction with divide by zero error |
| 641 | require.Error(t, err) |
| 642 | |
| 643 | err = conn.Deallocate(ctx, sql) |
| 644 | require.NoError(t, err) |
| 645 | |
| 646 | err = tx.Rollback(ctx) |
| 647 | require.NoError(t, err) |
| 648 | |
| 649 | sd, err = conn.Prepare(ctx, sql, sql) |
| 650 | require.NoError(t, err) |
| 651 | require.Equal(t, "stmt_2510cc7db17de3f42758a2a29c8b9ef8305d007b997ebdd6", sd.Name) |
| 652 | }) |
| 653 | } |
| 654 | |
| 655 | func TestDeallocateMissingPreparedStatementStillClearsFromPreparedStatementMap(t *testing.T) { |
| 656 | t.Parallel() |
nothing calls this directly
no test coverage detected