draco/maya/draco_maya_tests/draco_maya_wrapper_test.py

124 lines
4.7 KiB
Python

import unittest
import os
import sys
dir_path = os.path.dirname(os.path.realpath(__file__))
root_path = os.path.join(dir_path, '../draco_maya')
sys.path.insert(0, root_path)
def file_del(file_path):
if os.path.isfile(file_path):
os.remove(file_path)
from draco_maya_wrapper import Draco, DrcMesh
class DracoTest(unittest.TestCase):
def setUp(self):
self.drc = Draco()
def test_decode_bunny_drc(self):
mesh = self.drc.decode(os.path.join(dir_path, 'res/bunny.drc'))
# Faces check
self.assertEqual(69451, mesh.faces_num, 'Number of faces')
self.assertEqual(208353, mesh.faces_len,'Length of faces array precalculated')
self.assertEqual(208353, len(mesh.faces),'Length of faces array by len')
# Vertices check
self.assertEqual(34834, mesh.vertices_num, 'Number of vertices')
self.assertEqual(104502, mesh.vertices_len,'Length of vertices array precalculated')
self.assertEqual(104502, len(mesh.vertices),'Length of vertices array by len')
# Normals check
self.assertEqual(0, mesh.normals_num, 'Number of normals')
self.assertEqual(0, mesh.normals_len,'Length of normals array precalculated')
self.assertEqual(0, len(mesh.normals),'Length of normals array by len')
# Uvs check
self.assertEqual(0, mesh.uvs_num, 'Number of uvs')
self.assertEqual(0, mesh.uvs_len,'Length of uvs ')
self.assertEqual(0, len(mesh.uvs),'Length of uvs array by len')
def test_decode_trooper_drc(self):
mesh = self.drc.decode(os.path.join(dir_path, 'res/stormtrooper.drc'))
# Faces check
self.assertEqual(6518, mesh.faces_num, 'Number of faces')
self.assertEqual(19554, mesh.faces_len,'Length of faces array precalculated')
self.assertEqual(19554, len(mesh.faces),'Length of faces array by len')
# Vertices check
self.assertEqual(5176, mesh.vertices_num, 'Number of vertices')
self.assertEqual(15528, mesh.vertices_len,'Length of vertices array precalculated')
self.assertEqual(15528, len(mesh.vertices),'Length of vertices array by len')
# Normals check
self.assertEqual(5176, mesh.normals_num, 'Number of normals')
self.assertEqual(15528, mesh.normals_len, 'Length of normals array precalculated')
self.assertEqual(15528, len(mesh.normals),'Length of normals array by len')
# Uvs check
self.assertEqual(5176, mesh.uvs_num, 'Number of uvs')
self.assertEqual(10352, mesh.uvs_len, 'Length of uvs array')
self.assertEqual(10352, len(mesh.uvs), 'Length of uvs array by len')
def test_decode_unexistent_drc(self):
self.assertRaises(Exception, self.drc.decode, 'res/unexistent.drc')
def test_encode_triangle_mesh(self):
mesh = DrcMesh()
mesh.faces = [0, 1, 2]
mesh.faces_num = 1
mesh.vertices = [0, 0, 0, 1, 1, 1, 2, 2, 2]
mesh.vertices_num = 3
file = os.path.join(dir_path,'triangle.drc')
file_del(file)
self.drc.encode(mesh, file)
self.assertTrue(os.path.isfile(file), 'File should exists!')
file_del(file)
def test_encode_and_decode_triangle_mesh(self):
mesh = DrcMesh()
mesh.faces = [0, 1, 2]
mesh.faces_num = 1
mesh.vertices = [0, 0, 0, 1, 1, 1, 2, 2, 2]
mesh.vertices_num = 3
file = os.path.join(dir_path, 'res/triangle.drc')
file_del(file)
self.drc.encode(mesh, file)
dmesh = self.drc.decode(file)
# Faces check
self.assertEqual(1, dmesh.faces_num, 'Number of faces')
self.assertEqual(3, dmesh.faces_len,'Length of faces array precalculated')
self.assertEqual([0, 1, 2], dmesh.faces, 'Face Array')
# Vertices check
self.assertEqual(3, dmesh.vertices_num, 'Number of vertices')
self.assertEqual(9, dmesh.vertices_len,'Length of vertices array precalculated')
self.assertEqual([0, 0, 0, 1, 1, 1, 2, 2, 2], dmesh.vertices, 'Vertex Array')
file_del(file)
def test_decode_and_encode_stoormtrup_drc(self):
# Step1: decode
mesh = self.drc.decode(os.path.join(dir_path, 'res/stormtrooper.drc'))
# Step2: encode
file = os.path.join(dir_path, 'res/stormtrooper_copy.drc')
file_del(file)
self.drc.encode(mesh, file)
# Step3: re-decode and test
dmesh = self.drc.decode(file)
# Faces check
self.assertEqual(6518, dmesh.faces_num, 'Number of faces')
self.assertEqual(19554, dmesh.faces_len,'Length of faces array precalculated')
self.assertEqual(19554, len(dmesh.faces),'Length of faces array by len')
# Vertices check
self.assertEqual(5176, dmesh.vertices_num, 'Number of vertices')
self.assertEqual(15528, dmesh.vertices_len,'Length of vertices array precalculated')
self.assertEqual(15528, len(dmesh.vertices),'Length of vertices array by len')
# Normals check
self.assertEqual(5176, dmesh.normals_num, 'Number of normals')
self.assertEqual(15528, dmesh.normals_len, 'Length of normals array precalculated')
self.assertEqual(15528, len(dmesh.normals),'Length of normals array by len')
file_del(file)
if __name__ == '__main__':
unittest.main()