| 1 | --- regression test for postGIS |
|---|
| 2 | |
|---|
| 3 | |
|---|
| 4 | |
|---|
| 5 | --- assume datatypes already defined |
|---|
| 6 | |
|---|
| 7 | |
|---|
| 8 | |
|---|
| 9 | --- basic datatypes (correct) |
|---|
| 10 | |
|---|
| 11 | select '1',ST_asewkt('POINT( 1 2 )'::GEOMETRY) as geom; |
|---|
| 12 | select '2',ST_asewkt('POINT( 1 2 3)'::GEOMETRY) as geom; |
|---|
| 13 | |
|---|
| 14 | select '3',ST_asewkt('LINESTRING( 0 0, 1 1, 2 2, 3 3 , 4 4)'::GEOMETRY) as geom; |
|---|
| 15 | select '4',ST_asewkt('LINESTRING( 0 0 0 , 1 1 1 , 2 2 2 , 3 3 3, 4 4 4)'::GEOMETRY) as geom; |
|---|
| 16 | select '5',ST_asewkt('LINESTRING( 1 2 3 , 4 5 6 , 7 8 9 , 10 11 12, 13 14 15)'::GEOMETRY) as geom; |
|---|
| 17 | |
|---|
| 18 | select '6',ST_asewkt('POLYGON( (0 0, 10 0, 10 10, 0 10, 0 0) )'::GEOMETRY) as geom; |
|---|
| 19 | select '7',ST_asewkt('POLYGON( (0 0 1 , 10 0 1, 10 10 1, 0 10 1, 0 0 1) )'::GEOMETRY) as geom; |
|---|
| 20 | select '8',ST_asewkt('POLYGON( (0 0, 10 0, 10 10, 0 10, 0 0),(5 5, 7 5, 7 7 , 5 7, 5 5) )'::GEOMETRY) as geom; |
|---|
| 21 | select '9',ST_asewkt('POLYGON( (0 0, 10 0, 10 10, 0 10, 0 0),(5 5, 7 5, 7 7 , 5 7, 5 5),(1 1,2 1, 2 2, 1 2, 1 1) )'::GEOMETRY) as geom; |
|---|
| 22 | select '10',ST_asewkt('POLYGON( (0 0 1, 10 0 1, 10 10 1, 0 10 1, 0 0 1),(5 5 1, 7 5 1, 7 7 1 , 5 7 1, 5 5 1) )'::GEOMETRY) as geom; |
|---|
| 23 | select '11',ST_asewkt('POLYGON( (0 0 1, 10 0 1, 10 10 1, 0 10 1, 0 0 1),(5 5 1, 7 5 1, 7 7 1, 5 7 1, 5 5 1),(1 1 1,2 1 1, 2 2 1, 1 2 1, 1 1 1) )'::GEOMETRY) as geom; |
|---|
| 24 | |
|---|
| 25 | select '12',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 ))'::GEOMETRY); |
|---|
| 26 | select '13',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 3))'::GEOMETRY); |
|---|
| 27 | select '14',ST_asewkt('GEOMETRYCOLLECTION(LINESTRING( 0 0, 1 1, 2 2, 3 3 , 4 4))'::GEOMETRY); |
|---|
| 28 | select '15',ST_asewkt('GEOMETRYCOLLECTION(LINESTRING( 1 2 3 , 4 5 6 , 7 8 9 , 10 11 12, 13 14 15))'::GEOMETRY); |
|---|
| 29 | select '16',ST_asewkt('GEOMETRYCOLLECTION(POLYGON( (0 0 1, 10 0 1, 10 10 1, 0 10 1, 0 0 1),(5 5 1, 7 5 1, 7 7 1 , 5 7 1, 5 5 1) ))'::GEOMETRY); |
|---|
| 30 | select '17',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 0),POINT( 1 2 3) )'::GEOMETRY); |
|---|
| 31 | select '18',ST_asewkt('GEOMETRYCOLLECTION(LINESTRING( 0 0 0, 1 1 0, 2 2 0, 3 3 0, 4 4 0),POINT( 1 2 3) )'::GEOMETRY); |
|---|
| 32 | select '19',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 ),LINESTRING( 0 0, 1 1, 2 2, 3 3 , 4 4) )'::GEOMETRY); |
|---|
| 33 | select '20',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 0 ),POINT( 1 2 3),LINESTRING( 1 2 3 , 4 5 6 , 7 8 9 , 10 11 12, 13 14 15) )'::GEOMETRY); |
|---|
| 34 | select '21',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 0 ),POINT( 1 2 3),LINESTRING( 1 2 3 , 4 5 6 , 7 8 9 , 10 11 12, 13 14 15),POLYGON( (0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0) ) )'::GEOMETRY); |
|---|
| 35 | select '22',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 0),POINT( 1 2 3),POLYGON( (0 0 1, 10 0 1, 10 10 1, 0 10 1, 0 0 1),(5 5 1, 7 5 1, 7 7 1, 5 7 1, 5 5 1),(1 1 1,2 1 1, 2 2 1, 1 2 1, 1 1 1) ) )'::GEOMETRY); |
|---|
| 36 | |
|---|
| 37 | select '23',ST_asewkt('MULTIPOINT( 1 2)'::GEOMETRY) as geom; |
|---|
| 38 | select '24',ST_asewkt('MULTIPOINT( 1 2 3)'::GEOMETRY) as geom; |
|---|
| 39 | select '25',ST_asewkt('MULTIPOINT( 1 2, 3 4, 5 6)'::GEOMETRY) as geom; |
|---|
| 40 | select '26',ST_asewkt('MULTIPOINT( 1 2 3, 5 6 7, 8 9 10, 11 12 13)'::GEOMETRY) as geom; |
|---|
| 41 | select '27',ST_asewkt('MULTIPOINT( 1 2 0, 1 2 3, 4 5 0, 6 7 8)'::GEOMETRY) as geom; |
|---|
| 42 | select '28',ST_asewkt('MULTIPOINT( 1 2 3,4 5 0)'::GEOMETRY) as geom; |
|---|
| 43 | |
|---|
| 44 | select '29',ST_asewkt('MULTILINESTRING( (0 0, 1 1, 2 2, 3 3 , 4 4) )'::GEOMETRY) as geom; |
|---|
| 45 | select '30',ST_asewkt('MULTILINESTRING( (0 0, 1 1, 2 2, 3 3 , 4 4),(0 0, 1 1, 2 2, 3 3 , 4 4))'::GEOMETRY) as geom; |
|---|
| 46 | select '31',ST_asewkt('MULTILINESTRING( (0 0 0, 1 1 0, 2 2 0, 3 3 0, 4 4 0),(0 0 0, 1 1 0, 2 2 0, 3 3 0, 4 4 0),(1 2 3 , 4 5 6 , 7 8 9 , 10 11 12, 13 14 15) )'::GEOMETRY) as geom; |
|---|
| 47 | select '32',ST_asewkt('MULTILINESTRING( (1 2 3 , 4 5 6 , 7 8 9 , 10 11 12, 13 14 15),(0 0 0, 1 1 0, 2 2 0, 3 3 0, 4 4 0),(0 0 0, 1 1 0, 2 2 0, 3 3 0 , 4 4 0))'::GEOMETRY) as geom; |
|---|
| 48 | |
|---|
| 49 | select '33',ST_asewkt('MULTIPOLYGON( ((0 0, 10 0, 10 10, 0 10, 0 0)) )'::GEOMETRY) as geom; |
|---|
| 50 | select '34',ST_asewkt('MULTIPOLYGON( ((0 0, 10 0, 10 10, 0 10, 0 0)),( (0 0, 10 0, 10 10, 0 10, 0 0),(5 5, 7 5, 7 7 , 5 7, 5 5) ) )'::GEOMETRY) as geom; |
|---|
| 51 | select '35',ST_asewkt('MULTIPOLYGON( ((0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0)),( (0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0),(5 5 0, 7 5 0, 7 7 0, 5 7 0, 5 5 0) ) ,( (0 0 1, 10 0 1, 10 10 1, 0 10 1, 0 0 1),(5 5 1, 7 5 1, 7 7 1, 5 7 1, 5 5 1),(1 1 1,2 1 1, 2 2 1, 1 2 1, 1 1 1) ) )'::GEOMETRY) as geom; |
|---|
| 52 | |
|---|
| 53 | |
|---|
| 54 | select '36',ST_asewkt('GEOMETRYCOLLECTION(MULTIPOINT( 1 2))'::GEOMETRY); |
|---|
| 55 | select '37',ST_asewkt('GEOMETRYCOLLECTION(MULTIPOINT( 1 2 3))'::GEOMETRY); |
|---|
| 56 | select '38',ST_asewkt('GEOMETRYCOLLECTION(MULTIPOINT( 1 2 3, 5 6 7, 8 9 10, 11 12 13))'::GEOMETRY); |
|---|
| 57 | select '39',ST_asewkt('GEOMETRYCOLLECTION(MULTILINESTRING( (0 0, 1 1, 2 2, 3 3 , 4 4) ))'::GEOMETRY); |
|---|
| 58 | select '40',ST_asewkt('GEOMETRYCOLLECTION(MULTILINESTRING( (1 2 3 , 4 5 6 , 7 8 9 , 10 11 12, 13 14 15),(0 0 0, 1 1 0, 2 2 0, 3 3 0, 4 4 0),(0 0 0, 1 1 0, 2 2 0, 3 3 0, 4 4 0)))'::GEOMETRY); |
|---|
| 59 | select '41',ST_asewkt('GEOMETRYCOLLECTION(MULTIPOLYGON( ((0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0)),( (0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0),(5 5 0, 7 5 0, 7 7 0, 5 7 0, 5 5 0) ) ,( (0 0 1, 10 0 1, 10 10 1, 0 10 1, 0 0 1),(5 5 1, 7 5 1, 7 7 1, 5 7 1, 5 5 1),(1 1 1,2 1 1, 2 2 1, 1 2 1, 1 1 1) ) ))'::GEOMETRY); |
|---|
| 60 | select '42',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 0),MULTIPOINT( 1 2 3))'::GEOMETRY); |
|---|
| 61 | select '43',ST_asewkt('GEOMETRYCOLLECTION(MULTIPOINT( 1 2 0, 3 4 0, 5 6 0),POINT( 1 2 3))'::GEOMETRY); |
|---|
| 62 | select '44',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 3),MULTILINESTRING( (0 0 0, 1 1 0, 2 2 0, 3 3 0 , 4 4 0) ))'::GEOMETRY); |
|---|
| 63 | select '45',ST_asewkt('GEOMETRYCOLLECTION(MULTILINESTRING( (0 0 0, 1 1 0, 2 2 0, 3 3 0 , 4 4 0) ),POINT( 1 2 3))'::GEOMETRY); |
|---|
| 64 | select '46',ST_asewkt('GEOMETRYCOLLECTION(POINT( 1 2 3), MULTIPOLYGON( ((0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0)),( (0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0),(5 5 0, 7 5 0, 7 7 0, 5 7 0, 5 5 0) ) ,( (0 0 1, 10 0 1, 10 10 1, 0 10 1, 0 0 1),(5 5 1, 7 5 1, 7 7 1, 5 7 1, 5 5 1),(1 1 1,2 1 1, 2 2 1, 1 2 1, 1 1 1) ) ))'::GEOMETRY); |
|---|
| 65 | select '47',ST_asewkt('GEOMETRYCOLLECTION(MULTIPOLYGON( ((0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0)),( (0 0 0, 10 0 0, 10 10 0, 0 10 0, 0 0 0),(5 5 0, 7 5 0, 7 7 0, 5 7 0, 5 5 0) ) ,( (0 0 1, 10 0 1, 10 10 1, 0 10 1, 0 0 1),(5 5 1, 7 5 1, 7 7 1, 5 7 1, 5 5 1),(1 1 1,2 1 1, 2 2 1, 1 2 1, 1 1 1) ) ),MULTILINESTRING( (0 0 0, 1 1 0, 2 2 0, 3 3 0, 4 4 0),(0 0 0, 1 1 0, 2 2 0, 3 3 0, 4 4 0),(1 2 3 , 4 5 6 , 7 8 9 , 10 11 12, 13 14 15) ),MULTIPOINT( 1 2 3, 5 6 7, 8 9 10, 11 12 13))'::GEOMETRY); |
|---|
| 66 | |
|---|
| 67 | select '48',ST_asewkt('MULTIPOINT( -1 -2 -3, 5.4 6.6 7.77, -5.4 -6.6 -7.77, 1e6 1e-6 -1e6, -1.3e-6 -1.4e-5 0)'::GEOMETRY) as geom; |
|---|
| 68 | |
|---|
| 69 | select '49', ST_asewkt('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(POINT(1 1) ))'::GEOMETRY) as geom; |
|---|
| 70 | --- basic datatype (incorrect) |
|---|
| 71 | |
|---|
| 72 | select '50', 'POINT()'::GEOMETRY as geom; |
|---|
| 73 | select '51', 'POINT(1)'::GEOMETRY as geom; |
|---|
| 74 | select '52', 'POINT(,)'::GEOMETRY as geom; |
|---|
| 75 | select '53', 'MULTIPOINT(,)'::GEOMETRY as geom; |
|---|
| 76 | select '54', 'POINT(a b)'::GEOMETRY as geom; |
|---|
| 77 | select '55', 'MULTIPOINT()'::GEOMETRY as geom; |
|---|
| 78 | select '56', ST_asewkt('POLYGON( (0 0, 10 0, 10 10, 0 10) )'::GEOMETRY); |
|---|
| 79 | select '57', ST_asewkt('POLYGON( (0 0, 10 0, 10 10, 0 10, 0 0),(5 5, 7 5, 7 7 , 5 7) )'::GEOMETRY); |
|---|
| 80 | select '58', ST_asewkt('MULTILINESTRING((0 0, 1 1),(0 0, 1 1, 2 2,) )'::GEOMETRY); |
|---|
| 81 | |
|---|
| 82 | |
|---|
| 83 | --- funny results |
|---|
| 84 | |
|---|
| 85 | select '59',ST_asewkt('POINT(1 2 3, 4 5 6)'::GEOMETRY); |
|---|
| 86 | select '60',ST_asewkt('POINT(1 2 3 4 5 6 7)'::GEOMETRY); |
|---|
| 87 | select '61',ST_asewkt('LINESTRING(1 1)'::GEOMETRY); |
|---|
| 88 | select '62',regexp_replace(ST_asewkt('POINT( 1e700 0)'::GEOMETRY), E'(Infinity|1\.#INF)', 'inf'); |
|---|
| 89 | select '63',regexp_replace(ST_asewkt('POINT( -1e700 0)'::GEOMETRY), E'(Infinity|1\.#INF)', 'inf'); |
|---|
| 90 | --select '62',ST_asewkt('POINT( 1e700 0)'::GEOMETRY); |
|---|
| 91 | --select '63',ST_asewkt('POINT( -1e700 0)'::GEOMETRY); |
|---|
| 92 | select '64',ST_asewkt('MULTIPOINT(1 1, 2 2'::GEOMETRY); |
|---|
| 93 | |
|---|
| 94 | |
|---|
| 95 | --- is_same() testing |
|---|
| 96 | |
|---|
| 97 | select '65','POINT(1 1)'::GEOMETRY ~= 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 98 | select '65a',ST_OrderingEquals('POINT(1 1)'::GEOMETRY,'POINT(1 1)'::GEOMETRY) as bool; |
|---|
| 99 | select '66','POINT(1 1 0)'::GEOMETRY ~= 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 100 | select '66a',ST_OrderingEquals('POINT(1 1 0)'::GEOMETRY,'POINT(1 1)'::GEOMETRY) as bool; |
|---|
| 101 | select '67','POINT(1 1 0)'::GEOMETRY ~= 'POINT(1 1 0)'::GEOMETRY as bool; |
|---|
| 102 | select '67a',ST_OrderingEquals('POINT(1 1 0)'::GEOMETRY,'POINT(1 1 0)'::GEOMETRY) as bool; |
|---|
| 103 | |
|---|
| 104 | select '68','MULTIPOINT(1 1,2 2)'::GEOMETRY ~= 'MULTIPOINT(1 1,2 2)'::GEOMETRY as bool; |
|---|
| 105 | select '68a',ST_OrderingEquals('MULTIPOINT(1 1,2 2)'::GEOMETRY,'MULTIPOINT(1 1,2 2)'::GEOMETRY) as bool; |
|---|
| 106 | select '69','MULTIPOINT(2 2, 1 1)'::GEOMETRY ~= 'MULTIPOINT(1 1,2 2)'::GEOMETRY as bool; |
|---|
| 107 | select '69a',ST_OrderingEquals('MULTIPOINT(2 2, 1 1)'::GEOMETRY,'MULTIPOINT(1 1,2 2)'::GEOMETRY) as bool; |
|---|
| 108 | |
|---|
| 109 | select '70','GEOMETRYCOLLECTION(POINT( 1 2 3),POINT(4 5 6))'::GEOMETRY ~= 'GEOMETRYCOLLECTION(POINT( 4 5 6),POINT(1 2 3))'::GEOMETRY as bool; |
|---|
| 110 | select '70a',ST_OrderingEquals('GEOMETRYCOLLECTION(POINT( 1 2 3),POINT(4 5 6))'::GEOMETRY,'GEOMETRYCOLLECTION(POINT( 4 5 6),POINT(1 2 3))'::GEOMETRY) as bool; |
|---|
| 111 | select '71','MULTIPOINT(4 5 6, 1 2 3)'::GEOMETRY ~= 'GEOMETRYCOLLECTION(POINT( 4 5 6),POINT(1 2 3))'::GEOMETRY as bool; |
|---|
| 112 | select '71a',ST_OrderingEquals('MULTIPOINT(4 5 6, 1 2 3)'::GEOMETRY,'GEOMETRYCOLLECTION(POINT( 4 5 6),POINT(1 2 3))'::GEOMETRY) as bool; |
|---|
| 113 | select '72','MULTIPOINT(1 2 3, 4 5 6)'::GEOMETRY ~= 'GEOMETRYCOLLECTION(POINT( 4 5 6),POINT(1 2 3))'::GEOMETRY as bool; |
|---|
| 114 | select '72a',ST_OrderingEquals('MULTIPOINT(1 2 3, 4 5 6)'::GEOMETRY,'GEOMETRYCOLLECTION(POINT( 4 5 6),POINT(1 2 3))'::GEOMETRY) as bool; |
|---|
| 115 | select '73','MULTIPOINT(1 2 3, 4 5 6)'::GEOMETRY ~= 'GEOMETRYCOLLECTION(MULTIPOINT(1 2 3, 4 5 6))'::GEOMETRY as bool; |
|---|
| 116 | select '73a',ST_OrderingEquals('MULTIPOINT(1 2 3, 4 5 6)'::GEOMETRY,'GEOMETRYCOLLECTION(MULTIPOINT(1 2 3, 4 5 6))'::GEOMETRY) as bool; |
|---|
| 117 | |
|---|
| 118 | |
|---|
| 119 | select '74','LINESTRING(1 1,2 2)'::GEOMETRY ~= 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 120 | select '74a',ST_OrderingEquals('LINESTRING(1 1,2 2)'::GEOMETRY,'POINT(1 1)'::GEOMETRY) as bool; |
|---|
| 121 | select '75','LINESTRING(1 1, 2 2)'::GEOMETRY ~= 'LINESTRING(2 2, 1 1)'::GEOMETRY as bool; |
|---|
| 122 | select '75a',ST_OrderingEquals('LINESTRING(1 1, 2 2)'::GEOMETRY,'LINESTRING(2 2, 1 1)'::GEOMETRY) as bool; |
|---|
| 123 | select '76','LINESTRING(1 1, 2 2)'::GEOMETRY ~= 'LINESTRING(1 1, 2 2, 3 3)'::GEOMETRY as bool; |
|---|
| 124 | select '76a',ST_OrderingEquals('LINESTRING(1 1, 2 2)'::GEOMETRY,'LINESTRING(1 1, 2 2, 3 3)'::GEOMETRY) as bool; |
|---|
| 125 | |
|---|
| 126 | --- operator testing (testing is on the BOUNDING BOX (2d), not the actual geometries) |
|---|
| 127 | |
|---|
| 128 | select '77','POINT(1 1)'::GEOMETRY &< 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 129 | select '78','POINT(1 1)'::GEOMETRY &< 'POINT(2 1)'::GEOMETRY as bool; |
|---|
| 130 | select '79','POINT(2 1)'::GEOMETRY &< 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 131 | |
|---|
| 132 | select '80','POINT(1 1)'::GEOMETRY << 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 133 | select '81','POINT(1 1)'::GEOMETRY << 'POINT(2 1)'::GEOMETRY as bool; |
|---|
| 134 | select '82','POINT(2 1)'::GEOMETRY << 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 135 | |
|---|
| 136 | |
|---|
| 137 | select '83','POINT(1 1)'::GEOMETRY &> 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 138 | select '84','POINT(1 1)'::GEOMETRY &> 'POINT(2 1)'::GEOMETRY as bool; |
|---|
| 139 | select '85','POINT(2 1)'::GEOMETRY &> 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 140 | |
|---|
| 141 | select '86','POINT(1 1)'::GEOMETRY >> 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 142 | select '87','POINT(1 1)'::GEOMETRY >> 'POINT(2 1)'::GEOMETRY as bool; |
|---|
| 143 | select '88','POINT(2 1)'::GEOMETRY >> 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 144 | |
|---|
| 145 | -- overlap |
|---|
| 146 | |
|---|
| 147 | select '89','POINT(1 1)'::GEOMETRY && 'POINT(1 1)'::GEOMETRY as bool; |
|---|
| 148 | select '90','POINT(1 1)'::GEOMETRY && 'POINT(2 2)'::GEOMETRY as bool; |
|---|
| 149 | select '91','MULTIPOINT(0 0, 1 1)'::GEOMETRY && 'MULTIPOINT(1 1, 2 2)'::GEOMETRY as bool; |
|---|
| 150 | select '92','MULTIPOINT(0 0, 1 1)'::GEOMETRY && 'MULTIPOINT(1.0001 1, 2 2)'::GEOMETRY as bool; |
|---|
| 151 | select '93','MULTIPOINT(0 0, 1 1)'::GEOMETRY && 'MULTIPOINT(1 1.0001, 2 2)'::GEOMETRY as bool; |
|---|
| 152 | select '94','MULTIPOINT(0 0, 1 1)'::GEOMETRY && 'MULTIPOINT(1 0, 2 2)'::GEOMETRY as bool; |
|---|
| 153 | select '95','MULTIPOINT(0 0, 1 1)'::GEOMETRY && 'MULTIPOINT(1.0001 0, 2 2)'::GEOMETRY as bool; |
|---|
| 154 | |
|---|
| 155 | select '96','MULTIPOINT(0 0, 1 1)'::GEOMETRY && 'MULTIPOINT(0 1, 1 2)'::GEOMETRY as bool; |
|---|
| 156 | select '97','MULTIPOINT(0 0, 1 1)'::GEOMETRY && 'MULTIPOINT(0 1.0001, 1 2)'::GEOMETRY as bool; |
|---|
| 157 | |
|---|
| 158 | --- contains |
|---|
| 159 | |
|---|
| 160 | select '98','MULTIPOINT(0 0, 10 10)'::GEOMETRY ~ 'MULTIPOINT(5 5, 7 7)'::GEOMETRY as bool; |
|---|
| 161 | select '99','MULTIPOINT(5 5, 7 7)'::GEOMETRY ~ 'MULTIPOINT(0 0, 10 10)'::GEOMETRY as bool; |
|---|
| 162 | select '100','MULTIPOINT(0 0, 7 7)'::GEOMETRY ~ 'MULTIPOINT(0 0, 10 10)'::GEOMETRY as bool; |
|---|
| 163 | select '101','MULTIPOINT(-0.0001 0, 7 7)'::GEOMETRY ~ 'MULTIPOINT(0 0, 10 10)'::GEOMETRY as bool; |
|---|
| 164 | |
|---|
| 165 | --- contained by |
|---|
| 166 | |
|---|
| 167 | select '102','MULTIPOINT(0 0, 10 10)'::GEOMETRY @ 'MULTIPOINT(5 5, 7 7)'::GEOMETRY as bool; |
|---|
| 168 | select '103','MULTIPOINT(5 5, 7 7)'::GEOMETRY @ 'MULTIPOINT(0 0, 10 10)'::GEOMETRY as bool; |
|---|
| 169 | select '104','MULTIPOINT(0 0, 7 7)'::GEOMETRY @ 'MULTIPOINT(0 0, 10 10)'::GEOMETRY as bool; |
|---|
| 170 | select '105','MULTIPOINT(-0.0001 0, 7 7)'::GEOMETRY @ 'MULTIPOINT(0 0, 10 10)'::GEOMETRY as bool; |
|---|
| 171 | |
|---|
| 172 | |
|---|
| 173 | |
|---|
| 174 | --- function testing |
|---|
| 175 | --- conversion function |
|---|
| 176 | |
|---|
| 177 | select '106',box3d('MULTIPOINT(0 0, 7 7)'::GEOMETRY) as bvol; |
|---|
| 178 | |
|---|
| 179 | -- box3d only type is only used for indexing -- NEVER use one yourself |
|---|
| 180 | select '107',ST_AsEWKT(geometry('BOX3D(0 0 0, 7 7 7 )'::BOX3D)); |
|---|
| 181 | |
|---|
| 182 | --- debug function testing |
|---|
| 183 | |
|---|
| 184 | select '108',ST_NPoints('MULTIPOINT(0 0, 7 7)'::GEOMETRY) as value; |
|---|
| 185 | select '109',ST_NPoints('GEOMETRYCOLLECTION(POINT(1 1), LINESTRING( 1 1 , 2 2, 3 3))'::GEOMETRY) as value; |
|---|
| 186 | |
|---|
| 187 | select '110', ST_NRings('MULTIPOLYGON( ((0 0, 10 0, 10 10, 0 10, 0 0)),( (0 0, 10 0, 10 10, 0 10, 0 0),(5 5, 7 5, 7 7 , 5 7, 5 5) ) ,( (0 0, 10 0, 10 10, 0 10, 0 0),(5 5, 7 5, 7 7, 5 7, 5 5),(1 1,2 1, 2 2, 1 2, 1 1) ) )'::GEOMETRY) as value; |
|---|
| 188 | |
|---|
| 189 | select '111', ST_mem_size(PostGIS_DropBBOX('MULTIPOLYGON( ((0 0, 10 0, 10 10, 0 10, 0 0)),( (0 0, 10 0, 10 10, 0 10, 0 0),(5 5, 7 5, 7 7 , 5 7, 5 5) ) ,( (0 0, 10 0, 10 10, 0 10, 0 0),(5 5, 7 5, 7 7, 5 7, 5 5),(1 1,2 1, 2 2, 1 2, 1 1) ) )'::GEOMETRY)) as value; |
|---|
| 190 | |
|---|
| 191 | select '112',ST_NumGeometries('GEOMETRYCOLLECTION(POINT(1 1), LINESTRING( 1 1 , 2 2, 3 3),MULTIPOINT(1 1, 2 2))'::GEOMETRY) as value; |
|---|
| 192 | |
|---|
| 193 | ---selection |
|---|
| 194 | |
|---|
| 195 | |
|---|
| 196 | |
|---|
| 197 | --- TOAST testing |
|---|
| 198 | |
|---|
| 199 | -- create a table with data that will be TOASTed (even after compression) |
|---|
| 200 | create table TEST(a GEOMETRY, b GEOMETRY); |
|---|
| 201 | \i regress_biginsert.sql |
|---|
| 202 | |
|---|
| 203 | |
|---|
| 204 | ---test basic ops on this |
|---|
| 205 | |
|---|
| 206 | select '121',box3d(a) as box3d_a, box3d(b) as box3d_b from TEST; |
|---|
| 207 | |
|---|
| 208 | select '122',a <<b from TEST; |
|---|
| 209 | select '123',a &<b from TEST; |
|---|
| 210 | select '124',a >>b from TEST; |
|---|
| 211 | select '125',a &>b from TEST; |
|---|
| 212 | |
|---|
| 213 | select '126',a ~= b from TEST; |
|---|
| 214 | select '127',a @ b from TEST; |
|---|
| 215 | select '128',a ~ b from TEST; |
|---|
| 216 | |
|---|
| 217 | select '129', ST_mem_size(PostGIS_DropBBOX(a)), ST_mem_size(PostGIS_DropBBOX(b)) from TEST; |
|---|
| 218 | |
|---|
| 219 | select '131', ST_X('POINT(1 2)'); |
|---|
| 220 | select '132', ST_Y('POINT(1 2)'); |
|---|
| 221 | select '133', ST_Z('POINT(1 2)'); |
|---|
| 222 | select '133a', ST_Z('POINT(1 2 3)'); |
|---|
| 223 | select '133b', ST_Z('POINTM(1 2 3)'); |
|---|
| 224 | select '133c', ST_M('POINT(1 2)'); |
|---|
| 225 | select '133d', ST_M('POINTM(1 2 4)'); |
|---|
| 226 | select '133e', ST_M('POINT(1 2 4)'); |
|---|
| 227 | |
|---|
| 228 | select '137', box3d('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION EMPTY)'::geometry); |
|---|
| 229 | select '138', box3d('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION EMPTY, POINT(0 0))'::geometry); |
|---|
| 230 | |
|---|
| 231 | select '139', ST_AsEWKT(ST_multi(ST_setsrid('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION EMPTY, POINT(0 0))'::geometry, 2))); |
|---|
| 232 | select '140', ST_AsEWKT(ST_multi(ST_setsrid('POINT(2 2)'::geometry, 3))); |
|---|
| 233 | select '141', ST_AsEWKT(ST_multi(ST_setsrid('LINESTRING(2 2, 3 3)'::geometry, 4))); |
|---|
| 234 | select '142', ST_AsEWKT(ST_multi(ST_setsrid('LINESTRING(2 2, 3 3)'::geometry, 5))); |
|---|
| 235 | select '143', ST_AsEWKT(ST_multi(ST_setsrid('POLYGON((0 0, 1 0, 1 1, 0 1, 0 0))'::geometry, 6))); |
|---|
| 236 | select '143c1', ST_AsEWKT(ST_multi('CIRCULARSTRING(0 0, 1 1, 2 2)'::geometry)); |
|---|
| 237 | select '144', ST_AsEWKT(ST_force_3dm('POINT(1 2 3)')); |
|---|
| 238 | select '145', ST_AsEWKT(ST_force_3dz('POINTM(1 2 3)')); |
|---|
| 239 | select '146', ST_AsEWKT(ST_force_4d('POINTM(1 2 3)')); |
|---|
| 240 | select '147', ST_AsEWKT(ST_force_4d('POINT(1 2 3)')); |
|---|
| 241 | |
|---|
| 242 | select '148', ST_AsText(ST_segmentize('LINESTRING(0 0, 10 0)', 5)); |
|---|
| 243 | |
|---|
| 244 | select '149', ST_AsText(ST_segmentize('GEOMETRYCOLLECTION EMPTY', 0.5)); |
|---|
| 245 | |
|---|
| 246 | select '150', ST_AsEWKT(ST_force_collection(ST_setsrid('POLYGON((0 0, 1 0, 1 1, 0 1, 0 0))'::geometry, 6))); |
|---|
| 247 | |
|---|
| 248 | select '151', ST_MakeEnvelope(0, 0, 1, 1, 4326); |
|---|
| 249 | select '152', ST_SRID(ST_MakeEnvelope(0, 0, 1, 1, 4326)); |
|---|
| 250 | select '152.1', ST_SRID(ST_MakeEnvelope(0, 0, 1, 1)) = ST_SRID('POINT(0 0)'); |
|---|
| 251 | select '152.2', ST_SRID(ST_SetSRID(ST_MakeEnvelope(0, 0, 1, 1), 4326)); |
|---|
| 252 | |
|---|
| 253 | select '153', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(POINT(0 0))',1)); |
|---|
| 254 | select '154', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(POINT(0 0)))',1)); |
|---|
| 255 | select '155', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(POINT(0 0), POINT(1 1)))',1)); |
|---|
| 256 | select '156', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(LINESTRING(0 0, 1 1), POINT(1 1)))',1)); |
|---|
| 257 | select '157', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(LINESTRING(0 0, 1 1), POINT(1 1)))',2)); |
|---|
| 258 | select '158', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(LINESTRING(0 0, 1 1), POINT(1 1)),LINESTRING(2 2, 3 3))',2)); |
|---|
| 259 | select '159', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(LINESTRING(0 0, 1 1), POINT(1 1)),LINESTRING(2 2, 3 3))',3)); |
|---|
| 260 | select '160', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(LINESTRING(0 0, 1 1), POINT(1 1)),LINESTRING(2 2, 3 3))',1)); |
|---|
| 261 | select '161', ST_AsText(ST_CollectionExtract('GEOMETRYCOLLECTION(GEOMETRYCOLLECTION(LINESTRING(0 0, 1 1), GEOMETRYCOLLECTION(POINT(1 1))),LINESTRING(2 2, 3 3))',2)); |
|---|
| 262 | select '162', ST_MakeLine(ST_GeomFromText('POINT(-11.1111111 40)'),ST_GeomFromText('LINESTRING(-11.1111111 70,70 -11.1111111)')) As result; |
|---|
| 263 | select '163', ST_AsEWKT('POLYGON((0 0 0, 1 0 0, 1 1 0, 0 1 0, 0 0 0))'); |
|---|
| 264 | select '164', ST_AsEWKT('POLYGON((0 0 0, 1 0 0, 1 1 0, 0 1 0, 0 0 1))'); |
|---|
| 265 | select '165', ST_AsEWKT('POLYGON((0 0 0, 1 0 0, 1 1 0, 0 1 0, 0 0.1 1))'); |
|---|
| 266 | select '166', ST_AsText('POINT EMPTY'); |
|---|
| 267 | select '167', ST_AsText('LINESTRING EMPTY'); |
|---|
| 268 | select '168', ST_AsText('POLYGON EMPTY'); |
|---|
| 269 | select '169', ST_AsText('CIRCULARSTRING EMPTY'); |
|---|
| 270 | select '170', ST_AsText('COMPOUNDCURVE EMPTY'); |
|---|
| 271 | select '171', ST_AsText('CURVEPOLYGON EMPTY'); |
|---|
| 272 | select '172', ST_AsText('MULTIPOINT EMPTY'); |
|---|
| 273 | select '173', ST_AsText('MULTILINESTRING EMPTY'); |
|---|
| 274 | select '174', ST_AsText('MULTIPOLYGON EMPTY'); |
|---|
| 275 | select '175', ST_AsText('TRIANGLE EMPTY'); |
|---|
| 276 | select '176', ST_AsText('TIN EMPTY'); |
|---|
| 277 | select '177', ST_AsText('POLYHEDRALSURFACE EMPTY'); |
|---|
| 278 | select '178', ST_AsText('MULTISURFACE EMPTY'); |
|---|
| 279 | select '179', ST_AsText('MULTICURVE EMPTY'); |
|---|
| 280 | select '180', ST_AsText('GEOMETRYCOLLECTION EMPTY'); |
|---|
| 281 | select '181', ST_AsText('GEOMETRYCOLLECTION(TRIANGLE EMPTY,TIN EMPTY)'); |
|---|
| 282 | |
|---|
| 283 | |
|---|
| 284 | -- Drop test table |
|---|
| 285 | DROP table test; |
|---|