forked from SarahWeiii/CoACD
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrun_tests.py
44 lines (35 loc) · 1.5 KB
/
run_tests.py
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
43
44
import trimesh
import os
import glob
import coacd
import numpy
import unittest
class TestExamples(unittest.TestCase):
@staticmethod
def single(input_file):
def _test(self: 'TestExamples'):
coacd.set_log_level("warn")
mesh = trimesh.load(input_file, force="mesh")
mesh = coacd.Mesh(mesh.vertices, mesh.faces)
self.assertLessEqual(len(coacd.run_coacd(mesh)), 1000)
return _test
@unittest.skip
def test_deterministic(self):
mesh = trimesh.load('examples/SnowFlake.obj', force="mesh")
coacd.set_log_level("debug")
mesh = coacd.Mesh(mesh.vertices, mesh.faces)
acd1 = coacd.run_coacd(mesh, merge=False, seed=1337)
acd2 = coacd.run_coacd(mesh, merge=False, seed=1337)
self.assertEqual(len(acd1), len(acd2))
acd1 = sorted(acd1, key=lambda x: (len(x[0]), len(x[1]), x[0].sum()))
acd2 = sorted(acd2, key=lambda x: (len(x[0]), len(x[1]), x[0].sum()))
for (v1, t1), (v2, t2) in zip(acd1, acd2):
self.assertEqual(len(v1), len(v2))
self.assertEqual(len(t1), len(t2))
for (v1, t1), (v2, t2) in zip(acd1, acd2):
self.assertTrue(numpy.allclose(numpy.sort(v1), numpy.sort(v2)))
self.assertTrue(numpy.allclose(numpy.sort(t1), numpy.sort(t2)))
for f in glob.glob("examples/*.obj"):
setattr(TestExamples, f'test_{os.path.splitext(os.path.basename(f))[0].lower()}', TestExamples.single(f))
if __name__ == '__main__':
unittest.main()