diff options
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/regress/expected/numeric.out | 55 | ||||
| -rw-r--r-- | src/test/regress/sql/numeric.sql | 11 |
2 files changed, 66 insertions, 0 deletions
diff --git a/src/test/regress/expected/numeric.out b/src/test/regress/expected/numeric.out index cc119953982..ddcf5dbb114 100644 --- a/src/test/regress/expected/numeric.out +++ b/src/test/regress/expected/numeric.out @@ -2396,6 +2396,12 @@ select 1.000000000123 ^ (-2147483648); 0.7678656556403084 (1 row) +select 0.9999999999 ^ 23300000000000 = 0 as rounds_to_zero; + rounds_to_zero +---------------- + t +(1 row) + -- cases that used to error out select 0.12 ^ (-25); ?column? @@ -2409,6 +2415,43 @@ select 0.5678 ^ (-85); 782333637740774446257.7719390061997396 (1 row) +select 0.9999999999 ^ 70000000000000 = 0 as underflows; + underflows +------------ + t +(1 row) + +-- negative base to integer powers +select (-1.0) ^ 2147483646; + ?column? +-------------------- + 1.0000000000000000 +(1 row) + +select (-1.0) ^ 2147483647; + ?column? +--------------------- + -1.0000000000000000 +(1 row) + +select (-1.0) ^ 2147483648; + ?column? +-------------------- + 1.0000000000000000 +(1 row) + +select (-1.0) ^ 1000000000000000; + ?column? +-------------------- + 1.0000000000000000 +(1 row) + +select (-1.0) ^ 1000000000000001; + ?column? +--------------------- + -1.0000000000000000 +(1 row) + -- -- Tests for raising to non-integer powers -- @@ -2545,6 +2588,18 @@ select exp('-inf'::numeric); 0 (1 row) +select exp(-5000::numeric) = 0 as rounds_to_zero; + rounds_to_zero +---------------- + t +(1 row) + +select exp(-10000::numeric) = 0 as underflows; + underflows +------------ + t +(1 row) + -- cases that used to generate inaccurate results select exp(32.999); exp diff --git a/src/test/regress/sql/numeric.sql b/src/test/regress/sql/numeric.sql index 14b4acfe127..4e91abae20f 100644 --- a/src/test/regress/sql/numeric.sql +++ b/src/test/regress/sql/numeric.sql @@ -1126,10 +1126,19 @@ select 3.789 ^ 35; select 1.2 ^ 345; select 0.12 ^ (-20); select 1.000000000123 ^ (-2147483648); +select 0.9999999999 ^ 23300000000000 = 0 as rounds_to_zero; -- cases that used to error out select 0.12 ^ (-25); select 0.5678 ^ (-85); +select 0.9999999999 ^ 70000000000000 = 0 as underflows; + +-- negative base to integer powers +select (-1.0) ^ 2147483646; +select (-1.0) ^ 2147483647; +select (-1.0) ^ 2147483648; +select (-1.0) ^ 1000000000000000; +select (-1.0) ^ 1000000000000001; -- -- Tests for raising to non-integer powers @@ -1172,6 +1181,8 @@ select exp(1.0::numeric(71,70)); select exp('nan'::numeric); select exp('inf'::numeric); select exp('-inf'::numeric); +select exp(-5000::numeric) = 0 as rounds_to_zero; +select exp(-10000::numeric) = 0 as underflows; -- cases that used to generate inaccurate results select exp(32.999); |
