mirror of https://github.com/jackc/pgx.git
Improve error message when failing to scan a NULL::json
parent
0d5d8e0137
commit
2e73d1e8ee
|
@ -3,6 +3,7 @@ package pgtype
|
||||||
import (
|
import (
|
||||||
"database/sql/driver"
|
"database/sql/driver"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
"reflect"
|
"reflect"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -129,6 +130,8 @@ func (scanPlanJSONToJSONUnmarshal) Scan(src []byte, dst any) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return fmt.Errorf("cannot scan null into %T", dst)
|
||||||
}
|
}
|
||||||
|
|
||||||
return json.Unmarshal(src, dst)
|
return json.Unmarshal(src, dst)
|
||||||
|
|
|
@ -4,7 +4,9 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
pgx "github.com/jackc/pgx/v5"
|
||||||
"github.com/jackc/pgx/v5/pgxtest"
|
"github.com/jackc/pgx/v5/pgxtest"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
)
|
)
|
||||||
|
|
||||||
func isExpectedEqMap(a any) func(any) bool {
|
func isExpectedEqMap(a any) func(any) bool {
|
||||||
|
@ -58,3 +60,36 @@ func TestJSONCodec(t *testing.T) {
|
||||||
{jsonStruct{Name: "Adam", Age: 10}, new(jsonStruct), isExpectedEq(jsonStruct{Name: "Adam", Age: 10})},
|
{jsonStruct{Name: "Adam", Age: 10}, new(jsonStruct), isExpectedEq(jsonStruct{Name: "Adam", Age: 10})},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// https://github.com/jackc/pgx/issues/1273#issuecomment-1221414648
|
||||||
|
func TestJSONCodecUnmarshalSQLNull(t *testing.T) {
|
||||||
|
defaultConnTestRunner.RunTest(context.Background(), t, func(ctx context.Context, t testing.TB, conn *pgx.Conn) {
|
||||||
|
// Slices are nilified
|
||||||
|
slice := []string{"foo", "bar", "baz"}
|
||||||
|
err := conn.QueryRow(ctx, "select null::json").Scan(&slice)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Nil(t, slice)
|
||||||
|
|
||||||
|
// Maps are nilified
|
||||||
|
m := map[string]any{"foo": "bar"}
|
||||||
|
err = conn.QueryRow(ctx, "select null::json").Scan(&m)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Nil(t, m)
|
||||||
|
|
||||||
|
// Pointer to pointer are nilified
|
||||||
|
n := 42
|
||||||
|
p := &n
|
||||||
|
err = conn.QueryRow(ctx, "select null::json").Scan(&p)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Nil(t, p)
|
||||||
|
|
||||||
|
// A string cannot scan a NULL.
|
||||||
|
str := "foobar"
|
||||||
|
err = conn.QueryRow(ctx, "select null::json").Scan(&str)
|
||||||
|
require.EqualError(t, err, "can't scan into dest[0]: cannot scan null into *string")
|
||||||
|
|
||||||
|
// A non-string cannot scan a NULL.
|
||||||
|
err = conn.QueryRow(ctx, "select null::json").Scan(&n)
|
||||||
|
require.EqualError(t, err, "can't scan into dest[0]: cannot scan null into *int")
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue