<div dir="auto">Is it worth moving this in-depth discussion to a PR or similar for the new driver?<div dir="auto"><br></div><div dir="auto">My thinking is that a lengthy discussion on memory leak detection techniques in C++, how to run tests in Python, etc., aren't topics relevant to most GDAL mailing list subscribers.</div><div dir="auto"><br></div><div dir="auto">Cheers,</div><div dir="auto">Daniel</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, 6 Mar 2024, 16:54 Abel Pau via gdal-dev, <<a href="mailto:gdal-dev@lists.osgeo.org">gdal-dev@lists.osgeo.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">





<div lang="CA" link="#0563C1" vlink="#954F72">
<div class="m_-4624143798828506323WordSection1">
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">I was using ubuntu 20.04 and it doesn’t work there.<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Trying to install 22.04 but I have some issues (again).<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"><u></u> <u></u></span></p>
<div>
<div style="border:none;border-top:solid #e1e1e1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="ES">De:</span></b><span lang="ES"> Even Rouault <<a href="mailto:even.rouault@spatialys.com" target="_blank" rel="noreferrer">even.rouault@spatialys.com</a>>
<br>
<b>Enviado el:</b> dimecres, 6 de març de 2024 17:12<br>
<b>Para:</b> Abel Pau <<a href="mailto:a.pau@creaf.uab.cat" target="_blank" rel="noreferrer">a.pau@creaf.uab.cat</a>>; <a href="mailto:gdal-dev@lists.osgeo.org" target="_blank" rel="noreferrer">gdal-dev@lists.osgeo.org</a><br>
<b>Asunto:</b> Re: [gdal-dev] Testing the driver<u></u><u></u></span></p>
</div>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
<p>PYTHONMALLOC=malloc gdb --args python3 -m pytest <span lang="EN-US" style="color:#1f497d">
autotest/ogr/ogr_miramon_vector.py</span><u></u><u></u></p>
<p>PYTHONMALLOC=malloc valgrind python3 -m pytest <span lang="EN-US" style="color:#1f497d">
autotest/ogr/ogr_miramon_vector.py</span><u></u><u></u></p>
<div>
<p class="MsoNormal">Le 06/03/2024 à 16:02, Abel Pau via gdal-dev a écrit :<u></u><u></u></p>
</div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Hi again,</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">anyone have any advice for debuging into python code?<br>
I am using Pdb but it’s a little confusing.</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Any experience?</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Thanks</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">apau@ABEL2:/mnt/d/GitHub-repository/gdal/build$ pytest autotest/ogr/ogr_miramon_vector.py</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Test session starts (platform: linux, Python 3.8.10, pytest 8.0.2, pytest-sugar 1.0.0)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">benchmark: 4.0.0 (defaults: timer=time.perf_counter disable_gc=False min_rounds=5 min_time=0.000005 max_time=1.0 calibration_precision=10 warmup=False warmup_iterations=100000)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">GDAL Build Info:</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  PAM_ENABLED: YES</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  OGR_ENABLED: YES</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  CURL_ENABLED: YES</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  CURL_VERSION: 7.68.0</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  GEOS_ENABLED: YES</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  GEOS_VERSION: 3.8.0-CAPI-1.13.1</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  PROJ_BUILD_VERSION: 6.3.1</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  PROJ_RUNTIME_VERSION: 6.3.1</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  COMPILER: GCC 9.4.0</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">GDAL_DOWNLOAD_TEST_DATA: undefined (tests relying on downloaded data may be skipped)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">GDAL_RUN_SLOW_TESTS: undefined (tests marked as "slow" will be skipped)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">rootdir: /mnt/d/GitHub-repository/gdal/build/autotest</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">configfile: pytest.ini</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">plugins: benchmark-4.0.0, sugar-1.0.0, env-1.1.3</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">collected 3 items</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">ogr/ogr_miramon_vector.py
</span><span lang="EN-US" style="font-family:"Segoe UI Symbol",sans-serif;color:#1f497d">✓✓</span><span lang="EN-US" style="color:#1f497d">                                                                                                                                                                                                  67%</span><span lang="EN-US" style="font-family:"Arial",sans-serif;color:#1f497d">██████</span><span lang="EN-US" style="font-family:"MS Gothic";color:#1f497d">▋</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> PDB set_trace (IO-capturing turned off) >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>></span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">> /mnt/d/GitHub-repository/gdal/build/autotest/ogr/ogr_miramon_vector.py(132)test_ogr_miramon_simple_polygon()</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">-> f = lyr.GetNextFeature()</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">(Pdb) s</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">--Call--</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">> /mnt/d/GitHub-repository/gdal/build/swig/python/osgeo/ogr.py(1654)GetNextFeature()</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">-> def GetNextFeature(self, *args) -> "OGRFeatureShadow *":</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">(Pdb) s</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">> /mnt/d/GitHub-repository/gdal/build/swig/python/osgeo/ogr.py(1668)GetNextFeature()</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">-> return _ogr.Layer_GetNextFeature(self, *args)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">(Pdb) s</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">ERROR 2: CPLRealloc(): Out of memory allocating 667227037326010464 bytes.</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Fatal Python error: Aborted</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Current thread 0x00007f67c7140740 (most recent call first):</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/mnt/d/GitHub-repository/gdal/build/swig/python/osgeo/ogr.py", line 1668 in GetNextFeature</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/mnt/d/GitHub-repository/gdal/build/autotest/ogr/ogr_miramon_vector.py", line 132 in test_ogr_miramon_simple_polygon</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/python.py", line 194 in pytest_pyfunc_call</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_callers.py", line 102 in _multicall</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_manager.py", line 119 in _hookexec</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_hooks.py", line 501 in __call__</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/python.py", line 1831 in runtest</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/runner.py", line 170 in pytest_runtest_call</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_callers.py", line 102 in _multicall</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_manager.py", line 119 in _hookexec</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_hooks.py", line 501 in __call__</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/runner.py", line 263 in <lambda></span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/runner.py", line 342 in from_call</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/runner.py", line 262 in call_runtest_hook</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/runner.py", line 223 in call_and_report</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/runner.py", line 134 in runtestprotocol</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/runner.py", line 115 in pytest_runtest_protocol</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_callers.py", line 102 in _multicall</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_manager.py", line 119 in _hookexec</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_hooks.py", line 501 in __call__</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/main.py", line 352 in pytest_runtestloop</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_callers.py", line 102 in _multicall</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_manager.py", line 119 in _hookexec</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_hooks.py", line 501 in __call__</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/main.py", line 327 in _main</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/main.py", line 273 in wrap_session</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/main.py", line 320 in pytest_cmdline_main</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_callers.py", line 102 in _multicall</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_manager.py", line 119 in _hookexec</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/pluggy/_hooks.py", line 501 in __call__</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/config/__init__.py", line 175 in main</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/lib/python3.8/dist-packages/_pytest/config/__init__.py", line 198 in console_main</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  File "/usr/local/bin/pytest", line 8 in <module></span><u></u><u></u></p>
<p class="MsoNormal"><span lang="ES" style="color:#1f497d">Aborted</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="ES" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="ES" style="color:#1f497d"> </span><u></u><u></u></p>
<div>
<div style="border:none;border-top:solid #e1e1e1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="ES">De:</span></b><span lang="ES"> gdal-dev
<a href="mailto:gdal-dev-bounces@lists.osgeo.org" target="_blank" rel="noreferrer"><gdal-dev-bounces@lists.osgeo.org></a>
<b>En nombre de </b>Abel Pau via gdal-dev<br>
<b>Enviado el:</b> dimecres, 6 de març de 2024 15:08<br>
<b>Para:</b> Even Rouault <a href="mailto:even.rouault@spatialys.com" target="_blank" rel="noreferrer"><even.rouault@spatialys.com></a>;
<a href="mailto:gdal-dev@lists.osgeo.org" target="_blank" rel="noreferrer">gdal-dev@lists.osgeo.org</a><br>
<b>Asunto:</b> Re: [gdal-dev] Testing the driver</span><u></u><u></u></p>
</div>
</div>
<p class="MsoNormal"> <u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">About the question:
</span>. Does <span lang="EN-US" style="color:#1f497d">"pytest autotest/ogr/ogr_basic_test.py" work?*</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">The answer is YES.</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">ogr/ogr_basic_test.py
</span><span lang="EN-US" style="font-family:"Segoe UI Symbol",sans-serif;color:#1f497d">✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓✓</span><span lang="EN-US" style="color:#1f497d">                                                                                                                                    
 100% </span><span lang="EN-US" style="font-family:"Arial",sans-serif;color:#1f497d">██████████</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Results (5.98s):</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">      66 passed</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<div>
