-
Notifications
You must be signed in to change notification settings - Fork 4
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
HYDRA-861 & HYDRA-932 : Fix MtoA & LookdevX loading in tests + Related test improvements #108
Changes from all commits
108205e
071ba07
7ab3980
76d1aee
1f19933
2fb3745
80f6a95
a8cfd80
0794aa0
fa519c0
f889e4f
5f9e5fb
c39d5dd
18bcfdf
ec4e6c0
758bf27
3e1a73d
2772837
31354e8
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -26,7 +26,7 @@ For example, to run testVisibility on RelWithDebInfo : | |
|
||
### Running tests with MayaUSD | ||
|
||
Some tests require the MayaUSD plugin to be loaded in order to be run. If MayaUSD cannot be loaded, those tests will be skipped. In order for the test framework to find and load MayaUSD, the `-DMAYAUSD_LOCATION` CMake flag must be set to your MayaUSD installation directory when building MayaHydra. For convenience, you can use the `--mayausd-location` parameter when using the [build.py](../../../../../build.py) script, which will set the CMake flag for you with the given argument. The specified path should point to the directory where your MayaUSD `.mod` file resides. Note that the test framework will not find MayaUSD using the MAYA_MODULE_PATH environment variable. | ||
The tests require MayaUSD in order to be run. In order for the test framework to find and load MayaUSD, the `-DMAYAUSD_LOCATION` CMake flag must be set to your MayaUSD installation directory when building MayaHydra. For convenience, you can use the `--mayausd-location` parameter when using the [build.py](../../../../../build.py) script, which will set the CMake flag for you with the given argument. The specified path should point to the directory where your MayaUSD `.mod` file resides. Note that the test framework will not find MayaUSD using the MAYA_MODULE_PATH environment variable. | ||
|
||
For example, if your MayaUSD `.mod` file resides in `<some-path>/install/RelWithDebInfo`, you could call build.py as such : | ||
|
||
|
@@ -54,29 +54,34 @@ Looking to add a C++ test suite? See the corresponding [README.md](./cpp/README. | |
To add a new Python-only test suite : | ||
|
||
1. Create a new test[...].py file in the current folder. | ||
2. Create a test class that derives from unittest.TestCase (doesn't need to directly inherit from it). | ||
3. Add `test_[...]` methods for each test case in your test suite. | ||
4. Add the following snippet at the bottom of your file : | ||
2. Create a test class that derives from `mtohUtils.MayaHydraBaseTestCase`. | ||
3. Add the line `_file = __file__` in your class definition. | ||
4. If needed, set `_requiredPlugins` to list any plugins that need to be loaded for your test. MayaUSD does not need to be specified, it will be loaded automatically. | ||
5. Add `test_[...]` methods for each test case in your test suite. | ||
6. Add the following snippet at the bottom of your file : | ||
```python | ||
if __name__ == '__main__': | ||
fixturesUtils.runTests(globals()) | ||
``` | ||
5. Add the name of your test[...].py file to the list of `TEST_SCRIPT_FILES` in the [current folder's CMakeLists.txt](./CMakeLists.txt) | ||
7. Add the name of your test[...].py file to the list of `TEST_SCRIPT_FILES` in the [current folder's CMakeLists.txt](./CMakeLists.txt) | ||
|
||
Some important notes : | ||
- By default, the mayaHydra plugin will not be loaded. An easy way to load it is to have your test class derive from `MayaHydraBaseTestCase`, which will automatically load mayaHydra when running tests. Don't forget to add the line `_file = __file__` in your class. | ||
- After loading mayaHydra, the renderer will still be on Viewport 2.0. If you want to use another renderer, your test will have to switch to it. If you want to use HdStorm, an easy way to do it is to have your test class derive from `MayaHydraBaseTestCase` and call `self.setHdStormRenderer()` | ||
- Before each test, a new file will be opened and the renderer will be switched to Hydra. If you need to switch between renderers, you can use the `self.setHdStormRenderer()` and `self.setViewport2Renderer()` methods. | ||
Comment on lines
-67
to
+69
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Removed most of the previous info as it was outdated, and removed the mention of "MayaHydra not being loaded by default unless deriving from |
||
|
||
# Best practices | ||
- Don't skip tests unless necessary. If a test requires a certain plugin to be loaded, don't skip the test if the plugin fails to load, as this will falsely be reported as a pass. For such cases, prefer setting the `_requiredPlugins` variable in your test class. | ||
- Use relative paths in test data to make sure the tests will work anywhere. | ||
- Prefer storing USD data in text-form .usda instead of binary, for readability and ease of modification should a test need to be tweaked. | ||
|
||
# Image comparison | ||
|
||
Image comparison is done using [idiff from OpenImageIO](https://openimageio.readthedocs.io/en/latest/idiff.html). | ||
|
||
Some utilities exist to facilitate image comparison tests. Here is the simplest way to get going : | ||
1. Make your test class derive from `MtohTestCase`. | ||
2. Don't forget to add the line `_file = __file__` in your class. | ||
3. Create a folder called [TestName]Test (e.g. for testVisibility, create a folder VisibilityTest) | ||
4. Put the images you want to use for comparison in that folder | ||
5. Call `self.assertImagesClose`, `self.assertImagesEqual` and/or `self.assertSnapshotClose` with the file names of the images to compare with. | ||
1. Make sure your test class derives from `mtohUtils.MayaHydraBaseTestCase` (and has the line `_file = __file__`). | ||
Comment on lines
-75
to
+81
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. See There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. side question: is it possible to avoid the copying of "_file = file" each time? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. So, this is used in order to set the |
||
2. Create a folder called [TestName]Test (e.g. for testVisibility, create a folder VisibilityTest) | ||
3. Put the images you want to use for comparison in that folder | ||
4. Call `self.assertImagesClose`, `self.assertImagesEqual` and/or `self.assertSnapshotClose` with the file names of the images to compare with. | ||
|
||
For the `assert[...]Close` methods, you will need to pass in a fail threshold for individual pixels and a fail percentage for the whole image. Other parameters are also available for you to specify. You can find more information on these parameters on the [idiff documentation page](https://openimageio.readthedocs.io/en/latest/idiff.html). | ||
|
||
|
@@ -88,10 +93,4 @@ To create a reference snapshot, an easy way is to first write your test, and the | |
|
||
# Utilities | ||
|
||
Utility files are located under [/test/testUtils](../../../../testUtils/). Note that at the time of writing this (2023/08/16), many of the utils files and their contents were inherited from the USD plugin, and are not all used. Here are some of the main utilities you might find useful : | ||
|
||
- mtohutils.py : | ||
- `checkForMayaUsdPlugin()` will try to load the MayaUsd plugin and return a boolean indicating if the plugin was loaded successfully. By decorating a test case with the following line, you can run the test only if the MayaUsd plugin is found and loaded : | ||
```@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")``` | ||
- `MayaHydraBaseTestCase` is a base class you can use for your test classes that will provide you with some useful functionality, such as automatically loading the mayaHydra plugin. It also provides a method to use the HdStorm renderer (`setHdStormRenderer`), and another to create a simple scene with a cube (`makeCubeScene`). | ||
- `MtohTestCase` is a class you can use as a base for your test classes that will provide you with image comparison functionality (see [Image comparison](#Image-comparison) section). Note that this class already derives from MayaHydraBaseTestCase, so it will also automatically load the mayaHydra plugin. | ||
Utility files are located under [/test/testUtils](../../../../testUtils/). Note that at the time of writing this (2023/08/16), many of the utils files and their contents were inherited from the USD plugin, and are not all used. | ||
Comment on lines
-91
to
+96
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Removed most info as it is outdated or not very relevant. The plugin loading info has been moved into the steps to add tests + the best practices section |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(see
mtohUtils.py
for the corresponding code changes) I made it so we load MayaUSD by default for all tests, since we expect MayaHydra to be built with it anyways.