rene 0.2.0

Computational geometry.
Documentation
from collections.abc import Sequence

from hypothesis import given

from rene.exact import Segment
from tests.utils import equivalence

from . import strategies


@given(strategies.multisegments_segments, strategies.segments)
def test_basic(segments: Sequence[Segment], segment: Segment) -> None:
    result = segments.count(segment)

    assert isinstance(result, int)
    assert result in range(len(segments))
    assert equivalence(result == 0, segment not in segments)


@given(strategies.multisegments_segments, strategies.segments)
def test_alternatives(segments: Sequence[Segment], segment: Segment) -> None:
    result = segments.count(segment)

    assert result == list(segments).count(segment)
    assert result == tuple(segments).count(segment)