<div style="border:none;border-top:solid #e1e1e1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="ES">De:</span></b><span lang="ES"> Even Rouault <<a href="mailto:even.rouault@spatialys.com" target="_blank" rel="noreferrer">even.rouault@spatialys.com</a>>
<br>
<b>Enviado el:</b> dimecres, 6 de març de 2024 13:09<br>
<b>Para:</b> Abel Pau <<a href="mailto:a.pau@creaf.uab.cat" target="_blank" rel="noreferrer">a.pau@creaf.uab.cat</a>>;
<a href="mailto:gdal-dev@lists.osgeo.org" target="_blank" rel="noreferrer">gdal-dev@lists.osgeo.org</a><br>
<b>Asunto:</b> Re: [gdal-dev] Testing the driver</span><u></u><u></u></p>
</div>
</div>
<p class="MsoNormal"> <u></u><u></u></p>
<p>Hi,<u></u><u></u></p>
<p>I don't see anything wrong. I've tried that on my native Linux build and the test_ogr_miramon_vector_1() is found. Does
<span lang="EN-US" style="color:#1f497d">"pytest autotest/ogr/ogr_basic_test.py" work?*</span><u></u><u></u></p>
<p><span lang="EN-US" style="color:#1f497d">Note: you don't need the try / except in your test case unless you'd need to some particular cleanup, but that's not the case here. pytest handles test failures nicely</span><u></u><u></u></p>
<p><span lang="EN-US" style="color:#1f497d">Even</span><u></u><u></u></p>
<div>
<p class="MsoNormal">Le 05/03/2024 à 22:28, Abel Pau via gdal-dev a écrit :<u></u><u></u></p>
</div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal"><span lang="ES" style="color:#1f497d">Hi again,</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">after solving some issues I used WSL (Windows subsystem Linux) to create an environment where I am able to run tests.</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">I run the cmake inside build folder in the environment. It’s slow but finally it finish. After cmake --build . --target install all is ready to be tested.</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">I create a simple test ogr_miramon_vector.py (see the code below) to prove that it’s reliable.</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">I run:</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">pytest autotest/ogr/ogr_miramon_vector.py</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">and:</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">apau@ABEL2:/mnt/d/GitHub-repository/gdal/build$ pytest autotest/ogr/ogr_miramon_vector.py</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Test session starts (platform: linux, Python 3.8.10, pytest 8.0.2, pytest-sugar 1.0.0)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">benchmark: 4.0.0 (defaults: timer=time.perf_counter disable_gc=False min_rounds=5 min_time=0.000005 max_time=1.0 calibration_precision=10 warmup=False warmup_iterations=100000)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">GDAL Build Info:</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  PAM_ENABLED: YES</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  OGR_ENABLED: YES</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  CURL_ENABLED: YES</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  CURL_VERSION: 7.68.0</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  GEOS_ENABLED: YES</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  GEOS_VERSION: 3.8.0-CAPI-1.13.1</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  PROJ_BUILD_VERSION: 6.3.1</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  PROJ_RUNTIME_VERSION: 6.3.1</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">  COMPILER: GCC 9.4.0</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">GDAL_DOWNLOAD_TEST_DATA: undefined (tests relying on downloaded data may be skipped)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">GDAL_RUN_SLOW_TESTS: undefined (tests marked as "slow" will be skipped)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">rootdir: /mnt/d/GitHub-repository/gdal/build/autotest</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">configfile: pytest.ini</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">plugins: benchmark-4.0.0, sugar-1.0.0, env-1.1.3</span><u></u><u></u></p>
<p class="MsoNormal"><b><span lang="EN-US" style="color:#1f497d">collected 0 items</span></b><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">My questions is why it seems it’s not working?</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">Thanks!</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">The test:</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">-------------</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">import os</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">import gdaltest</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">import ogrtest</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">import pytest</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">from osgeo import gdal, ogr, osr</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">pytestmark = pytest.mark.require_driver("MiraMonVector")</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">###############################################################################</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">@pytest.fixture(scope="module", autouse=True)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">def init():</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">    with gdaltest.config_option("CPL_DEBUG", "ON"):</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        yield</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">###############################################################################</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"># basic test </span>
<u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">def test_ogr_miramon_vector_1():</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">    try:</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        ds = gdal.OpenEx("data/miramon/Points/SimplePoints/SimplePointsFile.pnt")</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        lyr = ds.GetLayer(0)</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        assert lyr is not None, "Failed to get layer"</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        assert lyr.GetFeatureCount() == 3</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        assert lyr.GetGeomType() == ogr.wkbPoint</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        f = lyr.GetNextFeature()</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        assert f.GetFID() == 0</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        assert f.GetGeometryRef().ExportToWkt() == "POINT (513.49 848.81)"</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        assert f.GetField("ID_GRAFIC") == "0"</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        f = lyr.GetNextFeature()</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        assert f.GetField("ID_GRAFIC") == "1"</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        f = lyr.GetNextFeature()</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        assert f.GetField("ID_GRAFIC") == "2"</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        ds = None</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">    except Exception as e:</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d">        pytest.fail(f"Test failed with exception: {e}")</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1f497d"> </span><u></u><u></u></p>
<div>
<div style="border:none;border-top:solid #e1e1e1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="ES">De:</span></b><span lang="ES"> Even Rouault
<a href="mailto:even.rouault@spatialys.com" target="_blank" rel="noreferrer"><even.rouault@spatialys.com></a> <br>
<b>Enviado el:</b> divendres, 9 de febrer de 2024 11:48<br>
<b>Para:</b> Abel Pau <a href="mailto:a.pau@creaf.uab.cat" target="_blank" rel="noreferrer"><a.pau@creaf.uab.cat></a>;
<a href="mailto:gdal-dev@lists.osgeo.org" target="_blank" rel="noreferrer">gdal-dev@lists.osgeo.org</a><br>
<b>Asunto:</b> Re: [gdal-dev] Testing the driver</span><u></u><u></u></p>
</div>
</div>
<p class="MsoNormal"> <u></u><u></u></p>
<p>Abel,<u></u><u></u></p>
<div>
<p class="MsoNormal">Le 09/02/2024 à 10:55, Abel Pau via gdal-dev a écrit :<u></u><u></u></p>
</div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal"><span lang="EN-US">Hi,</span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US">I am at the lasts steps before pulling a request about the MiraMon driver.
<br>
I need to write some documentation and formalize the tests. </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US">After that, I’ll do the pull request to github.</span><u></u><u></u></p>
</blockquote>
<p class="MsoNormal" style="margin-bottom:12.0pt"><span style="font-size:12.0pt;font-family:"Times New Roman",serif">I'd suggest first before issuing the pull request that you push to your fork on github and look at the Actions tab.
 That will allow you to fix a lot of things on your side, before issuing the PR itself<br>
