mirror of https://github.com/django/django.git
Added more WKT and WKB tests.
This commit is contained in:
parent
a5622f84ab
commit
1c3a9b9f96
|
@ -727,3 +727,86 @@ class OGRGeomTest(SimpleTestCase, TestDataMixin):
|
|||
msg = "Input to 'set_3d' must be a boolean, got 'None'"
|
||||
with self.assertRaisesMessage(ValueError, msg):
|
||||
geom.set_3d(None)
|
||||
|
||||
def test_wkt_and_wkb_output(self):
|
||||
tests = [
|
||||
# 2D
|
||||
("POINT (1 2)", "0101000000000000000000f03f0000000000000040"),
|
||||
(
|
||||
"LINESTRING (30 10,10 30)",
|
||||
"0102000000020000000000000000003e400000000000002"
|
||||
"44000000000000024400000000000003e40",
|
||||
),
|
||||
(
|
||||
"POLYGON ((30 10,40 40,20 40,30 10))",
|
||||
"010300000001000000040000000000000000003e400000000000002440000000000000"
|
||||
"44400000000000004440000000000000344000000000000044400000000000003e4000"
|
||||
"00000000002440",
|
||||
),
|
||||
(
|
||||
"MULTIPOINT (10 40,40 30)",
|
||||
"0104000000020000000101000000000000000000244000000000000044400101000000"
|
||||
"00000000000044400000000000003e40",
|
||||
),
|
||||
(
|
||||
"MULTILINESTRING ((10 10,20 20),(40 40,30 30,40 20))",
|
||||
"0105000000020000000102000000020000000000000000002440000000000000244000"
|
||||
"0000000000344000000000000034400102000000030000000000000000004440000000"
|
||||
"00000044400000000000003e400000000000003e400000000000004440000000000000"
|
||||
"3440",
|
||||
),
|
||||
(
|
||||
"MULTIPOLYGON (((30 20,45 40,10 40,30 20)),((15 5,40 10,10 20,15 5)))",
|
||||
"010600000002000000010300000001000000040000000000000000003e400000000000"
|
||||
"0034400000000000804640000000000000444000000000000024400000000000004440"
|
||||
"0000000000003e40000000000000344001030000000100000004000000000000000000"
|
||||
"2e40000000000000144000000000000044400000000000002440000000000000244000"
|
||||
"000000000034400000000000002e400000000000001440",
|
||||
),
|
||||
(
|
||||
"GEOMETRYCOLLECTION (POINT (40 10))",
|
||||
"010700000001000000010100000000000000000044400000000000002440",
|
||||
),
|
||||
# 3D
|
||||
(
|
||||
"POINT (1 2 3)",
|
||||
"0101000080000000000000f03f00000000000000400000000000000840",
|
||||
),
|
||||
(
|
||||
"LINESTRING (30 10 3,10 30 3)",
|
||||
"0102000080020000000000000000003e40000000000000244000000000000008400000"
|
||||
"0000000024400000000000003e400000000000000840",
|
||||
),
|
||||
(
|
||||
"POLYGON ((30 10 3,40 40 3,30 10 3))",
|
||||
"010300008001000000030000000000000000003e400000000000002440000000000000"
|
||||
"08400000000000004440000000000000444000000000000008400000000000003e4000"
|
||||
"000000000024400000000000000840",
|
||||
),
|
||||
(
|
||||
"MULTIPOINT (10 40 3,40 30 3)",
|
||||
"0104000080020000000101000080000000000000244000000000000044400000000000"
|
||||
"000840010100008000000000000044400000000000003e400000000000000840",
|
||||
),
|
||||
(
|
||||
"MULTILINESTRING ((10 10 3,20 20 3))",
|
||||
"0105000080010000000102000080020000000000000000002440000000000000244000"
|
||||
"00000000000840000000000000344000000000000034400000000000000840",
|
||||
),
|
||||
(
|
||||
"MULTIPOLYGON (((30 20 3,45 40 3,30 20 3)))",
|
||||
"010600008001000000010300008001000000030000000000000000003e400000000000"
|
||||
"0034400000000000000840000000000080464000000000000044400000000000000840"
|
||||
"0000000000003e4000000000000034400000000000000840",
|
||||
),
|
||||
(
|
||||
"GEOMETRYCOLLECTION (POINT (40 10 3))",
|
||||
"0107000080010000000101000080000000000000444000000000000024400000000000"
|
||||
"000840",
|
||||
),
|
||||
]
|
||||
for geom, wkb in tests:
|
||||
with self.subTest(geom=geom):
|
||||
g = OGRGeometry(geom)
|
||||
self.assertEqual(g.wkt, geom)
|
||||
self.assertEqual(g.wkb.hex(), wkb)
|
||||
|
|
Loading…
Reference in New Issue