Skip to content

Commit

Permalink
230 filter osm input (#232)
Browse files Browse the repository at this point in the history
* fix: Func handles string by casting to pathlib.Path

* test: Func copes with single output of globstring
  • Loading branch information
r-leyshon authored Jan 18, 2024
1 parent aa98494 commit 0429df3
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 0 deletions.
3 changes: 3 additions & 0 deletions src/transport_performance/osm/osm_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,9 @@ def filter_osm(
"""
# defence
_type_defence(pbf_pth, "pbf_pth", (pathlib.Path, str))
# if pbf_pth is str, convert to Path in order to access as_posix method
pbf_pth = pathlib.Path(pbf_pth)
_is_expected_filetype(pbf_pth, param_nm="pbf_pth", exp_ext=".pbf")
_enforce_file_extension(out_pth, ".pbf", ".pbf", "out_pth")
for nm, val in {
Expand Down
21 changes: 21 additions & 0 deletions tests/osm/test_osm_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@
import os
from unittest.mock import patch, call
import re
import glob

from pyprojroot import here

from transport_performance.osm.osm_utils import filter_osm

Expand Down Expand Up @@ -118,3 +121,21 @@ def test_filter_osm_with_osmosis(self, mock_print, tmpdir):
.startswith("call('Filter completed. Written to ")
)
assert out is None

@pytest.mark.runinteg
@patch("builtins.print")
def test_filter_osm_takes_globstring(self, mock_print, tmpdir):
"""Assert filter operation executes when user passes a globstring."""
found_pbf = sorted(glob.glob(str(here("tests/data/*.pbf"))))[0]
target_pth = os.path.join(tmpdir, "test_globstring_input.osm.pbf")
filter_osm(
pbf_pth=found_pbf, out_pth=target_pth, install_osmosis=False
)
# check the file exists
assert os.path.exists(
target_pth
), f"Filtered pbf file not found: {target_pth}"
func_out = mock_print.mock_calls
assert (
func_out[-1].__str__().endswith("test_globstring_input.osm.pbf')")
)

0 comments on commit 0429df3

Please sign in to comment.