<br>
<br>
</span><u></u><u></u></p>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal"><span lang="EN-US"> </span><u></u><u></u></p>
<p class="MsoNormal"><span lang="EN-US">I am a little confused about the testing. I can use pytest or ctest, right? Which is the favourite? Are there any changes from the official documentation?</span><u></u><u></u></p>
</blockquote>
<p>ctest is just the CMake way of launching the test suite. It will execute C++ tests of autotest/cpp directly, and for tests written in python will launch "pytest autotest/XXXXX" for each directory. 
<u></u><u></u></p>
<p>"ctest --test-dir $build_dir -R autotest_ogr -V"  will just run all the autotest/ogr tests, which can be quite long already.<u></u><u></u></p>
<p>To test your own development, you may have a more pleasant experience by directly running just the tests for your driver with something like "pytest autotest/ogr/ogr_miramon.py"  (be careful on Windows, the content of $build_dir/autotest is copied from $source_dir/autotest
 each time "cmake" is run, so if you edit your test .py file directly in the build directory, be super careful of not accidentally losing your work, and make sure to copy its content to the source directory first. That's admittedly an annoying point of the
 current test setup on Windows, compared to Unix where we use symbolic links)<u></u><u></u></p>
<p>after setting the environment to have PYTHONPATH point to something like $build_dir/swig/python/Release or $build_dir/swig/python/Debug (I believe you're on Windows?).  If you look at the first lines output by the above "ctest --test-dir $build_dir -R autotest_ogr
 -V" invokation, you'll actually see the PYTHONPATH value to specify.<u></u><u></u></p>
<p>You also need to first install pytest and other testing dependencies with: python -m pip install autotest/requirements.txt<u></u><u></u></p>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal"><span lang="EN-US">There is a minimal test to create?</span><u></u><u></u></p>
</blockquote>
<p class="MsoNormal" style="margin-bottom:12.0pt"><span style="font-size:12.0pt;font-family:"Times New Roman",serif">A maximal test suite, you mean ;-) You should aim for a "reasonable" coverage of the code you wrote. Aiming to test
 the nominal code paths of your driver is desirable (testing the error cases generally requires a lot more effort). 
