forked from bartvdbraak/blender
4a02b9ffeb
Runs tests based on blend files with minimum python interaction. Developed as part of GSoC 2021 - Regression Testing of Geometry Nodes. Earlier, tests were built from scratch by adding a modifier/operation from the Python API. Now, tests can also be created inside blender and are compared using Python script. Features: Automatically adding expected object if it doesn't exist. This patch adds tests for the following Geometry Nodes category: * Curves * Geometry * Mesh * Points The implemented UML diagram for refactoring of mesh test framework. {F10225906} Technical Changes: SpecMeshTest: It adds the modifier/operation based on the Spec provided. BlendFileTest: It applies already existing modifier/operation from the blend file. Test folders hierarchy with tests. This folder should be extracted to `lib\tests\modeling` {F10240651} Note: The `geometry_nodes` folder might lie under another `geometry_nodes` folder while extracting, please double check. Use the inner-most one. The hierarchy should be: -`lib\tests\modeling\geometry_nodes\mesh` -`lib\tests\modeling\geometry_nodes\points` and so on. * From `ctest` the tests should be run as `ctest -R geo_node -C [Configuration]` on Windows. * Each single test can be run with its entire name e..g `ctest -R geo_node_geometry_join_geometry`.(just an example). Run `ctest -N -R geo_node` to see all tests. * From blender, the tests can be run `blender -b path\to\blend\file --python path\to\geo_node_test.py` Reviewed By: zazizizou, JacquesLucke Differential Revision: https://developer.blender.org/D11611
120 lines
6.1 KiB
Python
120 lines
6.1 KiB
Python
# ##### BEGIN GPL LICENSE BLOCK #####
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# as published by the Free Software Foundation; either version 2
|
|
# of the License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software Foundation,
|
|
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
#
|
|
# ##### END GPL LICENSE BLOCK #####
|
|
|
|
# <pep8 compliant>
|
|
|
|
# To run the test type: blender -b /path/to/the/blend/file --python path/to/this/py/file -- --run-all-tests -- --verbose
|
|
# Type the above line in cmd/terminal, for example, look below
|
|
# blender -b c:\blender-lib\deform_modifiers.blend --python c:\deform_modifiers.py -- --run-all-tests -- --verbose
|
|
|
|
|
|
import os
|
|
import sys
|
|
import bpy
|
|
|
|
sys.path.append(os.path.dirname(os.path.realpath(__file__)))
|
|
from modules.mesh_test import SpecMeshTest, ModifierSpec, OperatorSpecObjectMode, DeformModifierSpec, RunTest
|
|
|
|
tests = [
|
|
|
|
# Surface Deform Test, finally can bind to the Target object.
|
|
# Actual deformation occurs by animating imitating user input.
|
|
|
|
SpecMeshTest("SurfaceDeform", "testObjMonkeySurfaceDeform", "expObjMonkeySurfaceDeform",
|
|
[DeformModifierSpec(10, [
|
|
ModifierSpec('surface_deform', 'SURFACE_DEFORM', {'target': bpy.data.objects["Cube"]})],
|
|
OperatorSpecObjectMode('surfacedeform_bind', {'modifier': 'surface_deform'}))]),
|
|
|
|
# Mesh Deform Test, finally can bind to the Target object.
|
|
# Actual deformation occurs by animating imitating user input.
|
|
|
|
SpecMeshTest("MeshDeform", "testObjMonkeyMeshDeform", "expObjMonkeyMeshDeform",
|
|
[DeformModifierSpec(10, [ModifierSpec('mesh_deform', 'MESH_DEFORM',
|
|
{'object': bpy.data.objects["MeshCube"], 'precision': 2})],
|
|
OperatorSpecObjectMode('meshdeform_bind', {'modifier': 'mesh_deform'}))]),
|
|
|
|
# Surface Deform Test, finally can bind to the Target object.
|
|
# Actual deformation occurs by animating imitating user input.
|
|
|
|
SpecMeshTest("Hook", "testObjHookPlane", "expObjHookPlane",
|
|
[DeformModifierSpec(10, [ModifierSpec('hook', 'HOOK',
|
|
{'object': bpy.data.objects["Empty"], 'falloff_radius': 1,
|
|
'vertex_group': 'Group'})])]),
|
|
|
|
# Laplacian Deform Test, first a hook is attached.
|
|
|
|
SpecMeshTest("Laplace", "testObjCubeLaplacian", "expObjCubeLaplacian",
|
|
[DeformModifierSpec(10,
|
|
[ModifierSpec('hook2', 'HOOK', {'object': bpy.data.objects["Empty.001"],
|
|
'vertex_group': 'hook_vg'}),
|
|
ModifierSpec('laplace', 'LAPLACIANDEFORM', {'vertex_group': 'laplace_vg'})],
|
|
OperatorSpecObjectMode('laplaciandeform_bind', {'modifier': 'laplace'}))]),
|
|
|
|
SpecMeshTest("WarpPlane", "testObjPlaneWarp", "expObjPlaneWarp",
|
|
[DeformModifierSpec(10, [ModifierSpec('warp', 'WARP',
|
|
{'object_from': bpy.data.objects["From"],
|
|
'object_to': bpy.data.objects["To"],
|
|
})])]),
|
|
|
|
#############################################
|
|
# Curves Deform Modifiers
|
|
#############################################
|
|
SpecMeshTest("CurveArmature", "testObjBezierCurveArmature", "expObjBezierCurveArmature",
|
|
[DeformModifierSpec(10, [ModifierSpec('curve_armature', 'ARMATURE',
|
|
{'object': bpy.data.objects['testArmatureHelper'],
|
|
'use_vertex_groups': False, 'use_bone_envelopes': True})])]),
|
|
|
|
SpecMeshTest("CurveLattice", "testObjBezierCurveLattice", "expObjBezierCurveLattice",
|
|
[DeformModifierSpec(10, [ModifierSpec('curve_lattice', 'LATTICE',
|
|
{'object': bpy.data.objects['testLatticeCurve']})])]),
|
|
|
|
# HOOK for Curves can't be tested with current framework, as it requires going to Edit Mode to select vertices,
|
|
# here is no equivalent of a vertex group in Curves.
|
|
# Dummy test for Hook, can also be called corner case
|
|
SpecMeshTest("CurveHook", "testObjBezierCurveHook", "expObjBezierCurveHook",
|
|
[DeformModifierSpec(10,
|
|
[ModifierSpec('curve_Hook', 'HOOK', {'object': bpy.data.objects['EmptyCurve']})])]),
|
|
|
|
SpecMeshTest("MeshDeformCurve", "testObjCurveMeshDeform", "expObjCurveMeshDeform",
|
|
[DeformModifierSpec(10, [
|
|
ModifierSpec('mesh_deform_curve', 'MESH_DEFORM', {'object': bpy.data.objects["Cylinder"],
|
|
'precision': 2})],
|
|
OperatorSpecObjectMode('meshdeform_bind', {'modifier': 'mesh_deform_curve'}))]),
|
|
|
|
SpecMeshTest("WarpCurve", "testObjBezierCurveWarp", "expObjBezierCurveWarp",
|
|
[DeformModifierSpec(10, [ModifierSpec('warp_curve', 'WARP',
|
|
{'object_from': bpy.data.objects["From_curve"],
|
|
'object_to': bpy.data.objects["To_curve"]})])]),
|
|
|
|
]
|
|
|
|
deform_tests = RunTest(tests)
|
|
command = list(sys.argv)
|
|
for i, cmd in enumerate(command):
|
|
if cmd == "--run-all-tests":
|
|
deform_tests.apply_modifiers = True
|
|
deform_tests.do_compare = True
|
|
deform_tests.run_all_tests()
|
|
break
|
|
elif cmd == "--run-test":
|
|
deform_tests.apply_modifiers = False
|
|
deform_tests.do_compare = False
|
|
name = command[i + 1]
|
|
deform_tests.run_test(name)
|
|
break
|