278 строки
8.1 KiB
Python
Исполняемый файл
278 строки
8.1 KiB
Python
Исполняемый файл
#!/usr/bin/env pytest
|
|
###############################################################################
|
|
# $Id$
|
|
#
|
|
# Project: GDAL/OGR Test Suite
|
|
# Purpose: Test gdal_polygonize.py script
|
|
# Author: Frank Warmerdam <warmerdam@pobox.com>
|
|
#
|
|
###############################################################################
|
|
# Copyright (c) 2008, Frank Warmerdam <warmerdam@pobox.com>
|
|
# Copyright (c) 2010, Even Rouault <even dot rouault at spatialys.com>
|
|
#
|
|
# Permission is hereby granted, free of charge, to any person obtaining a
|
|
# copy of this software and associated documentation files (the "Software"),
|
|
# to deal in the Software without restriction, including without limitation
|
|
# the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
# and/or sell copies of the Software, and to permit persons to whom the
|
|
# Software is furnished to do so, subject to the following conditions:
|
|
#
|
|
# The above copyright notice and this permission notice shall be included
|
|
# in all copies or substantial portions of the Software.
|
|
#
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
# DEALINGS IN THE SOFTWARE.
|
|
###############################################################################
|
|
|
|
import os
|
|
|
|
import ogrtest
|
|
import pytest
|
|
import test_py_scripts
|
|
|
|
from osgeo import gdal, ogr
|
|
|
|
pytestmark = pytest.mark.skipif(
|
|
test_py_scripts.get_py_script("gdal_polygonize") is None,
|
|
reason="gdal_polygonize not available",
|
|
)
|
|
|
|
|
|
@pytest.fixture()
|
|
def script_path():
|
|
return test_py_scripts.get_py_script("gdal_polygonize")
|
|
|
|
|
|
###############################################################################
|
|
# Test a fairly simple case, with nodata masking.
|
|
|
|
|
|
@pytest.mark.require_driver("AAIGRID")
|
|
def test_gdal_polygonize_1(script_path):
|
|
|
|
outfilename = "tmp/poly.shp"
|
|
# Create a OGR datasource to put results in.
|
|
shp_drv = ogr.GetDriverByName("ESRI Shapefile")
|
|
if os.path.exists(outfilename):
|
|
shp_drv.DeleteDataSource(outfilename)
|
|
|
|
shp_ds = shp_drv.CreateDataSource(outfilename)
|
|
|
|
shp_layer = shp_ds.CreateLayer("poly", None, ogr.wkbPolygon)
|
|
|
|
fd = ogr.FieldDefn("DN", ogr.OFTInteger)
|
|
shp_layer.CreateField(fd)
|
|
|
|
shp_ds.Destroy()
|
|
|
|
# run the algorithm.
|
|
test_py_scripts.run_py_script(
|
|
script_path,
|
|
"gdal_polygonize",
|
|
test_py_scripts.get_data_path("alg") + "polygonize_in.grd tmp poly DN",
|
|
)
|
|
|
|
# Confirm we get the set of expected features in the output layer.
|
|
|
|
shp_ds = ogr.Open("tmp")
|
|
shp_lyr = shp_ds.GetLayerByName("poly")
|
|
|
|
expected_feature_number = 13
|
|
assert shp_lyr.GetFeatureCount() == expected_feature_number
|
|
|
|
expect = [107, 123, 115, 115, 140, 148, 123, 140, 100, 101, 102, 156, 103]
|
|
|
|
tr = ogrtest.check_features_against_list(shp_lyr, "DN", expect)
|
|
|
|
# check at least one geometry.
|
|
if tr:
|
|
shp_lyr.SetAttributeFilter("dn = 156")
|
|
feat_read = shp_lyr.GetNextFeature()
|
|
if (
|
|
ogrtest.check_feature_geometry(
|
|
feat_read,
|
|
"POLYGON ((440720 3751200,440900 3751200,440900 3751020,440720 3751020,440720 3751200),(440780 3751140,440780 3751080,440840 3751080,440840 3751140,440780 3751140))",
|
|
)
|
|
!= 0
|
|
):
|
|
tr = 0
|
|
feat_read.Destroy()
|
|
|
|
shp_ds.Destroy()
|
|
# Reload drv because of side effects of run_py_script()
|
|
shp_drv = ogr.GetDriverByName("ESRI Shapefile")
|
|
shp_drv.DeleteDataSource(outfilename)
|
|
|
|
assert tr
|
|
|
|
|
|
###############################################################################
|
|
# Test a simple case without masking.
|
|
|
|
|
|
@pytest.mark.require_driver("AAIGRID")
|
|
def test_gdal_polygonize_2(script_path):
|
|
|
|
outfilename = "tmp/out.geojson"
|
|
if gdal.VSIStatL(outfilename) is not None:
|
|
gdal.Unlink(outfilename)
|
|
|
|
# run the algorithm.
|
|
test_py_scripts.run_py_script(
|
|
script_path,
|
|
"gdal_polygonize",
|
|
"-b 1 -q -nomask "
|
|
+ test_py_scripts.get_data_path("alg")
|
|
+ "polygonize_in.grd "
|
|
+ outfilename,
|
|
)
|
|
|
|
# Confirm we get the set of expected features in the output layer.
|
|
ds = gdal.OpenEx(outfilename)
|
|
assert ds.GetDriver().ShortName == "GeoJSON"
|
|
lyr = ds.GetLayerByName("out")
|
|
|
|
expected_feature_number = 17
|
|
assert lyr.GetFeatureCount() == expected_feature_number
|
|
|
|
expect = [
|
|
107,
|
|
123,
|
|
115,
|
|
132,
|
|
115,
|
|
140,
|
|
132,
|
|
132,
|
|
148,
|
|
123,
|
|
140,
|
|
132,
|
|
100,
|
|
101,
|
|
102,
|
|
156,
|
|
103,
|
|
]
|
|
|
|
tr = ogrtest.check_features_against_list(lyr, "DN", expect)
|
|
|
|
ds = None
|
|
|
|
gdal.Unlink(outfilename)
|
|
|
|
assert tr
|
|
|
|
|
|
@pytest.mark.require_driver("GPKG")
|
|
def test_gdal_polygonize_3(script_path):
|
|
|
|
drv = ogr.GetDriverByName("GPKG")
|
|
outfilename = "tmp/out.gpkg"
|
|
if os.path.exists(outfilename):
|
|
drv.DeleteDataSource(outfilename)
|
|
|
|
# run the algorithm.
|
|
test_py_scripts.run_py_script(
|
|
script_path,
|
|
"gdal_polygonize",
|
|
'-b 1 -f "GPKG" -q -nomask -lco FID=myfid '
|
|
+ test_py_scripts.get_data_path("alg")
|
|
+ "polygonize_in.grd "
|
|
+ outfilename,
|
|
)
|
|
|
|
# Confirm we get the set of expected features in the output layer.
|
|
gpkg_ds = ogr.Open(outfilename)
|
|
gpkg_lyr = gpkg_ds.GetLayerByName("out")
|
|
assert gpkg_lyr.GetFIDColumn() == "myfid"
|
|
geom_type = gpkg_lyr.GetGeomType()
|
|
geom_is_polygon = geom_type in (ogr.wkbPolygon, ogr.wkbMultiPolygon)
|
|
|
|
gpkg_ds.Destroy()
|
|
# Reload drv because of side effects of run_py_script()
|
|
drv = ogr.GetDriverByName("GPKG")
|
|
drv.DeleteDataSource(outfilename)
|
|
|
|
if geom_is_polygon:
|
|
return
|
|
pytest.fail(
|
|
"GetGeomType() returned %d instead of %d or %d (ogr.wkbPolygon or ogr.wkbMultiPolygon)"
|
|
% (geom_type, ogr.wkbPolygon, ogr.wkbMultiPolygon)
|
|
)
|
|
|
|
|
|
###############################################################################
|
|
# Test -b mask
|
|
|
|
|
|
@pytest.mark.require_driver("GML")
|
|
def test_gdal_polygonize_4(script_path):
|
|
|
|
outfilename = "tmp/out.gml"
|
|
# Test mask syntax
|
|
test_py_scripts.run_py_script(
|
|
script_path,
|
|
"gdal_polygonize",
|
|
"-q -f GML -b mask "
|
|
+ test_py_scripts.get_data_path("gcore")
|
|
+ "byte.tif "
|
|
+ outfilename,
|
|
)
|
|
|
|
content = open(outfilename, "rt").read()
|
|
|
|
os.unlink(outfilename)
|
|
os.unlink(outfilename[0:-3] + "xsd")
|
|
|
|
assert (
|
|
'<gml:Polygon srsName="urn:ogc:def:crs:EPSG::26711" gml:id="out.geom.0"><gml:exterior><gml:LinearRing><gml:posList>440720 3751320 440720 3750120 441920 3750120 441920 3751320 440720 3751320</gml:posList></gml:LinearRing></gml:exterior></gml:Polygon>'
|
|
in content
|
|
)
|
|
|
|
# Test mask,1 syntax
|
|
test_py_scripts.run_py_script(
|
|
script_path,
|
|
"gdal_polygonize",
|
|
"-q -f GML -b mask,1 "
|
|
+ test_py_scripts.get_data_path("gcore")
|
|
+ "byte.tif "
|
|
+ outfilename,
|
|
)
|
|
|
|
content = open(outfilename, "rt").read()
|
|
|
|
os.unlink(outfilename)
|
|
os.unlink(outfilename[0:-3] + "xsd")
|
|
|
|
assert (
|
|
'<gml:Polygon srsName="urn:ogc:def:crs:EPSG::26711" gml:id="out.geom.0"><gml:exterior><gml:LinearRing><gml:posList>440720 3751320 440720 3750120 441920 3750120 441920 3751320 440720 3751320</gml:posList></gml:LinearRing></gml:exterior></gml:Polygon>'
|
|
in content
|
|
)
|
|
|
|
|
|
###############################################################################
|
|
# Test -8
|
|
|
|
|
|
def test_gdal_polygonize_minus_8(script_path):
|
|
|
|
outfilename = "tmp/out.geojson"
|
|
test_py_scripts.run_py_script(
|
|
script_path,
|
|
"gdal_polygonize",
|
|
"-q -8 " + test_py_scripts.get_data_path("gcore") + "byte.tif " + outfilename,
|
|
)
|
|
|
|
ds = gdal.OpenEx(outfilename)
|
|
lyr = ds.GetLayer(0)
|
|
assert lyr.GetFeatureCount() == 229
|
|
ds = None
|
|
|
|
os.unlink(outfilename)
|