File: enum_codec_test.go

package info (click to toggle)
golang-github-jackc-pgx-v5 5.8.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,764 kB
  • sloc: sh: 88; sql: 21; makefile: 6
file content (67 lines) | stat: -rw-r--r-- 1,863 bytes parent folder | download
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)
	})
}