diff options
author | Michael P | 2011-03-22 13:55:37 +0000 |
---|---|---|
committer | Pavan Deolasee | 2011-05-24 10:11:49 +0000 |
commit | 3ea4ee8f50c165af648cf7d7c8ff71a5b81d2d50 (patch) | |
tree | 931fa91f92ec0ac3f68e09d19602282fbf8712ea | |
parent | 54302b0b32f35c34ad29e58ac9aa163ff4cd4d08 (diff) |
Fix for regression test point
point is a type that cannot be ordered with ORDER BY,
so create its table as DISTRIBUTE BY REPLICATION for regressions.
-rw-r--r-- | src/test/regress/expected/point_1.out | 249 | ||||
-rw-r--r-- | src/test/regress/sql/point.sql | 4 |
2 files changed, 252 insertions, 1 deletions
diff --git a/src/test/regress/expected/point_1.out b/src/test/regress/expected/point_1.out new file mode 100644 index 0000000000..472930cb6a --- /dev/null +++ b/src/test/regress/expected/point_1.out @@ -0,0 +1,249 @@ +-- +-- POINT +-- +-- Postgres-XC case: point type cannot be ordered so table +-- is replicated for regression tests whatever the cluster configuration +CREATE TABLE POINT_TBL(f1 point) DISTRIBUTE BY REPLICATION; +INSERT INTO POINT_TBL(f1) VALUES ('(0.0,0.0)'); +INSERT INTO POINT_TBL(f1) VALUES ('(-10.0,0.0)'); +INSERT INTO POINT_TBL(f1) VALUES ('(-3.0,4.0)'); +INSERT INTO POINT_TBL(f1) VALUES ('(5.1, 34.5)'); +INSERT INTO POINT_TBL(f1) VALUES ('(-5.0,-12.0)'); +-- bad format points +INSERT INTO POINT_TBL(f1) VALUES ('asdfasdf'); +ERROR: invalid input syntax for type point: "asdfasdf" +LINE 1: INSERT INTO POINT_TBL(f1) VALUES ('asdfasdf'); + ^ +INSERT INTO POINT_TBL(f1) VALUES ('10.0,10.0'); +INSERT INTO POINT_TBL(f1) VALUES ('(10.0 10.0)'); +ERROR: invalid input syntax for type point: "(10.0 10.0)" +LINE 1: INSERT INTO POINT_TBL(f1) VALUES ('(10.0 10.0)'); + ^ +INSERT INTO POINT_TBL(f1) VALUES ('(10.0,10.0'); +ERROR: invalid input syntax for type point: "(10.0,10.0" +LINE 1: INSERT INTO POINT_TBL(f1) VALUES ('(10.0,10.0'); + ^ +SELECT '' AS six, * FROM POINT_TBL; + six | f1 +-----+------------ + | (0,0) + | (-10,0) + | (-3,4) + | (5.1,34.5) + | (-5,-12) + | (10,10) +(6 rows) + +-- left of +SELECT '' AS three, p.* FROM POINT_TBL p WHERE p.f1 << '(0.0, 0.0)' ORDER BY p.f1[0], p.f1[1]; + three | f1 +-------+---------- + | (-10,0) + | (-5,-12) + | (-3,4) +(3 rows) + +-- right of +SELECT '' AS three, p.* FROM POINT_TBL p WHERE '(0.0,0.0)' >> p.f1 ORDER BY p.f1[0], p.f1[1]; + three | f1 +-------+---------- + | (-10,0) + | (-5,-12) + | (-3,4) +(3 rows) + +-- above +SELECT '' AS one, p.* FROM POINT_TBL p WHERE '(0.0,0.0)' >^ p.f1 ORDER BY p.f1[0], p.f1[1]; + one | f1 +-----+---------- + | (-5,-12) +(1 row) + +-- below +SELECT '' AS one, p.* FROM POINT_TBL p WHERE p.f1 <^ '(0.0, 0.0)' ORDER BY p.f1[0], p.f1[1]; + one | f1 +-----+---------- + | (-5,-12) +(1 row) + +-- equal +SELECT '' AS one, p.* FROM POINT_TBL p WHERE p.f1 ~= '(5.1, 34.5)' ORDER BY p.f1[0], p.f1[1]; + one | f1 +-----+------------ + | (5.1,34.5) +(1 row) + +-- point in box +SELECT '' AS three, p.* FROM POINT_TBL p + WHERE p.f1 <@ box '(0,0,100,100)' ORDER BY p.f1[0], p.f1[1]; + three | f1 +-------+------------ + | (0,0) + | (5.1,34.5) + | (10,10) +(3 rows) + +SELECT '' AS three, p.* FROM POINT_TBL p + WHERE box '(0,0,100,100)' @> p.f1; + three | f1 +-------+------------ + | (0,0) + | (5.1,34.5) + | (10,10) +(3 rows) + +SELECT '' AS three, p.* FROM POINT_TBL p + WHERE not p.f1 <@ box '(0,0,100,100)'; + three | f1 +-------+---------- + | (-10,0) + | (-3,4) + | (-5,-12) +(3 rows) + +SELECT '' AS two, p.* FROM POINT_TBL p + WHERE p.f1 <@ path '[(0,0),(-10,0),(-10,10)]' ORDER BY p.f1[0], p.f1[1]; + two | f1 +-----+--------- + | (-10,0) + | (0,0) +(2 rows) + +SELECT '' AS three, p.* FROM POINT_TBL p + WHERE not box '(0,0,100,100)' @> p.f1; + three | f1 +-------+---------- + | (-10,0) + | (-3,4) + | (-5,-12) +(3 rows) + +SELECT '' AS six, p.f1, p.f1 <-> point '(0,0)' AS dist + FROM POINT_TBL p + ORDER BY dist, p.f1[0], p.f1[1]; + six | f1 | dist +-----+------------+------------------ + | (0,0) | 0 + | (-3,4) | 5 + | (-10,0) | 10 + | (-5,-12) | 13 + | (10,10) | 14.142135623731 + | (5.1,34.5) | 34.8749193547455 +(6 rows) + +SELECT '' AS thirtysix, p1.f1 AS point1, p2.f1 AS point2, p1.f1 <-> p2.f1 AS dist + FROM POINT_TBL p1, POINT_TBL p2 + ORDER BY dist, p1.f1[0], p2.f1[0]; + thirtysix | point1 | point2 | dist +-----------+------------+------------+------------------ + | (-10,0) | (-10,0) | 0 + | (-5,-12) | (-5,-12) | 0 + | (-3,4) | (-3,4) | 0 + | (0,0) | (0,0) | 0 + | (5.1,34.5) | (5.1,34.5) | 0 + | (10,10) | (10,10) | 0 + | (-3,4) | (0,0) | 5 + | (0,0) | (-3,4) | 5 + | (-10,0) | (-3,4) | 8.06225774829855 + | (-3,4) | (-10,0) | 8.06225774829855 + | (-10,0) | (0,0) | 10 + | (0,0) | (-10,0) | 10 + | (-10,0) | (-5,-12) | 13 + | (-5,-12) | (-10,0) | 13 + | (-5,-12) | (0,0) | 13 + | (0,0) | (-5,-12) | 13 + | (0,0) | (10,10) | 14.142135623731 + | (10,10) | (0,0) | 14.142135623731 + | (-3,4) | (10,10) | 14.3178210632764 + | (10,10) | (-3,4) | 14.3178210632764 + | (-5,-12) | (-3,4) | 16.1245154965971 + | (-3,4) | (-5,-12) | 16.1245154965971 + | (-10,0) | (10,10) | 22.3606797749979 + | (10,10) | (-10,0) | 22.3606797749979 + | (5.1,34.5) | (10,10) | 24.9851956166046 + | (10,10) | (5.1,34.5) | 24.9851956166046 + | (-5,-12) | (10,10) | 26.6270539113887 + | (10,10) | (-5,-12) | 26.6270539113887 + | (-3,4) | (5.1,34.5) | 31.5572495632937 + | (5.1,34.5) | (-3,4) | 31.5572495632937 + | (0,0) | (5.1,34.5) | 34.8749193547455 + | (5.1,34.5) | (0,0) | 34.8749193547455 + | (-10,0) | (5.1,34.5) | 37.6597928831267 + | (5.1,34.5) | (-10,0) | 37.6597928831267 + | (-5,-12) | (5.1,34.5) | 47.5842410888311 + | (5.1,34.5) | (-5,-12) | 47.5842410888311 +(36 rows) + +SELECT '' AS thirty, p1.f1 AS point1, p2.f1 AS point2 + FROM POINT_TBL p1, POINT_TBL p2 + WHERE (p1.f1 <-> p2.f1) > 3 ORDER BY p1.f1[0], p1.f1[1], p2.f1[0], p2.f1[1]; + thirty | point1 | point2 +--------+------------+------------ + | (-10,0) | (-5,-12) + | (-10,0) | (-3,4) + | (-10,0) | (0,0) + | (-10,0) | (5.1,34.5) + | (-10,0) | (10,10) + | (-5,-12) | (-10,0) + | (-5,-12) | (-3,4) + | (-5,-12) | (0,0) + | (-5,-12) | (5.1,34.5) + | (-5,-12) | (10,10) + | (-3,4) | (-10,0) + | (-3,4) | (-5,-12) + | (-3,4) | (0,0) + | (-3,4) | (5.1,34.5) + | (-3,4) | (10,10) + | (0,0) | (-10,0) + | (0,0) | (-5,-12) + | (0,0) | (-3,4) + | (0,0) | (5.1,34.5) + | (0,0) | (10,10) + | (5.1,34.5) | (-10,0) + | (5.1,34.5) | (-5,-12) + | (5.1,34.5) | (-3,4) + | (5.1,34.5) | (0,0) + | (5.1,34.5) | (10,10) + | (10,10) | (-10,0) + | (10,10) | (-5,-12) + | (10,10) | (-3,4) + | (10,10) | (0,0) + | (10,10) | (5.1,34.5) +(30 rows) + +-- put distance result into output to allow sorting with GEQ optimizer - tgl 97/05/10 +SELECT '' AS fifteen, p1.f1 AS point1, p2.f1 AS point2, (p1.f1 <-> p2.f1) AS distance + FROM POINT_TBL p1, POINT_TBL p2 + WHERE (p1.f1 <-> p2.f1) > 3 and p1.f1 << p2.f1 + ORDER BY distance, p1.f1[0], p2.f1[0]; + fifteen | point1 | point2 | distance +---------+------------+------------+------------------ + | (-3,4) | (0,0) | 5 + | (-10,0) | (-3,4) | 8.06225774829855 + | (-10,0) | (0,0) | 10 + | (-10,0) | (-5,-12) | 13 + | (-5,-12) | (0,0) | 13 + | (0,0) | (10,10) | 14.142135623731 + | (-3,4) | (10,10) | 14.3178210632764 + | (-5,-12) | (-3,4) | 16.1245154965971 + | (-10,0) | (10,10) | 22.3606797749979 + | (5.1,34.5) | (10,10) | 24.9851956166046 + | (-5,-12) | (10,10) | 26.6270539113887 + | (-3,4) | (5.1,34.5) | 31.5572495632937 + | (0,0) | (5.1,34.5) | 34.8749193547455 + | (-10,0) | (5.1,34.5) | 37.6597928831267 + | (-5,-12) | (5.1,34.5) | 47.5842410888311 +(15 rows) + +-- put distance result into output to allow sorting with GEQ optimizer - tgl 97/05/10 +SELECT '' AS three, p1.f1 AS point1, p2.f1 AS point2, (p1.f1 <-> p2.f1) AS distance + FROM POINT_TBL p1, POINT_TBL p2 + WHERE (p1.f1 <-> p2.f1) > 3 and p1.f1 << p2.f1 and p1.f1 >^ p2.f1 + ORDER BY distance, p1.f1[0], p1.f1[1], p2.f1[0], p2.f1[1]; + three | point1 | point2 | distance +-------+------------+----------+------------------ + | (-3,4) | (0,0) | 5 + | (-10,0) | (-5,-12) | 13 + | (5.1,34.5) | (10,10) | 24.9851956166046 +(3 rows) + diff --git a/src/test/regress/sql/point.sql b/src/test/regress/sql/point.sql index 8d32ff8c0a..50d55c870f 100644 --- a/src/test/regress/sql/point.sql +++ b/src/test/regress/sql/point.sql @@ -2,7 +2,9 @@ -- POINT -- -CREATE TABLE POINT_TBL(f1 point); +-- Postgres-XC case: point type cannot use ORDER BY so table +-- is replicated for regression tests whatever the cluster configuration +CREATE TABLE POINT_TBL(f1 point) DISTRIBUTE BY REPLICATION; INSERT INTO POINT_TBL(f1) VALUES ('(0.0,0.0)'); |