<br>
<br>
<br>
</span><u></u><u></u></p>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal"><span lang="EN-US">Can you recommend me some driver that tests things like:</span><u></u><u></u></p>
<p class="m_-4624143798828506323MsoListParagraph"><u></u><span>1.<span style="font:7.0pt "Times New Roman"">      
</span></span><u></u><span lang="EN-US">Read a point/arc/polygon layer from some format (gml,kml, gpckg,..) and assert the number of readed objectes</span><u></u><u></u></p>
<p class="m_-4624143798828506323MsoListParagraph"><u></u><span>2.<span style="font:7.0pt "Times New Roman"">      
</span></span><u></u><span lang="EN-US">Read a point layer and assert some points (3d included) and some of the fields values</span><u></u><u></u></p>
<p class="m_-4624143798828506323MsoListParagraph"><u></u><span>3.<span style="font:7.0pt "Times New Roman"">      
</span></span><u></u><span lang="EN-US">The same with arcs and polygons</span><u></u><u></u></p>
<p class="m_-4624143798828506323MsoListParagraph"><u></u><span>4.<span style="font:7.0pt "Times New Roman"">      
</span></span><u></u><span lang="EN-US">Create some layer from the own format to anothers and compare the results with some “good” results.</span><u></u><u></u></p>
<p class="m_-4624143798828506323MsoListParagraph"><u></u><span>5.<span style="font:7.0pt "Times New Roman"">      
</span></span><u></u><span lang="EN-US">Create multiple layers from one outer format (like gpx) and verify the name of the created files...</span><u></u><u></u></p>
</blockquote>
<p>You don't necessarily need to use other formats. It is actually better if the tests of a format don't depend too much on other formats, to keep things isolated.<u></u><u></u></p>
<p>To test the read part of your driver, add a autotest/ogr/data/miramon directory with *small* test files, ideally at most a few KB each to keep the size of the GDAL repository reasonable, and a few features in each is often enough to unit test, with different
 type of geometries, attributes, and use the OGR Python API to open the file and iterate over its layers and features to check their content. Those files should have ideally be produced by the Miramon software and not by the writing side of your driver, to
 check the interoperability of your driver with a "reference" software.<u></u><u></u></p>
