1#
2# This is a shared file included from t/gis-precise.test and t/gis-debug.test
3#
4# - gis-precise.test is executed both in debug and production builds
5# and makes sure that the checked GIS functions return the expected results.
6#
7# - gis-debug.test is executed only in debug builds
8# (and is skipped in production builds).
9# gis-debug.test activates tracing of the internal GIS routines.
10# The trace log is printed to the client side warnings.
11# So gis-debug.test makes sure not only that the correct results are returned,
12# but also check *how* these results were generated - makes sure that
13# the internal GIS routines went through the expected data and code flow paths.
14#
15
16--disable_warnings
17DROP TABLE IF EXISTS p1;
18--enable_warnings
19
20DELIMITER |;
21CREATE PROCEDURE p1(dist DOUBLE, geom TEXT)
22BEGIN
23  DECLARE g GEOMETRY;
24  SET g=GeomFromText(geom);
25  SELECT geom AS `-----`;
26  SELECT dist, GeometryType(@buf:=ST_Buffer(g, dist)) AS `buffer`, ROUND(ST_AREA(@buf),2) AS buf_area;
27END|
28DELIMITER ;|
29
30--disable_query_log
31
32--echo #
33--echo # Testing ST_BUFFER with positive distance
34--echo #
35
36CALL p1(1, 'POINT(0 0))');
37CALL p1(1, 'LineString(0 1, 1 1))');
38CALL p1(1, 'LineString(9 9,8 1,1 5,0 0)');
39CALL p1(1, 'Polygon((2 2,2 8,8 8,8 2,2 2))');
40CALL p1(1, 'Polygon((0 0,0 8,8 8,8 0,0 0),(2 2,6 2,6 6,2 6,2 2))');
41CALL p1(1, 'Polygon((0 0, 0 8, 8 8, 8 10, -10 10, -10 0, 0 0))');
42CALL p1(1, 'MultiPoint(9 9,8 1,1 5)');
43CALL p1(1, 'MultiLineString((0 0,2 2))');
44CALL p1(1, 'MultiLineString((0 0,2 2,0 4))');
45CALL p1(1, 'MultiLineString((0 0,2 2),(0 2,2 0))');
46CALL p1(1, 'MultiLineString((2 2,2 8,-2 8),(-6 -6, 6 6),(10 10, 14 14))');
47CALL p1(1, 'MultiPolygon(((2 2,2 8,8 8,8 2,2 2)), ((9 9,8 1,1 5,9 9)))');
48CALL p1(1, 'MultiPolygon(((2 2,2 8,8 8,8 2,2 2), (4 4,4 6,6 6,6 4,4 4)),((9 9,8 1,1 5,9 9)))');
49CALL p1(1, 'GeometryCollection(Point(0 0))');
50CALL p1(1, 'GeometryCollection(LineString(0 0, 2 2)))');
51CALL p1(1, 'GeometryCollection(Polygon((2 2,2 8,8 8,8 2,2 2))))');
52CALL p1(1, 'GeometryCollection(MultiPoint(9 9,8 1,1 5))');
53CALL p1(1, 'GeometryCollection(MultiLineString((0 0,0 1),(3 0,3 1)))');
54CALL p1(1, 'GeometryCollection(MultiPolygon(((0 0, 3 0, 3 3, 0 3, 0 0)),((6 6,6 9,9 9,9 6,6 6))))');
55CALL p1(1, 'GeometryCollection(Point(9 9),LineString(1 5,0 0),Polygon((2 2,2 8,8 8,8 2,2 2)))');
56
57
58--echo #
59--echo # Testing ST_BUFFER with zero distance
60--echo #
61
62CALL p1(0, 'POINT(0 0))');
63CALL p1(0, 'LineString(0 1, 1 1))');
64CALL p1(0, 'LineString(9 9,8 1,1 5,0 0)');
65CALL p1(0, 'Polygon((2 2,2 8,8 8,8 2,2 2))');
66CALL p1(0, 'Polygon((0 0,0 8,8 8,8 0,0 0),(2 2,6 2,6 6,2 6,2 2))');
67CALL p1(0, 'Polygon((0 0, 0 8, 8 8, 8 10, -10 10, -10 0, 0 0))');
68CALL p1(0, 'MultiPoint(9 9,8 1,1 5)');
69CALL p1(0, 'MultiLineString((0 0,2 2))');
70CALL p1(0, 'MultiLineString((0 0,2 2,0 4))');
71CALL p1(0, 'MultiLineString((0 0,2 2),(0 2,2 0))');
72CALL p1(0, 'MultiLineString((2 2,2 8,-2 8),(-6 -6, 6 6),(10 10, 14 14))');
73CALL p1(0, 'MultiPolygon(((2 2,2 8,8 8,8 2,2 2)), ((9 9,8 1,1 5,9 9)))');
74CALL p1(0, 'MultiPolygon(((2 2,2 8,8 8,8 2,2 2), (4 4,4 6,6 6,6 4,4 4)),((9 9,8 1,1 5,9 9)))');
75CALL p1(0, 'GeometryCollection(Point(0 0))');
76CALL p1(0, 'GeometryCollection(LineString(0 0, 2 2)))');
77CALL p1(0, 'GeometryCollection(Polygon((2 2,2 8,8 8,8 2,2 2))))');
78CALL p1(0, 'GeometryCollection(MultiPoint(9 9,8 1,1 5))');
79CALL p1(0, 'GeometryCollection(MultiLineString((0 0,0 1),(3 0,3 1)))');
80CALL p1(0, 'GeometryCollection(MultiPolygon(((0 0, 3 0, 3 3, 0 3, 0 0)),((6 6,6 9,9 9,9 6,6 6))))');
81CALL p1(0, 'GeometryCollection(Point(9 9),LineString(1 5,0 0),Polygon((2 2,2 8,8 8,8 2,2 2)))');
82
83
84--echo #
85--echo # Testing ST_BUFFER with negative distance
86--echo #
87
88CALL p1(-1, 'POINT(0 0))');
89CALL p1(-1, 'LineString(0 1, 1 1))');
90CALL p1(-1, 'LineString(9 9,8 1,1 5,0 0)');
91CALL p1(-1, 'Polygon((2 2,2 8,8 8,8 2,2 2))');
92#
93# Wrong shape
94# CALL p1(-1, 'Polygon((0 0,0 8,8 8,8 0,0 0),(2 2,6 2,6 6,2 6,2 2))');
95# Wrong shape
96# CALL p1(-1, 'Polygon((0 0, 0 8, 8 8, 8 10, -10 10, -10 0, 0 0))');
97#
98CALL p1(-1, 'MultiPoint(9 9,8 1,1 5)');
99CALL p1(-1, 'MultiLineString((0 0,2 2))');
100CALL p1(-1, 'MultiLineString((0 0,2 2,0 4))');
101CALL p1(-1, 'MultiLineString((0 0,2 2),(0 2,2 0))');
102CALL p1(-1, 'MultiLineString((2 2,2 8,-2 8),(-6 -6, 6 6),(10 10, 14 14))');
103#
104# Wrong shape
105#CALL p1(-1, 'MultiPolygon(((2 2,2 8,8 8,8 2,2 2)), ((9 9,8 1,1 5,9 9)))');
106#CALL p1(-1, 'MultiPolygon(((2 2,2 8,8 8,8 2,2 2), (4 4,4 6,6 6,6 4,4 4)),((9 9,8 1,1 5,9 9)))');
107#
108CALL p1(-1, 'GeometryCollection(Point(0 0))');
109CALL p1(-1, 'GeometryCollection(LineString(0 0, 2 2)))');
110CALL p1(-1, 'GeometryCollection(Polygon((2 2,2 8,8 8,8 2,2 2))))');
111CALL p1(-1, 'GeometryCollection(MultiPoint(9 9,8 1,1 5))');
112CALL p1(-1, 'GeometryCollection(MultiLineString((0 0,0 1),(3 0,3 1)))');
113#
114# Wrong shape
115# CALL p1(-1, 'GeometryCollection(MultiPolygon(((0 0, 3 0, 3 3, 0 3, 0 0)),((6 6,6 9,9 9,9 6,6 6))))');
116#
117CALL p1(-1, 'GeometryCollection(Point(9 9),LineString(1 5,0 0),Polygon((2 2,2 8,8 8,8 2,2 2)))');
118
119
120--enable_query_log
121
122SELECT ST_CONTAINS(
123  GeomFromText('MULTIPOLYGON(((0 0, 0 5, 5 5, 5 0, 0 0)),((6 6, 6 11, 11 11, 11 6, 6 6)))'),
124  GeomFromText('POINT(5 10)'));
125SELECT AsText(ST_UNION(
126  GeomFromText('MULTIPOLYGON(((0 0, 0 5, 5 5, 5 0, 0 0)),((6 6, 6 11, 11 11, 11 6, 6 6)))'),
127  GeomFromText('POINT(5 10)')));
128
129DROP PROCEDURE p1;
130
131--echo #
132--echo # Bug #13833019 ASSERTION `T1->RESULT_RANGE' FAILED IN GCALC_OPERATION_REDUCER::END_COUPLE
133--echo #
134SELECT GeometryType(ST_BUFFER(MULTIPOLYGONFROMTEXT('MULTIPOLYGON(((0 0,9 4,3 3,0 0)),((2 2,2 2,8 8,2 3,2 2)))'), 3));
135
136--echo #
137--echo # Bug #13832749 	HANDLE_FATAL_SIGNAL IN GCALC_FUNCTION::COUNT_INTERNAL
138--echo #
139SELECT GeometryType(ST_BUFFER(MULTIPOLYGONFROMTEXT('MULTIPOLYGON(((3 5,2 5,2 4,3 4,3 5)),((2 2,2 8,8 8,8 2,2 2), (4 4,4 6,6 6,6 4,4 4)), ((9 9,8 1,1 5,9 9)))'),1));
140
141
142--echo #
143--echo # Bug#13358363 - ASSERTION: N > 0 && N < SINUSES_CALCULATED*2+1 | GET_N_SINCOS/ADD_EDGE_BUFFER
144--echo #
145
146DO ST_BUFFER(ST_GEOMCOLLFROMTEXT('linestring(1 1,2 2)'),'');
147
148SELECT ST_WITHIN(
149        LINESTRINGFROMTEXT(' LINESTRING(3 8,9 2,3 8,3 3,7 6,4 7,4 7,8 1) '),
150        ST_BUFFER(MULTIPOLYGONFROMTEXT(' MULTIPOLYGON(((3 5,2 5,2 4,3 4,3 5)),((2 2,2 8,8 8,8 2,2 2),(4 4,4 6,6 6,6 4,4 4)),((0 5,3 5,3 2,1 2,1 1,3 1,3 0,0 0,0 3,2 3,2 4,0 4,0 5))) '),
151                  ST_NUMINTERIORRINGS(POLYGONFROMTEXT('POLYGON((3 5,2 4,2 5,3 5)) '))));
152
153SELECT ST_DIMENSION(ST_BUFFER(POLYGONFROMTEXT(' POLYGON((3 5,2 5,2 4,3 4,3 5)) '),
154                              ST_NUMINTERIORRINGS(POLYGONFROMTEXT(' POLYGON((0 0,9 3,4 2,0 0))'))));
155
156SELECT ST_NUMINTERIORRINGS(
157       ST_ENVELOPE(ST_BUFFER(MULTIPOLYGONFROMTEXT('MULTIPOLYGON(((3 5,2 5,2 4,3 4,3 5))) '),
158                             SRID(MULTILINESTRINGFROMTEXT('MULTILINESTRING((2 2,4 2,1 2,2 4,2 2)) ')))));
159
160SELECT ASTEXT(ST_BUFFER(POLYGONFROMTEXT(' POLYGON((9 9,5 2,4 5,9 9))'),
161                        SRID(GEOMETRYFROMTEXT(' MULTIPOINT(8 4,5 0,7 8,6 9,3 4,7 3,5 5) '))));
162