Skip to content
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

Merged
merged 19 commits into from
Mar 26, 2024
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
19 commits
Select commit Hold shift + click to select a range
108205e
HYDRA-861 : Fix mtoa loading
debloip-adsk Mar 20, 2024
071ba07
HYDRA-861 : Make USD stage path relative in testArnoldLights scene
debloip-adsk Mar 22, 2024
7ab3980
HYDRA-932 : Remove Arnold/mtoa/ai references in testMayaDisplayModes …
debloip-adsk Mar 22, 2024
76d1aee
HYDRA-861 : Fix LookdevX loading
debloip-adsk Mar 22, 2024
1f19933
HYDRA-861 : Rework plugin loading test infrastructure and fail if plu…
debloip-adsk Mar 22, 2024
2fb3745
HYDRA-861 : Use relative paths in all test scene files
debloip-adsk Mar 24, 2024
80f6a95
HYDRA-861 : Kill ADPClientService.exe on test suite end
debloip-adsk Mar 24, 2024
a8cfd80
HYDRA-861 : Add comment for killing ADPClientService
debloip-adsk Mar 25, 2024
0794aa0
HYDRA-861 : Update point instance picking test and remove specific ch…
debloip-adsk Mar 25, 2024
fa519c0
HYDRA-861 : Add back skipping testSceneBrowser on OSX
debloip-adsk Mar 25, 2024
f889e4f
HYDRA-861 : Document force flag usage in taskkill
debloip-adsk Mar 25, 2024
5f9e5fb
HYDRA-861 : Add best practices section in test README
debloip-adsk Mar 25, 2024
c39d5dd
HYDRA-861 : Document MAYA_MODULE_PATH usage for MtoA
debloip-adsk Mar 25, 2024
18bcfdf
HYDRA-861 : Re-add existing line about MAYA_MODULE_PATH
debloip-adsk Mar 25, 2024
ec4e6c0
HYDRA-861 : Add note on what happens before each test
debloip-adsk Mar 25, 2024
758bf27
HYDRA-861 : Add other best practices
debloip-adsk Mar 25, 2024
3e1a73d
HYDRA-861 : Rename _extraPluginsToLoad to _requiredPlugins
debloip-adsk Mar 26, 2024
2772837
Merge branch 'dev' into debloip/HYDRA-861/HYDRA-932/fix-mtoa-loodkevx…
debloip-adsk Mar 26, 2024
31354e8
HYDRA-861 : Adjust testRefinement and testUsdNativeInstancePicking + …
debloip-adsk Mar 26, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
23 changes: 11 additions & 12 deletions cmake/test.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -224,6 +224,7 @@ finally:

set(ALL_PATH_VARS
PYTHONPATH
MAYA_MODULE_PATH
MAYA_PLUG_IN_PATH
MAYA_SCRIPT_PATH
XBMLANGPATH
Expand Down Expand Up @@ -299,18 +300,14 @@ finally:

# mtoa
if(DEFINED MTOA_LOCATION)
list(APPEND MAYAUSD_VARNAME_PATH
"${MTOA_LOCATION}/bin")
list(APPEND MAYAUSD_VARNAME_MAYA_SCRIPT_PATH
"${MTOA_LOCATION}/scripts/mtoa/mel")
list(APPEND MAYAUSD_VARNAME_MAYA_PXR_PLUGINPATH_NAME
"${MTOA_LOCATION}/usd")
list(APPEND MAYAUSD_VARNAME_MAYA_RENDER_DESC_PATH
"${MTOA_LOCATION}/")
list(APPEND MAYAUSD_MATERIALX_SEARCH_PATH
"${MTOA_LOCATION}/materialx/arnold")
list(APPEND MAYAUSD_MATERIALX_SEARCH_PATH
"${MTOA_LOCATION}/materialx/targets")
# It seems like we need to use MAYA_MODULE_PATH for MtoA to work properly.
# Even if we emulate the .mod file by manually setting the same env vars
# to the same values, MtoA itself will appear to load successfully when
# calling loadPlugin, but some of its extensions will fail to initialize,
# leading to incorrect behavior and test failures. In those cases, it seems
# like having a locally installed MtoA fixed it, but we can't rely on that.
list(APPEND MAYAUSD_VARNAME_MAYA_MODULE_PATH
"${MTOA_LOCATION}")
endif()

# lookdevx
Expand All @@ -325,6 +322,8 @@ finally:
"${LOOKDEVX_LOCATION}/scripts")
list(APPEND MAYAUSD_VARNAME_PYTHONPATH
"${LOOKDEVX_LOCATION}/python")
list(APPEND MAYAUSD_VARNAME_MAYA_PLUG_IN_PATH
"${LOOKDEVX_LOCATION}/plug-ins")
endif()

