File: test_819_menger_sponge.py

package info (click to toggle)
ezdxf 1.4.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 104,528 kB
  • sloc: python: 182,341; makefile: 116; lisp: 20; ansic: 4
file content (42 lines) | stat: -rw-r--r-- 961 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#  Copyright (c) 2022, Manfred Moitzi
#  License: MIT License

import pytest

from ezdxf.addons import MengerSponge


@pytest.fixture(scope="module")
def mesh():
    return MengerSponge().mesh()


def test_euler_characteristic_for_menger_sponge(mesh):
    """The euler characteristic does not work for non-convex meshes."""
    diag = mesh.diagnose()
    assert diag.euler_characteristic == -8


def test_edge_balance_for_menger_sponge(mesh):
    """ The is_edge_balance_broken property is not reliable for concave meshes
    each edge connects two faces
    """
    diag = mesh.diagnose()
    assert diag.is_edge_balance_broken is False


def test_menger_sponge_is_non_manifold(mesh):
    diag = mesh.diagnose()
    assert diag.is_manifold is True


def test_menger_sponge_face_count(mesh):
    assert len(mesh.faces) == 72


def test_menger_sponge_edge_count(mesh):
    assert len(mesh.vertices) == 64


if __name__ == '__main__':
    pytest.main([__file__])