<p>For the write site of the driver, you can for example run gdal.VectorTranslate(dest, source) on those files, and use again the test function to validate that the read side of your driver likes what the write site has produced. An alternative is also to do
 a binary comparison of the file generated by your driver with a reference test file stored in for example autotest/ogr/data/miramon/ref_output. But this may be sometimes a fragile approach if the output of your driver might change in the future (would require
 regenerating the reference test files).<u></u><u></u></p>
<p>I'd suggest your test suite also has a test that runs the "test_ogrsf" command line utility which is a kind of compliance test suite which checks a number of expectations for a driver, like that GetFeatureCount() returns the same number as iterating with
 GetNextFeature(), etc etc<u></u><u></u></p>
<p>It is difficult to point at a "reference" test suite, as all drivers have their particularities and may need specific tests. Potential sources of inspirations:<u></u><u></u></p>
<p>- autotest/ogr/ogr_gtfs.py  . Shows very simple testing of the read side of a driver, and includes a test_ogrsf test<u></u><u></u></p>
<p>- autotest/ogr/ogr_csv.py  has examples where the writing side of the driver is checked by opening the output file and checking that some strings are present in it (only easily doable with text based formats)<u></u><u></u></p>
<p>- autotest/ogr/ogr_openfilegdb_write.py . Extensive testing of the writing side of a driver . A lot in it will be specific to the format and irrelevant to your concern, but you should at least find all possible aspects of how to test the write side of a
 driver.<u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:12.0pt;font-family:"Times New Roman",serif">Even
