mirror of
https://github.com/enzet/map-machine.git
synced 2025-06-06 04:41:54 +02:00
Issue #128: add test.
This commit is contained in:
parent
7a56d0df87
commit
8dbc03c973
1 changed files with 23 additions and 4 deletions
|
@ -16,6 +16,10 @@ from tests import SCHEME, SHAPE_EXTRACTOR
|
|||
|
||||
|
||||
def get_constructor(osm_data: OSMData) -> Constructor:
|
||||
"""
|
||||
Get custom constructor for bounds (-0.01, -0.01, 0.01, 0.01) and zoom level
|
||||
18.
|
||||
"""
|
||||
flinger: Flinger = Flinger(
|
||||
BoundaryBox(-0.01, -0.01, 0.01, 0.01), 18, osm_data.equator_length
|
||||
)
|
||||
|
@ -26,13 +30,15 @@ def get_constructor(osm_data: OSMData) -> Constructor:
|
|||
return constructor
|
||||
|
||||
|
||||
def create_way(tags: Tags, index: int) -> OSMWay:
|
||||
def create_way(osm_data: OSMData, tags: Tags, index: int) -> None:
|
||||
"""Create simple OSM way with two arbitrary nodes."""
|
||||
nodes: list[OSMNode] = [
|
||||
OSMNode({}, 1, np.array((-0.01, -0.01))),
|
||||
OSMNode({}, 2, np.array((0.01, 0.01))),
|
||||
]
|
||||
return OSMWay(tags, index, nodes)
|
||||
for node in nodes:
|
||||
osm_data.add_node(node)
|
||||
osm_data.add_way(OSMWay(tags, index, nodes))
|
||||
|
||||
|
||||
def test_river_and_wood() -> None:
|
||||
|
@ -42,8 +48,8 @@ def test_river_and_wood() -> None:
|
|||
See https://github.com/enzet/map-machine/issues/126
|
||||
"""
|
||||
osm_data: OSMData = OSMData()
|
||||
osm_data.add_way(create_way({"natural": "wood"}, 1))
|
||||
osm_data.add_way(create_way({"waterway": "river"}, 2))
|
||||
create_way(osm_data, {"natural": "wood"}, 1)
|
||||
create_way(osm_data, {"waterway": "river"}, 2)
|
||||
|
||||
figures: list[Figure] = get_constructor(osm_data).get_sorted_figures()
|
||||
|
||||
|
@ -52,6 +58,19 @@ def test_river_and_wood() -> None:
|
|||
assert figures[1].tags["waterway"] == "river"
|
||||
|
||||
|
||||
def test_placement_and_lanes() -> None:
|
||||
"""
|
||||
Check that `placement` tag is processed correctly when `lanes` tag is not
|
||||
specified.
|
||||
|
||||
See https://github.com/enzet/map-machine/issues/128
|
||||
"""
|
||||
osm_data: OSMData = OSMData()
|
||||
create_way(osm_data, {"highway": "motorway", "placement": "right_of:2"}, 1)
|
||||
|
||||
get_constructor(osm_data)
|
||||
|
||||
|
||||
def test_empty_ways() -> None:
|
||||
"""Ways without nodes."""
|
||||
osm_data: OSMData = OSMData()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue