1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
package pgtype_test
import (
"context"
"testing"
pgx "github.com/jackc/pgx/v5"
"github.com/stretchr/testify/require"
)
func TestEnumCodec(t *testing.T) {
defaultConnTestRunner.RunTest(context.Background(), t, func(ctx context.Context, t testing.TB, conn *pgx.Conn) {
_, err := conn.Exec(ctx, `drop type if exists enum_test;
create type enum_test as enum ('foo', 'bar', 'baz');`)
require.NoError(t, err)
defer conn.Exec(ctx, "drop type enum_test")
dt, err := conn.LoadType(ctx, "enum_test")
require.NoError(t, err)
conn.TypeMap().RegisterType(dt)
var s string
err = conn.QueryRow(ctx, `select 'foo'::enum_test`).Scan(&s)
require.NoError(t, err)
require.Equal(t, "foo", s)
err = conn.QueryRow(ctx, `select $1::enum_test`, "bar").Scan(&s)
require.NoError(t, err)
require.Equal(t, "bar", s)
err = conn.QueryRow(ctx, `select 'foo'::enum_test`).Scan(&s)
require.NoError(t, err)
require.Equal(t, "foo", s)
err = conn.QueryRow(ctx, `select $1::enum_test`, "bar").Scan(&s)
require.NoError(t, err)
require.Equal(t, "bar", s)
err = conn.QueryRow(ctx, `select 'baz'::enum_test`).Scan(&s)
require.NoError(t, err)
require.Equal(t, "baz", s)
})
}
func TestEnumCodecValues(t *testing.T) {
defaultConnTestRunner.RunTest(context.Background(), t, func(ctx context.Context, t testing.TB, conn *pgx.Conn) {
_, err := conn.Exec(ctx, `drop type if exists enum_test;
create type enum_test as enum ('foo', 'bar', 'baz');`)
require.NoError(t, err)
defer conn.Exec(ctx, "drop type enum_test")
dt, err := conn.LoadType(ctx, "enum_test")
require.NoError(t, err)
conn.TypeMap().RegisterType(dt)
rows, err := conn.Query(ctx, `select 'foo'::enum_test`)
require.NoError(t, err)
require.True(t, rows.Next())
values, err := rows.Values()
require.NoError(t, err)
require.Equal(t, []any{"foo"}, values)
})
}
|