</span><u></u><u></u></p>
<pre>-- <u></u><u></u></pre>
<pre><a href="http://www.spatialys.com" target="_blank" rel="noreferrer">http://www.spatialys.com</a><u></u><u></u></pre>
<pre>My software is free, but my time generally not.<u></u><u></u></pre>
<p class="MsoNormal" style="margin-bottom:12.0pt"><span style="font-size:12.0pt;font-family:"Times New Roman",serif"> </span><u></u><u></u></p>
<pre>_______________________________________________<u></u><u></u></pre>
<pre>gdal-dev mailing list<u></u><u></u></pre>
<pre><a href="mailto:gdal-dev@lists.osgeo.org" target="_blank" rel="noreferrer">gdal-dev@lists.osgeo.org</a><u></u><u></u></pre>
<pre><a href="https://lists.osgeo.org/mailman/listinfo/gdal-dev" target="_blank" rel="noreferrer">https://lists.osgeo.org/mailman/listinfo/gdal-dev</a><u></u><u></u></pre>
</blockquote>
<pre>-- <u></u><u></u></pre>
<pre><a href="http://www.spatialys.com" target="_blank" rel="noreferrer">http://www.spatialys.com</a><u></u><u></u></pre>
<pre>My software is free, but my time generally not.<u></u><u></u></pre>
<p class="MsoNormal"><span style="font-size:12.0pt;font-family:"Times New Roman",serif"><br>
<br>
<u></u><u></u></span></p>
<pre>_______________________________________________<u></u><u></u></pre>
<pre>gdal-dev mailing list<u></u><u></u></pre>
<pre><a href="mailto:gdal-dev@lists.osgeo.org" target="_blank" rel="noreferrer">gdal-dev@lists.osgeo.org</a><u></u><u></u></pre>
<pre><a href="https://lists.osgeo.org/mailman/listinfo/gdal-dev" target="_blank" rel="noreferrer">https://lists.osgeo.org/mailman/listinfo/gdal-dev</a><u></u><u></u></pre>
</blockquote>
<pre>-- <u></u><u></u></pre>
<pre><a href="http://www.spatialys.com" target="_blank" rel="noreferrer">http://www.spatialys.com</a><u></u><u></u></pre>
<pre>My software is free, but my time generally not.<u></u><u></u></pre>
</div>
</div>

_______________________________________________<br>
gdal-dev mailing list<br>
<a href="mailto:gdal-dev@lists.osgeo.org" target="_blank" rel="noreferrer">gdal-dev@lists.osgeo.org</a><br>
<a href="https://lists.osgeo.org/mailman/listinfo/gdal-dev" rel="noreferrer noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/gdal-dev</a><br>
</blockquote></div>