Skip to content

Commit

Permalink
Fix Issue 1329 - agtype_to_int4 crash
Browse files Browse the repository at this point in the history
Fixed issue 1329 where `agtype_to_int`<8,4,2> and `agtype_to_int4_array`
crashed due to not properly checking input.

As these functions take "any" input, the input has to be properly
checked before casting it to a specific type. The input section
assumed it was agtype, which caused crashes for non-agtypes.

The functions `agtype_to_int`<8,4,2> will convert non-agtypes into
agtype. However, there were no regression tests for this.

TODOS -

The function `agtype_to_int4_array` only takes agtype, currently,
and we should consider allowing it to take "any" types.

The functions `agtype_to_int`<8,4,2> will convert non-agtypes to
agtype ints but, not for their string equivs. Meaning, passing a
('true') or ('3.14') will fail but, passing a (true) or (3.14)
will not.

Added regression tests.
Added missing regression tests.
  • Loading branch information
jrgemignani committed Oct 31, 2023
1 parent 34c738f commit c80b90f
Show file tree
Hide file tree
Showing 5 changed files with 437 additions and 36 deletions.
222 changes: 215 additions & 7 deletions regress/expected/agtype.out
Original file line number Diff line number Diff line change
Expand Up @@ -2744,6 +2744,59 @@ SELECT agtype_to_int8(agtype_in('false'));
0
(1 row)

-- should return SQL NULL
SELECT agtype_to_int8(agtype_in('null'));
agtype_to_int8
----------------

(1 row)

SELECT agtype_to_int8(NULL);
agtype_to_int8
----------------

(1 row)

-- non agtype input
SELECT agtype_to_int8(1);
agtype_to_int8
----------------
1
(1 row)

SELECT agtype_to_int8(3.14);
agtype_to_int8
----------------
3
(1 row)

SELECT agtype_to_int8(3.14::numeric);
agtype_to_int8
----------------
3
(1 row)

SELECT agtype_to_int8('3');
agtype_to_int8
----------------
3
(1 row)

SELECT agtype_to_int8(true);
agtype_to_int8
----------------
1
(1 row)

SELECT agtype_to_int8(false);
agtype_to_int8
----------------
0
(1 row)

-- should error
SELECT agtype_to_int8('3.14');
ERROR: invalid input syntax for type bigint: "3.14"
--
-- Test boolean to integer cast
--
Expand All @@ -2759,14 +2812,8 @@ SELECT agtype_to_int4(agtype_in('false'));
0
(1 row)

SELECT agtype_to_int4(agtype_in('null'));
agtype_to_int4
----------------

(1 row)

--
-- Test agtype to integer cast
-- Test agtype to integer4 cast
--
SELECT agtype_to_int4(agtype_in('1'));
agtype_to_int4
Expand All @@ -2793,6 +2840,155 @@ SELECT agtype_to_int4(agtype_in('[1, 2, 3]'));
ERROR: cannot cast agtype array to type int
SELECT agtype_to_int4(agtype_in('{"int":1}'));
ERROR: cannot cast agtype object to type int
-- should return SQL NULL
SELECT agtype_to_int4(agtype_in('null'));
agtype_to_int4
----------------

(1 row)

SELECT agtype_to_int4(NULL);
agtype_to_int4
----------------

(1 row)

-- non agtype input
SELECT agtype_to_int4(1);
agtype_to_int4
----------------
1
(1 row)

SELECT agtype_to_int4(3.14);
agtype_to_int4
----------------
3
(1 row)

SELECT agtype_to_int4(3.14::numeric);
agtype_to_int4
----------------
3
(1 row)

SELECT agtype_to_int4('3');
agtype_to_int4
----------------
3
(1 row)

SELECT agtype_to_int4(true);
agtype_to_int4
----------------
1
(1 row)

SELECT agtype_to_int4(false);
agtype_to_int4
----------------
0
(1 row)

-- should error
SELECT agtype_to_int4('3.14');
ERROR: invalid input syntax for type integer: "3.14"
--
-- Test boolean to integer2 cast
--
SELECT agtype_to_int2(agtype_in('true'));
agtype_to_int2
----------------
1
(1 row)

SELECT agtype_to_int2(agtype_in('false'));
agtype_to_int2
----------------
0
(1 row)

--
-- Test agtype to integer2 cast
--
SELECT agtype_to_int2(agtype_in('1'));
agtype_to_int2
----------------
1
(1 row)

