From 9dd6ddad97f12de7a72947a0749f9ec749dd2059 Mon Sep 17 00:00:00 2001 From: Sylvain Laperche Date: Sat, 11 May 2024 10:57:05 +0200 Subject: [PATCH] tests: add test case from Python bug report Cf. https://github.com/uber/h3-py/issues/343 --- tests/api/geom/to_cells.rs | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/tests/api/geom/to_cells.rs b/tests/api/geom/to_cells.rs index ec5e60f..942fe3f 100644 --- a/tests/api/geom/to_cells.rs +++ b/tests/api/geom/to_cells.rs @@ -453,6 +453,34 @@ fn bug_h3_java_138() { assert_eq!(count, 14_697); } +// https://github.com/uber/h3-py/issues/343 +#[test] +fn bug_h3_python_343() { + let poly = polygon![ + (x:-141.001, y:61.895), + (x:-140.996, y:61.895), + (x:-140.996, y:64.848), + (x:-141.001, y:64.848) + ]; + let shape = Polygon::from_degrees(poly).unwrap(); + let config = PolyfillConfig::new(Resolution::Nine) + .containment_mode(ContainmentMode::ContainsCentroid); + let count = shape.to_cells(config).count(); + assert_eq!(count, 896); + + let poly = polygon![ + (x:-141.001, y:61.895), + (x:-140.996, y:61.895), + (x:-140.996, y:65.848), + (x:-141.001, y:65.848) + ]; + let shape = Polygon::from_degrees(poly).unwrap(); + let config = PolyfillConfig::new(Resolution::Nine) + .containment_mode(ContainmentMode::ContainsCentroid); + let count = shape.to_cells(config).count(); + assert_eq!(count, 1167); +} + macro_rules! cell { ($x: expr) => {{ CellIndex::try_from($x).expect("valid cell")