Skip to content

Commit

Permalink
Merge pull request #127 from PDOK/bump-gdal
Browse files Browse the repository at this point in the history
bump gdal
  • Loading branch information
botenvouwer authored Jul 18, 2024
2 parents 7fe3071 + 2cc04be commit aa5afc9
Show file tree
Hide file tree
Showing 7 changed files with 65 additions and 37 deletions.
16 changes: 12 additions & 4 deletions .github/workflows/pytest.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,22 +9,30 @@ jobs:
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-22.04, ubuntu-20.04] # no ubuntugis @ ubuntu-24.04
os: [ubuntu-24.04, ubuntu-22.04, ubuntu-20.04] # no ubuntugis @ ubuntu-24.04
python-version: ['3.11', '3.10', '3.9', '3.8', '3.7'] # , '3.6'] <- 3.6 needs setup.cfg
gdal-version: ['3.4', '3.6'] # TODO: gdal 3.6 is still unstable.
gdal-version: ['3.8', '3.6', '3.4']
exclude:
- os: ubuntu-24.04
python-version: '3.8'
python-version: '3.9'
- os: ubuntu-24.04
python-version: '3.7'
- os: ubuntu-24.04
python-version: '3.7'
- os: ubuntu-24.04
gdal-version: '3.6'
- os: ubuntu-24.04
gdal-version: '3.4'
- os: ubuntu-22.04
gdal-version: '3.4'
- os: ubuntu-22.04
gdal-version: '3.8'
- os: ubuntu-20.04
python-version: '3.11'
- os: ubuntu-20.04
gdal-version: '3.6'
- os: ubuntu-20.04
gdal-version: '3.8'
steps:
- name: Checkout 🛎️
uses: actions/checkout@v3
Expand All @@ -43,7 +51,7 @@ jobs:
echo adding ubuntugis stable
sudo apt-add-repository ppa:ubuntugis/ppa
fi
sudo apt-get update
sudo apt-get update || true # ignore erros becouse we can not install gdal from `ppa:ubuntugis/ppa` without apt errors
echo available python3-gdal versions: $(apt-cache madison python3-gdal | cut -f2 -d "|" | tr -d " ")
echo available libgdal-dev versions: $(apt-cache madison libgdal-dev | cut -f2 -d "|" | tr -d " ")
export APT_GDAL_VERSION=$(apt-cache madison python3-gdal | grep ${{ matrix.gdal-version }} | head -n1 | cut -f2 -d "|" | tr -d " ")
Expand Down
4 changes: 2 additions & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
ARG GDAL_VERSION=3.6.2
ARG GDAL_VERSION=3.9.1

FROM osgeo/gdal:alpine-normal-${GDAL_VERSION} AS base
FROM ghcr.io/osgeo/gdal:alpine-normal-${GDAL_VERSION} AS base

LABEL maintainer="Roel van den Berg <[email protected]>"

Expand Down
10 changes: 7 additions & 3 deletions geopackage_validator/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,8 @@

from pathlib import Path
import json
import yaml

from typing import Callable, Optional
import yaml

try:
from osgeo import ogr, osr, gdal
Expand Down Expand Up @@ -57,7 +56,12 @@ def silence_gdal():
gdal.PushErrorHandler(error_handler)

driver = ogr.GetDriverByName("GPKG")
dataset = driver.Open(filename, 0)

dataset = None
try:
dataset = driver.Open(filename, 0)
except Exception as e:
error_handler(gdal.CE_Failure, 0, e.args[0])

if dataset is not None:
dataset.silence_gdal = silence_gdal
Expand Down
40 changes: 22 additions & 18 deletions geopackage_validator/validate.py
Original file line number Diff line number Diff line change
Expand Up @@ -77,29 +77,32 @@ def validators_to_use(
return [validator_dict[code] for code in codes]


class GdalErrorHandler(object):
def __init__(self):
self.gdal_error_traces = []
self.gdal_warning_traces = []

def handler(self, err_level, err_no, err_msg):
trace = err_msg.replace("\n", " ")
if err_level == gdal.CE_Warning:
self.gdal_warning_traces.append(trace)
else:
self.gdal_error_traces.append(trace)


def validate(
gpkg_path, table_definitions_path=None, validations_path=None, validations=""
):
"""Starts the geopackage validations."""
utils.check_gdal_version()

gdal_error_traces = []
gdal_warning_traces = []

# Register GDAL error handler function
def gdal_error_handler(err_class, err_num, error):
trace = error.replace("\n", " ")
# import pdb
# pdb.set_trace()
if err_class == gdal.CE_Warning:
gdal_warning_traces.append(trace)
else:
gdal_error_traces.append(trace)
errHandler = GdalErrorHandler()
dataset = utils.open_dataset(gpkg_path, errHandler.handler)

dataset = utils.open_dataset(gpkg_path, gdal_error_handler)
if len(gdal_error_traces):
if len(errHandler.gdal_error_traces):
initial_gdal_traces = [
gdal_error_traces.pop() for _ in range(len(gdal_error_traces))
errHandler.gdal_error_traces.pop()
for _ in range(len(errHandler.gdal_error_traces))
]
initial_gdal_errors = [
format_result(
Expand Down Expand Up @@ -163,7 +166,8 @@ def gdal_error_handler(err_class, err_num, error):
validation_error = True
success = False
current_gdal_error_traces = [
gdal_error_traces.pop() for _ in range(len(gdal_error_traces))
errHandler.gdal_error_traces.pop()
for _ in range(len(errHandler.gdal_error_traces))
]
if current_gdal_error_traces:
success = False
Expand All @@ -178,12 +182,12 @@ def gdal_error_handler(err_class, err_num, error):
)
validation_results.append(output)

if gdal_warning_traces:
if errHandler.gdal_warning_traces:
output = format_result(
validation_code="UNKNOWN_WARNINGS",
validation_description="It is recommended that these unexpected (GDAL) warnings are looked into.",
level=ValidationLevel.UNKNOWN_WARNING,
trace=gdal_warning_traces,
trace=errHandler.gdal_warning_traces,
)
validation_results.append(output)

Expand Down
5 changes: 3 additions & 2 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -10,17 +10,18 @@ license = {text = "MIT"}
classifiers = [
"Programming Language :: Python :: 3",
"Programming Language :: Python :: 3 :: Only",
"Programming Language :: Python :: 3.6",
"Programming Language :: Python :: 3.7",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
]
dynamic = ["version", "readme"]
dependencies = [
"setuptools>=42.0,!=58.*,!=59.*,!=60.*,!=61.*",
"Click >= 8.0",
"click-log >=0.3",
"gdal >=3.0.4",
"gdal >=3.4",
"minio",
"pyyaml",
]
Expand Down
25 changes: 17 additions & 8 deletions tests/test_utils.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
from osgeo import gdal

from geopackage_validator.utils import (
open_dataset,
dataset_geometry_tables,
Expand All @@ -24,9 +26,15 @@ def gdal_error_handler(err_class, err_num, error):
results.append("GDAL_ERROR")

dataset = open_dataset("tests/data/test_gdal_error.gpkg", gdal_error_handler)
validations = dataset.ExecuteSQL('select rtreecheck("rtree_table_geom");')
dataset.ReleaseResultSet(validations)
assert results[0] == "GDAL_ERROR"

# Since GDAL 3.7 the exceptions work more pythonic
try:
validations = dataset.ExecuteSQL('select rtreecheck("rtree_table_geom");')
dataset.ReleaseResultSet(validations)
except RuntimeError as e:
results.append("GDAL_TRY_ERROR")

assert results[0] == "GDAL_ERROR" or results[0] == "GDAL_TRY_ERROR"
assert len(results) == 1


Expand All @@ -39,20 +47,20 @@ def gdal_error_handler(err_class, err_num, error):

dataset = open_dataset("tests/data/test_gdal_error.gpkg", gdal_error_handler)
with dataset.silence_gdal():
validations = dataset.ExecuteSQL('select rtreecheck("rtree_table_geom");')
validations = dataset.ExecuteSQL(
'select rtreecheck("rtree_cbs_arbeidsmarktregio_2014_gegeneraliseerd_geom_parent");'
)
dataset.ReleaseResultSet(validations)
assert len(results) == 0


def do_something_with_error_gdal(dataset):
validations = dataset.ExecuteSQL('select rtreecheck("rtree_table_geom");')
dataset.ReleaseResultSet(validations)
gdal.Error(gdal.CE_Warning, 9999, "test warning message")


def do_something_silenced_gdal(dataset):
with dataset.silence_gdal():
validations = dataset.ExecuteSQL('select rtreecheck("rtree_table_geom");')
dataset.ReleaseResultSet(validations)
gdal.Error(gdal.CE_Warning, 9999, "test warning message")


def test_silence_between_gdal_errors():
Expand All @@ -64,6 +72,7 @@ def gdal_error_handler(err_class, err_num, error):
results.append("GDAL_ERROR")

dataset = open_dataset("tests/data/test_gdal_error.gpkg", gdal_error_handler)

do_something_with_error_gdal(dataset)
do_something_silenced_gdal(dataset)
do_something_with_error_gdal(dataset)
Expand Down
2 changes: 2 additions & 0 deletions tests/test_validate.py
Original file line number Diff line number Diff line change
Expand Up @@ -111,9 +111,11 @@ def test_validate_all_validations_no_error():


def test_validate_all_validations_with_broken_gpkg_throws_gdal_error():

results, validations_executed, success = validate(
gpkg_path="tests/data/test_broken_geopackage.gpkg", validations="ALL"
)

assert len(results) == 1
print(results)
assert results[0]["locations"] == [
Expand Down

0 comments on commit aa5afc9

Please sign in to comment.