build123d/tests/test_direct_api/test_vtk_poly_data.py
2025-01-29 09:39:37 +01:00

88 lines
2.8 KiB
Python

"""
build123d imports
name: test_v_t_k_poly_data.py
by: Gumyr
date: January 22, 2025
desc:
This python module contains tests for the build123d project.
license:
Copyright 2025 Gumyr
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
import unittest
from build123d.topology import Solid
from build123d.vtk_tools import to_vtk_poly_data
from vtkmodules.vtkCommonDataModel import vtkPolyData
from vtkmodules.vtkFiltersCore import vtkTriangleFilter
class TestVTKPolyData(unittest.TestCase):
def setUp(self):
# Create a simple test object (e.g., a cylinder)
self.object_under_test = Solid.make_cylinder(1, 2)
def test_to_vtk_poly_data(self):
# Generate VTK data
vtk_data = to_vtk_poly_data(
self.object_under_test, tolerance=0.1, angular_tolerance=0.2, normals=True
)
# Verify the result is of type vtkPolyData
self.assertIsInstance(vtk_data, vtkPolyData)
# Further verification can include:
# - Checking the number of points, polygons, or cells
self.assertGreater(
vtk_data.GetNumberOfPoints(), 0, "VTK data should have points."
)
self.assertGreater(
vtk_data.GetNumberOfCells(), 0, "VTK data should have cells."
)
# Optionally, compare the output with a known reference object
# (if available) by exporting or analyzing the VTK data
known_filter = vtkTriangleFilter()
known_filter.SetInputData(vtk_data)
known_filter.Update()
known_output = known_filter.GetOutput()
self.assertEqual(
vtk_data.GetNumberOfPoints(),
known_output.GetNumberOfPoints(),
"Number of points in VTK data does not match the expected output.",
)
self.assertEqual(
vtk_data.GetNumberOfCells(),
known_output.GetNumberOfCells(),
"Number of cells in VTK data does not match the expected output.",
)
def test_empty_shape(self):
# Test handling of empty shape
empty_object = Solid() # Create an empty object
with self.assertRaises(ValueError) as context:
to_vtk_poly_data(empty_object)
self.assertEqual(str(context.exception), "Cannot convert an empty shape")
if __name__ == "__main__":
unittest.main()