Modifier Tests¶
Introduction¶
The current framework supports tests for:
- Mesh Modifiers
- Generate
- Deform
- Physics
- Curve Modifiers
- Operators
There are some exceptions and limitations as each modifier is a bit different, some require to switch between Object and Edit mode, some are just random and non-reproducible, and some output an Empty Mesh, hence its difficult or not possible to test them.
Note
The current framework support is only for "mesh" and "curve" modifiers, not other objects like grease pencil and volume. Additionally, as more functionality moves to geometry nodes tests might move as well.
Adding of new tests¶
The current tests for Mesh Modifiers are located in
tests/python/modifiers.py
file. Navigate to this file and add
another test for "Array" Modifier.
Steps to follow:
- Navigate to the supporting blend files which are located in the
lib\tests\\
folder. - Open the file
modifiers.blend
which is located in themodeling
folder. - Open the blend file and add 2
Cubes
. - Rename them to "LearnTestCubeArray", and the second one "LearnExpCubeArray" respectively.
- Now open the python file and add this line in the tests list
SpecMeshTest("LearnTestingArray", "LearnTestCubeArray", "LearnExpCubeArray",
[ModifierSpec('array', 'ARRAY', {})]),
Note
To have a better understanding for each parameter, navigate to
tests/python/modules/mesh_test.py
and look at the comments in
"ModifierSpec" class, this will give a clearer idea of what's possible.
Different passed arguments¶
--verbose
: First set your environment variable. Typeset BLENDER_VERBOSE=1
in the command prompt (cmd). Note, it doesn't work for Windows Powershell.--run-test
: To run a single test for visualization and comparison purpose in Blender.--run-all-tests
: To run all tests.
Advanced Steps for Automated Testing¶
How do the tests work?¶
Good question, the trick is you don't have to manually add and apply the modifier in Blender at all, on the "LearnExpCubeArray" that is the expected object, you can but then that is doing it manually. So here are the steps-
- After you add the test and expected object, no need to apply the modifier to the expected object.
- Set the
BLENDER_TEST_UPDATE
flag to 1 (or any value look at Stackoverflow on how variables are "set", 1 is just the simplest), and it will update the expected object for you. - There is a good chance that the test will fail for the first time, if you look closely at the console, then get updated and then should pass.
- The file will get saved with the updated expected object, so the next time you run the test, it will pass in first go.
Note
Failing of a test doesn't necessarily mean its a bug.
Changing Parameters of the Added Tests¶
Turn on the Python tool tip in the Preferences in Blender. You can now
hover the setting you want to change and look at the attribute name. For
example, let's increase the count
in the Array
modifier. Then
the code will look like this -
"LearnTestingArray", "LearnTestCubeArray", "LearnExpCubeArray",
[ModifierSpec('array', 'ARRAY', {'count': 4})]],
Note
The setting name in Blender and actual setting might be different, that's where the tooltip will help you.
Contributing, Reviewing and Committing¶
For Contributing: The tests can be contributed by anyone.
For Reviewing: One module member of the affected area should be included, Jacques or Hans (Geometry Nodes), Bastien or Campbell (modifiers/operators), Jeroen Baker (Compositor) and Brecht for performance tests. Apart from the core members, volunteers to add for first pass and initial feedback:
- Habib Gahbiche (zazizizou): Operators, modifiers, compositors and geometry nodes tests.
- Himanshi Kalra (calra): Operators, modifiers and geometry nodes tests.
For committing: One requires commit access and id and password of projects.blender.org, I use SmartSVN to commit the test files. Like other patches, test files can also be committed on other's behalf.
Points to remember¶
- Try to keep the meshes as simple as possible.
- Make sure the tests pass after the
BLENDER_TEST_UPDATE
flag is un-set.
Future Scope¶
Adding tests for new modifiers and extending the framework for new object types.
FAQ¶
What to do my test is failing?¶
Use Ctrl+F
and find a similar test, look closely at the comments and
see if its a corner case.
Its still failing? Let's dig deeper...¶
For Windows: Set the BLENDER_TEST_UPDATE flag=1 in the environment variable, so now when you run the test, the "expected object" gets updated automatically, if all's good it should pass.
If it still fails, you can manually investigate by running a single test
using the --run-test <test_name>
, see the example below
blender c:\blender-git\lib\tests\modeling\modifiers.blend --python c:\blender-git\blender\tests\python\curve_modifiers.py -- --run-test CurveWeld -- --verbose
Here you will find a new object called "evaluated_object", you can try applying the modifiers to it and see if its the same as the expected object you added.
In case you are interested in testing operators, they follow a similar approach.
What to do when getting errors in console?¶
Try slowly reading through it, it could be a typo in parameter name, so
the exception thrown would be an AttributeError
and some common
programming mistake.
Where are the Physics modifiers' tests located?¶
Each Physics modifier has been given a separate python file and blend
file, the python file name usually starts with
physics_<modifier_name>
, so you can test them as well, have a look
at already added tests to see how to send the parameters, they use
nested dictionary to send nested parameters. The supporting blend files
are in physics
folder.
Deform modifiers have a common blend file for Deform tests of both Mesh and Curves, it contains mostly the one that requires user input, which has been achieved by animating the object.