SELECT agtype_to_int2(agtype_in('1.45'));
agtype_to_int2
----------------
1
(1 row)

SELECT agtype_to_int2(agtype_in('1.444::numeric'));
agtype_to_int2
----------------
1
(1 row)

-- These should all fail
SELECT agtype_to_int2(agtype_in('"string"'));
ERROR: invalid input syntax for type smallint: "string"
SELECT agtype_to_int2(agtype_in('[1, 2, 3]'));
ERROR: cannot cast agtype array to type int
SELECT agtype_to_int2(agtype_in('{"int":1}'));
ERROR: cannot cast agtype object to type int
-- should return SQL NULL
SELECT agtype_to_int2(agtype_in('null'));
agtype_to_int2
----------------

(1 row)

SELECT agtype_to_int2(NULL);
agtype_to_int2
----------------

(1 row)

-- non agtype input
SELECT agtype_to_int2(1);
agtype_to_int2
----------------
1
(1 row)

SELECT agtype_to_int2(3.14);
agtype_to_int2
----------------
3
(1 row)

SELECT agtype_to_int2(3.14::numeric);
agtype_to_int2
----------------
3
(1 row)

SELECT agtype_to_int2('3');
agtype_to_int2
----------------
3
(1 row)

SELECT agtype_to_int2(true);
agtype_to_int2
----------------
1
(1 row)

SELECT agtype_to_int2(false);
agtype_to_int2
----------------
0
(1 row)

-- should error
SELECT agtype_to_int2('3.14');
ERROR: invalid input syntax for type smallint: "3.14"
--
-- Test agtype to int[]
--
Expand All @@ -2814,6 +3010,18 @@ SELECT agtype_to_int4_array(agtype_in('["6","7",3.66]'));
{6,7,4}
(1 row)

-- should error
SELECT agtype_to_int4_array(bool('true'));
ERROR: argument must resolve to agtype
SELECT agtype_to_int4_array((1,2,3,4,5));
ERROR: argument must resolve to agtype
-- should return SQL NULL
SELECT agtype_to_int4_array(NULL);
agtype_to_int4_array
----------------------

(1 row)

--
-- Map Literal
--
Expand Down
64 changes: 64 additions & 0 deletions regress/expected/expr.out
Original file line number Diff line number Diff line change
Expand Up @@ -7559,6 +7559,70 @@ SELECT * FROM bool(true AND false);
f
(1 row)

-- Issue 1329
-- returns 1
SELECT agtype_to_int2(bool('true'));
agtype_to_int2
----------------
1
(1 row)

SELECT agtype_to_int4(bool('true'));
agtype_to_int4
----------------
1
(1 row)

SELECT agtype_to_int8(bool('true'));
agtype_to_int8
----------------
1
(1 row)

-- returns 0
SELECT agtype_to_int2(bool('false'));
agtype_to_int2
----------------
0
(1 row)

SELECT agtype_to_int4(bool('false'));
agtype_to_int4
----------------
0
(1 row)

SELECT agtype_to_int8(bool('false'));
agtype_to_int8
----------------
0
(1 row)

-- should error
SELECT agtype_to_int2(bool('neither'));
ERROR: invalid input syntax for type boolean: "neither"
LINE 1: SELECT agtype_to_int2(bool('neither'));
^
SELECT agtype_to_int4(bool('neither'));
ERROR: invalid input syntax for type boolean: "neither"
LINE 1: SELECT agtype_to_int4(bool('neither'));
^
SELECT agtype_to_int8(bool('neither'));
ERROR: invalid input syntax for type boolean: "neither"
LINE 1: SELECT agtype_to_int8(bool('neither'));
^
SELECT agtype_to_int2('true');
ERROR: invalid input syntax for type smallint: "true"
SELECT agtype_to_int4('true');
ERROR: invalid input syntax for type integer: "true"
SELECT agtype_to_int8('true');
ERROR: invalid input syntax for type bigint: "true"
SELECT agtype_to_int2('false');
ERROR: invalid input syntax for type smallint: "false"
SELECT agtype_to_int4('false');
ERROR: invalid input syntax for type integer: "false"
SELECT agtype_to_int8('false');
ERROR: invalid input syntax for type bigint: "false"
--
-- Cleanup
--
Expand Down
Loading

0 comments on commit c80b90f

Please sign in to comment.