postgis/regress/core/isvaliddetail.sql
Raúl Marín Rodríguez f36587f776 Use BEGIN-ROLLBACK instead of RESET
git-svn-id: http://svn.osgeo.org/postgis/trunk@17955 b70326c6-7e19-0410-871a-916f4a2858ee
2019-10-18 12:18:06 +00:00

61 lines
1.8 KiB
PL/PgSQL

select 1, valid, reason, st_astext(location) FROM (
SELECT (ST_IsValidDetail('LINESTRING (70 250, 190 340)')).*
) foo;
select 2, valid, reason, st_astext(location) FROM (
SELECT (ST_IsValidDetail('LINESTRING (70 250, 70 250)')).*
) foo;
-- Twisted polygon
select 3, valid, reason, st_astext(location) FROM (
SELECT (ST_IsValidDetail(
'POLYGON ((70 250, 70 500, 80 400, 40 400, 70 250))'
)).*
) foo;
-- Twisted polygon is also invalid for ESRI
select 4, valid, reason, st_astext(location) FROM (
SELECT (ST_IsValidDetail(
'POLYGON ((70 250, 70 500, 80 400, 40 400, 70 250))'
,
1 -- ESRI flag
)).*
) foo;
-- Self-touching ring forming hole
select 5, valid, reason, st_astext(location) FROM (
SELECT (ST_IsValidDetail(
'POLYGON ((70 250, 40 500, 100 400, 70 250, 80 350, 60 350, 70 250))'
,
0 -- No flags
)).*
) foo;
select '5s', ST_IsValid(
'POLYGON ((70 250, 40 500, 100 400, 70 250, 80 350, 60 350, 70 250))' , 0);
select '5r', ST_IsValidReason(
'POLYGON ((70 250, 40 500, 100 400, 70 250, 80 350, 60 350, 70 250))' , 0);
-- Self-touching ring forming hole with ESRI flag
select 6, valid, reason, st_astext(location) FROM (
SELECT (ST_IsValidDetail(
'POLYGON ((70 250, 40 500, 100 400, 70 250, 80 350, 60 350, 70 250))'
,
1 -- ESRI flag
)).*
) foo;
select '6s', ST_IsValid(
'POLYGON ((70 250, 40 500, 100 400, 70 250, 80 350, 60 350, 70 250))' , 1);
select '5r', ST_IsValidReason(
'POLYGON ((70 250, 40 500, 100 400, 70 250, 80 350, 60 350, 70 250))' , 1);
-- Check that it works without the extension schema being available
BEGIN;
SET search_path TO pg_catalog;
select 7, valid, reason, :schema st_astext(location) FROM (
SELECT (:schema ST_IsValidDetail(
'POLYGON ((70 250, 70 500, 80 400, 40 400, 70 250))':: :schema geometry
)).*
) foo;
ROLLBACK;