if(IS_WINDOWS AND DEFINED ENV{PYTHONHOME})
Expand Down
34 changes: 14 additions & 20 deletions test/lib/mayaUsd/render/mayaToHydra/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -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.
Copy link
Collaborator Author

@debloip-adsk debloip-adsk Mar 25, 2024

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.


For example, if your MayaUSD `.mod` file resides in `<some-path>/install/RelWithDebInfo`, you could call build.py as such :

Expand Down Expand Up @@ -54,29 +54,29 @@ 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 `_extraPluginsToLoad` to list any plugins that need to be loaded for your test. MayaUSD does not need to be specified, it will be loaded automatically.
Copy link
Collaborator Author

@debloip-adsk debloip-adsk Mar 25, 2024

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) The _extraPluginsToLoad variable will be used to list any plugins required by the test suite. As opposed to the previous method of skipping a test if it failed to load, this method will try to load the listed plugins, but fail the test suite immediately if one of them fails to load.

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()`
# 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 `_extraPluginsToLoad` variable in your test class.

# 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
Copy link
Collaborator Author

@debloip-adsk debloip-adsk Mar 25, 2024

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 and explanation of merging MtohTestCase into MayaHydraBaseTestCase

Copy link
Collaborator

Choose a reason for hiding this comment

The 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?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So, this is used in order to set the _inputDir variable, which points to the input folder containing the reference images (or dumped data sources), by using the given file path and test class name. Since the input folders live in the same hierarchy as the test files, __file__ is used to get the path to test file, which can then be used to construct the path to its corresponding input folder. I've tried other means of obtaining the path to the test file/class from the generic test setup code, such as by using inspect.getfile(), but it does not seem to work. With the relative paths between the test setup code and test files being known, we could in theory use these to construct the path to the input folders, but that would need to be changed along with any directory structure change, and we'd also need to account for C++ tests being in a subdirectory. At this point I think it'd be more trouble than it's worth, so I suggest staying with what we have.

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).

Expand All @@ -88,10 +88,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
Copy link
Collaborator Author

Choose a reason for hiding this comment

The 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

Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,6 @@ def setupUsdStage(self):
UsdLux.RectLight.Define(usdStage, "/USDRectLight")
cmds.refresh()

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_SkipMayaUsdUfeLights(self):
self.setupUsdStage()
with PluginLoaded('mayaHydraCppTests'):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,6 @@ def setupScene(self):

cmds.refresh()

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_PathInterface(self):
self.setupScene()
with PluginLoaded('mayaHydraCppTests'):
Expand Down
6 changes: 1 addition & 5 deletions test/lib/mayaUsd/render/mayaToHydra/cpp/testPicking.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@

from testUtils import PluginLoaded

class TestPicking(mtohUtils.MtohTestCase):
class TestPicking(mtohUtils.MayaHydraBaseTestCase):
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down Expand Up @@ -89,31 +89,27 @@ def test_PickMayaLight(self):
with PluginLoaded('mayaHydraCppTests'):
cmds.mayaHydraCppTest(directionalLightObjectName, "simpleLight", f="TestPicking.pickObject")

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_PickUsdMesh(self):
import mayaUsd_createStageWithNewLayer
stagePath = mayaUsd_createStageWithNewLayer.createStageWithNewLayer()
cubeObjectName = self.createUsdCubeFromMaya(stagePath)
with PluginLoaded('mayaHydraCppTests'):
cmds.mayaHydraCppTest(cubeObjectName, "mesh", f="TestPicking.pickObject")

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_PickUsdImplicitSurface(self):
import mayaUsd_createStageWithNewLayer
stagePath = mayaUsd_createStageWithNewLayer.createStageWithNewLayer()
cubeObjectName = self.createUsdCube(stagePath)
with PluginLoaded('mayaHydraCppTests'):
cmds.mayaHydraCppTest(cubeObjectName, "mesh", f="TestPicking.pickObject")

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_PickUsdLight(self):
import mayaUsd_createStageWithNewLayer
stagePath = mayaUsd_createStageWithNewLayer.createStageWithNewLayer()
rectLightObjectName = self.createUsdRectLight(stagePath)
with PluginLoaded('mayaHydraCppTests'):
cmds.mayaHydraCppTest(rectLightObjectName, "rectLight", f="TestPicking.pickObject")

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_MarqueeSelection(self):
import mayaUsd_createStageWithNewLayer
stagePath = mayaUsd_createStageWithNewLayer.createStageWithNewLayer()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
import testUtils
from testUtils import PluginLoaded

class TestPointInstancePicking(mtohUtils.MtohTestCase):
class TestPointInstancePicking(mtohUtils.MayaHydraBaseTestCase):
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand All @@ -45,7 +45,6 @@ def setUp(self):
cmds.setAttr('persp.rotate', -33.4, 63.0, 0, type='float3')
cmds.refresh()

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_PickPointInstancer(self):
with PluginLoaded('mayaHydraCppTests'):

Expand All @@ -63,7 +62,6 @@ def test_PickPointInstancer(self):
self.PICK_PATH + marker,
f="TestPointInstancePicking.pickPointInstance")

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_PickInstances(self):
with PluginLoaded('mayaHydraCppTests'):

Expand All @@ -87,7 +85,6 @@ def test_PickInstances(self):
self.PICK_PATH + marker,
f="TestPointInstancePicking.pickPointInstance")

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_PickPrototypes(self):
with PluginLoaded('mayaHydraCppTests'):

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@ def loadUsdScene(self):
self.setHdStormRenderer()
cmds.refresh()

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_UsdPrimInstancing(self):
self.loadUsdScene()
with PluginLoaded('mayaHydraCppTests'):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@ def loadUsdScene(self):
usdUtils.createStageFromFile(usdScenePath)
self.setHdStormRenderer()

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_HydraFromUsdSceneCorrectness(self):
self.loadUsdScene()
cmds.select(all=True)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,6 @@ def setupUsdStage(self):

cmds.refresh()

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_UsdStageLayerMuting(self):
self.setupUsdStage()
with PluginLoaded('mayaHydraCppTests'):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ class TestWireframeSelectionHighlightSceneIndex(mtohUtils.MayaHydraBaseTestCase)
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_wireframeSelectionHighlightSceneIndex(self):
self.setHdStormRenderer()
with PluginLoaded('mayaHydraCppTests'):
Expand Down
4 changes: 2 additions & 2 deletions test/lib/mayaUsd/render/mayaToHydra/testArnoldLights.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,10 @@
import unittest
import platform

class TestArnoldLights(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestArnoldLights(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__
_extraPluginsToLoad = ['mtoa']

@property
def imageDiffFailThreshold(self):
Expand Down Expand Up @@ -74,7 +75,6 @@ def verifyLightingModes(self, shadowOn):
#self.assertSnapshotClose("noLight" + imageSuffix + ".png", self.imageDiffFailThreshold, self.imageDiffFailPercent)

#Test arnold lights (e.g., aiSkyDomeLight,etc.) with a maya native sphere and usd sphere.
@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin() and mtohUtils.checkForMtoAPlugin(), "Requires Maya USD and MtoA Plugins.")
def test_ArnoldLights(self):
cmds.file(new=True, force=True)

Expand Down
2 changes: 1 addition & 1 deletion test/lib/mayaUsd/render/mayaToHydra/testCurveTools.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@

import platform

class TestCurveTools(mtohUtils.MtohTestCase):
class TestCurveTools(mtohUtils.MayaHydraBaseTestCase):
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down
2 changes: 1 addition & 1 deletion test/lib/mayaUsd/render/mayaToHydra/testFlowViewportAPI.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ def setRotateY(matrixAsAList, angle):
matrixAsAList[2+4*0] = sin(angle)
return matrixAsAList

class TestFlowViewportAPI(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestFlowViewportAPI(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down
2 changes: 1 addition & 1 deletion test/lib/mayaUsd/render/mayaToHydra/testFootPrintNode.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
HD_STORM = "HdStormRendererPlugin"
HD_STORM_OVERRIDE = "mayaHydraRenderOverride_" + HD_STORM

class TestFootPrintNode(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestFootPrintNode(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down
2 changes: 1 addition & 1 deletion test/lib/mayaUsd/render/mayaToHydra/testImageDiffing.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
import fixturesUtils
import mtohUtils

class TestImageDiffing(mtohUtils.MtohTestCase):
class TestImageDiffing(mtohUtils.MayaHydraBaseTestCase):
"""Test the image diffing setup to make sure it works and returns the expected results."""

_file = __file__
Expand Down
2 changes: 1 addition & 1 deletion test/lib/mayaUsd/render/mayaToHydra/testLookThrough.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
import mayaUtils
import platform

class TestLookThrough(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestLookThrough(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down
4 changes: 2 additions & 2 deletions test/lib/mayaUsd/render/mayaToHydra/testMaterialXOnNative.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,9 @@
import mtohUtils
import unittest

class TestMaterialXOnNative(mtohUtils.MtohTestCase):
class TestMaterialXOnNative(mtohUtils.MayaHydraBaseTestCase):
_file = __file__
_extraPluginsToLoad = ['LookdevXMaya']

IMAGEDIFF_FAIL_THRESHOLD = 0.01
IMAGEDIFF_FAIL_PERCENT = 0.1
Expand All @@ -30,7 +31,6 @@ def verifySnapshot(self, imageName):
self.IMAGEDIFF_FAIL_THRESHOLD,
self.IMAGEDIFF_FAIL_PERCENT)

@unittest.skipUnless(mtohUtils.checkForPlugin('LookdevXMaya'), "Requires LookDevX Plugin.")
def test_MaterialX(self):
mayaUtils.openTestScene("testMaterialX", "RedMtlxSphere.ma")
self.setBasicCam(2)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@

import platform

class TestMayaDisplayLayers(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestMayaDisplayLayers(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down
3 changes: 1 addition & 2 deletions test/lib/mayaUsd/render/mayaToHydra/testMayaDisplayModes.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@

import platform

class TestMayaDisplayModes(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestMayaDisplayModes(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down Expand Up @@ -100,7 +100,6 @@ def test_MayaDisplayModes(self):
self.assertSnapshotClose("displayTextures" + ".png", self.imageDiffFailThreshold, self.imageDiffFailPercent)
cmds.modelEditor(panel, edit=True, displayTextures=False)

@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_MayaBoundingBoxDisplayMode(self):
with PluginLoaded('mayaHydraFlowViewportAPILocator'):
# open a Maya scene that contains USD prims, custom flow viewport data producer prims and maya native prims
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@

import platform

class TestMayaIsolateSelect(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestMayaIsolateSelect(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down
3 changes: 1 addition & 2 deletions test/lib/mayaUsd/render/mayaToHydra/testMayaLights.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@

import platform

class TestMayaLights(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestMayaLights(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down Expand Up @@ -88,7 +88,6 @@ def verifyLightingModes(self, shadowOn):
self.assertSnapshotClose("noLight" + imageSuffix + ".png", self.imageDiffFailThreshold, self.imageDiffFailPercent)

#Test maya lights (e.g., default,directional,point,spot,etc.) with a maya native sphere and usd sphere.
@unittest.skipUnless(mtohUtils.checkForMayaUsdPlugin(), "Requires Maya USD Plugin.")
def test_MayaLights(self):
cmds.file(new=True, force=True)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@

import platform

class TestMayaShadingModes(mtohUtils.MtohTestCase): #Subclassing mtohUtils.MtohTestCase to be able to call self.assertSnapshotClose
class TestMayaShadingModes(mtohUtils.MayaHydraBaseTestCase): #Subclassing mtohUtils.MayaHydraBaseTestCase to be able to call self.assertSnapshotClose
# MayaHydraBaseTestCase.setUpClass requirement.
_file = __file__

Expand Down
Loading