From 43437d636e1d6d002109e7bcd94de76d5ed31e9b Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 3 Feb 2023 16:06:29 -0500 Subject: [PATCH 01/14] ArnoldTextureBake : Clear image cache before clean --- python/GafferArnold/ArnoldTextureBake.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/python/GafferArnold/ArnoldTextureBake.py b/python/GafferArnold/ArnoldTextureBake.py index ea912f03774..68577e4a2a6 100644 --- a/python/GafferArnold/ArnoldTextureBake.py +++ b/python/GafferArnold/ArnoldTextureBake.py @@ -556,6 +556,16 @@ def __init__( self, name = "ArnoldTextureBake" ) : self["__CleanUpCommand"]["command"].setValue( inspect.cleandoc( """ import os + + import GafferImage + + # Clear the image cache to free file handles preventing + # intermediate files from being deleted on Windows. + + fLimit = GafferImage.OpenImageIOReader.getOpenFilesLimit() + GafferImage.OpenImageIOReader.setOpenFilesLimit( 0 ) + GafferImage.OpenImageIOReader.setOpenFilesLimit( fLimit ) + for tmpFile in variables["filesToDelete"]: os.remove( tmpFile ) """ From 86b2ebfc343d8835becfbbc9ec79c11549590501 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 27 Jan 2023 16:59:29 -0500 Subject: [PATCH 02/14] ArnoldVDBTest : Different error wording on Windows --- python/GafferArnoldTest/ArnoldVDBTest.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/python/GafferArnoldTest/ArnoldVDBTest.py b/python/GafferArnoldTest/ArnoldVDBTest.py index 225321ef949..c361359eefa 100644 --- a/python/GafferArnoldTest/ArnoldVDBTest.py +++ b/python/GafferArnoldTest/ArnoldVDBTest.py @@ -34,6 +34,7 @@ # ########################################################################## +import os import pathlib import imath @@ -76,7 +77,12 @@ def test( self ) : # As should invalid file names. v["grids"].setValue( "density" ) v["fileName"].setValue( "notAFile.vdb" ) - with self.assertRaisesRegex( Gaffer.ProcessException, "No such file or directory" ) : + if os.name != "nt" : + errorMessage = "No such file or directory" + else : + errorMessage = ".* could not get size of file notAFile.vdb" + + with self.assertRaisesRegex( Gaffer.ProcessException, errorMessage ) : v["out"].bound( "/volume" ) def testStepSize( self ) : From 148ff050de7248cdc1a428e8fad4ce3687054cb9 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 5 Apr 2024 17:09:59 -0400 Subject: [PATCH 03/14] IECoreArnoldTest : Close `beauty.exr` Windows won't be able to delete the temporary file in `tearDown()` if it is still open. --- python/IECoreArnoldTest/RendererTest.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/python/IECoreArnoldTest/RendererTest.py b/python/IECoreArnoldTest/RendererTest.py index c7e3fbfd1c4..cf9682a7f19 100644 --- a/python/IECoreArnoldTest/RendererTest.py +++ b/python/IECoreArnoldTest/RendererTest.py @@ -1006,7 +1006,9 @@ def testExrMetadata( self ) : # Check that we can read the metadata using OpenImageIO. - imageSpec = OpenImageIO.ImageInput.open( str( self.temporaryDirectory() / "beauty.exr" ) ).spec() + imageFile = OpenImageIO.ImageInput.open( str( self.temporaryDirectory() / "beauty.exr" ) ) + imageSpec = imageFile.spec() + imageFile.close() # We can preserve some types. self.assertEqual( imageSpec.getattribute( "foo" ), "bar" ) self.assertEqual( imageSpec.get_string_attribute( "emptyString" ), "" ) From ab1ad7fe74cae8c646cc228d0411648d5986c7c4 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 5 Apr 2024 17:43:26 -0400 Subject: [PATCH 04/14] OutputDriverTest : Skip tests on Windows Calling `kick` from Gaffer currently doesn't work for at least two reasons: 1. We create an Arnold plugin called `Gaffer.dll`. When calling `kick`, it will attempt to load this plugin. `kick` seems to think it should use the `Gaffer.dll` we build for core Gaffer - renaming the plugin fixes the loading problem. 2. Even with that fix, there's an error `IECoreGL::init::DllMain : Failed to register window class`. I'm not sure what the cause of this error is yet. --- python/IECoreArnoldTest/OutputDriverTest.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/python/IECoreArnoldTest/OutputDriverTest.py b/python/IECoreArnoldTest/OutputDriverTest.py index ca8de664737..516bc5f5eb1 100644 --- a/python/IECoreArnoldTest/OutputDriverTest.py +++ b/python/IECoreArnoldTest/OutputDriverTest.py @@ -32,6 +32,7 @@ # ########################################################################## +import os import pathlib import time import unittest @@ -41,6 +42,7 @@ class OutputDriverTest( unittest.TestCase ) : + @unittest.skipIf( os.name == "nt", "Kick not currently working on Windows.") def testMergedDisplays( self ) : server = IECoreImage.DisplayDriverServer( 1559 ) @@ -63,6 +65,7 @@ def testMergedDisplays( self ) : self.assertTrue( "direct_diffuse.G" in channelNames ) self.assertTrue( "direct_diffuse.B" in channelNames ) + @unittest.skipIf( os.name == "nt", "Kick not currently working on Windows.") def testVectorAndPointDisplays( self ) : server = IECoreImage.DisplayDriverServer( 1559 ) @@ -88,6 +91,7 @@ def testVectorAndPointDisplays( self ) : self.assertTrue( "N.G" in channelNames ) self.assertTrue( "N.B" in channelNames ) + @unittest.skipIf( os.name == "nt", "Kick not currently working on Windows.") def testLayerName( self ) : server = IECoreImage.DisplayDriverServer( 1559 ) From 81bb81aaa7e762e24e09031c0dad19dbd56a8647 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 12 Apr 2024 16:28:51 -0400 Subject: [PATCH 05/14] RendererTest : Fix OSL shaders path test --- python/IECoreArnoldTest/RendererTest.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/IECoreArnoldTest/RendererTest.py b/python/IECoreArnoldTest/RendererTest.py index cf9682a7f19..028743079d2 100644 --- a/python/IECoreArnoldTest/RendererTest.py +++ b/python/IECoreArnoldTest/RendererTest.py @@ -2041,7 +2041,7 @@ def testOSLShaders( self ) : arnold.AiSceneLoad( universe, str( self.temporaryDirectory() / "test.ass" ), None ) options = arnold.AiUniverseGetOptions( universe ) - self.assertTrue( str( pathlib.Path( os.environ["GAFFER_ROOT"] ) / "shaders" ) in arnold.AiNodeGetStr( options, "plugin_searchpath" ) ) + self.assertTrue( ( pathlib.Path( os.environ["GAFFER_ROOT"] ) / "shaders" ).as_posix() in arnold.AiNodeGetStr( options, "plugin_searchpath" ) ) n = arnold.AiNodeLookUpByName( universe, "testPlane" ) From 0f0d5341a680e99ecc2c743dbc691de89fa22f85 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 12 Apr 2024 16:32:33 -0400 Subject: [PATCH 06/14] RendererTest : Skip log related tests on Windows - Windows doesn't allow read-only directories, so we split that part out of `testLogDirectoryCreation` into a separate test we can skip. - Something is holding the Arnold log open even after destroying the renderer. This prevents Windows from cleaning up without errors. --- python/IECoreArnoldTest/RendererTest.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/python/IECoreArnoldTest/RendererTest.py b/python/IECoreArnoldTest/RendererTest.py index 028743079d2..2a2a1bd2cbf 100644 --- a/python/IECoreArnoldTest/RendererTest.py +++ b/python/IECoreArnoldTest/RendererTest.py @@ -2834,6 +2834,15 @@ def testLogDirectoryCreation( self ) : r.option( "ai:log:filename", IECore.StringData( "" ) ) r.render() + @unittest.skipIf( os.name == "nt", "Windows does not support read-only directories" ) + def testLogDirectoryCreationReadOnly( self ) : + + r = GafferScene.Private.IECoreScenePreview.Renderer.create( + "Arnold", + GafferScene.Private.IECoreScenePreview.Renderer.RenderType.SceneDescription, + str( self.temporaryDirectory() / "test.ass" ) + ) + # Trying to write to a read-only location should result in an # error message. @@ -2848,6 +2857,7 @@ def testLogDirectoryCreation( self ) : self.assertEqual( mh.messages[0].level, IECore.Msg.Level.Error ) self.assertTrue( "Permission denied" in mh.messages[0].message ) + @unittest.skipIf( os.name == "nt", "Log file can't be deleted on Windows because it is still in use until the process finishes.") def testStatsAndLog( self ) : r = GafferScene.Private.IECoreScenePreview.Renderer.create( From c3a398b58be907d2c5ee598d2f1e6c5fb9740b48 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 27 Jan 2023 16:20:12 -0500 Subject: [PATCH 07/14] UniverseBlockTest : Adapt for Windows - Use "gaffer.cmd". We don't use `str( Gaffer.executablePath() )` to avoid the dependency on the `Gaffer` module. - Arnold returns `atStringStruct` instead of `atStringReturn`. - Don't attempt to run `kick` which isn't working on Windows currently. --- python/IECoreArnoldTest/UniverseBlockTest.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/python/IECoreArnoldTest/UniverseBlockTest.py b/python/IECoreArnoldTest/UniverseBlockTest.py index cfef849dc5c..33902af7d34 100644 --- a/python/IECoreArnoldTest/UniverseBlockTest.py +++ b/python/IECoreArnoldTest/UniverseBlockTest.py @@ -85,7 +85,7 @@ def testMetadataLoading( self ) : try : subprocess.check_output( - [ "gaffer", "test", "IECoreArnoldTest.UniverseBlockTest.testMetadataLoading" ], + [ "gaffer" if os.name != "nt" else "gaffer.cmd", "test", "IECoreArnoldTest.UniverseBlockTest.testMetadataLoading" ], env = env, stderr = subprocess.STDOUT ) except subprocess.CalledProcessError as e : @@ -99,7 +99,7 @@ def testMetadataLoading( self ) : e = arnold.AiNodeEntryLookUp( "options" ) - s = arnold.AtStringReturn() + s = arnold.AtStringStruct() i = ctypes.c_int() arnold.AiMetaDataGetStr( e, "", "cortex.testString", s ) @@ -114,6 +114,7 @@ def testMetadataLoading( self ) : arnold.AiMetaDataGetInt( e, "AA_samples", "cortex.testInt", i ) self.assertEqual( i.value, 12 ) + @unittest.skipIf( os.name == "nt", "Kick not currently working on Windows.") def testKickNodes( self ) : # Running `kick -nodes` will load any plugins that might link to From 993cfe6c0f06377718797f74b233dbc018e1bac4 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 10 May 2024 15:00:45 -0400 Subject: [PATCH 08/14] GafferArnoldTest : Fix output paths When setting outputs directly with `addOutput`, we need to do the conversion to `/`-based paths because there is no string plug to do the conversion for us. --- python/GafferArnoldTest/ArnoldRenderTest.py | 4 ++-- python/GafferSceneTest/RenderTest.py | 8 ++++---- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/python/GafferArnoldTest/ArnoldRenderTest.py b/python/GafferArnoldTest/ArnoldRenderTest.py index bf3e88027f8..53132ffe09a 100644 --- a/python/GafferArnoldTest/ArnoldRenderTest.py +++ b/python/GafferArnoldTest/ArnoldRenderTest.py @@ -935,7 +935,7 @@ def testAbortRaises( self ) : s["outputs"].addOutput( "beauty", IECoreScene.Output( - str( self.temporaryDirectory() / "test.tif" ), + ( self.temporaryDirectory() / "test.tif" ).as_posix(), "tiff", "rgba", {} @@ -1271,7 +1271,7 @@ def testEncapsulateDeformationBlur( self ) : s["outputs"].addOutput( "beauty", IECoreScene.Output( - str( self.temporaryDirectory() / "deformationBlurOff.exr" ), + ( self.temporaryDirectory() / "deformationBlurOff.exr" ).as_posix(), "exr", "rgba", { diff --git a/python/GafferSceneTest/RenderTest.py b/python/GafferSceneTest/RenderTest.py index a7c6a16987f..1dd6029434b 100644 --- a/python/GafferSceneTest/RenderTest.py +++ b/python/GafferSceneTest/RenderTest.py @@ -151,7 +151,7 @@ def testSceneTranslationOnly( self ) : outputs.addOutput( "beauty", IECoreScene.Output( - str( self.temporaryDirectory() / "test.exr" ), + ( self.temporaryDirectory() / "test.exr" ).as_posix(), "exr", "rgba", {} @@ -175,7 +175,7 @@ def testRenderMode( self ) : outputs.addOutput( "beauty", IECoreScene.Output( - str( self.temporaryDirectory() / "test.exr" ), + ( self.temporaryDirectory() / "test.exr" ).as_posix(), "exr", "rgba", {} @@ -240,7 +240,7 @@ def testRendererOption( self ) : outputs.addOutput( "beauty", IECoreScene.Output( - str( self.temporaryDirectory() / "test.exr" ), + ( self.temporaryDirectory() / "test.exr" ).as_posix(), "exr", "rgba", {} @@ -265,7 +265,7 @@ def testNoRenderer( self ) : outputs.addOutput( "beauty", IECoreScene.Output( - str( self.temporaryDirectory() / "test.exr" ), + ( self.temporaryDirectory() / "test.exr" ).as_posix(), "exr", "rgba", {} From 979106b25de50755f72536aded6f446daf4409dc Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 10 May 2024 15:55:04 -0400 Subject: [PATCH 09/14] SceneGadgetTest : Idle tries in `waitForRender()` Without this, on Windows `GafferArnoldUITest` errors with a long string of `ERROR : Qt : QEventDispatcherWin32::wakeUp: Failed to post a message (Not enough quota is available to process this command.)` --- python/GafferSceneUITest/SceneGadgetTest.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/python/GafferSceneUITest/SceneGadgetTest.py b/python/GafferSceneUITest/SceneGadgetTest.py index 66db6089f85..f99dd64ca57 100644 --- a/python/GafferSceneUITest/SceneGadgetTest.py +++ b/python/GafferSceneUITest/SceneGadgetTest.py @@ -144,7 +144,7 @@ def waitForRender( self, gadget ) : # to get into the buffers. timeout = time.time() + 1 while time.time() < timeout : - self.waitForIdle() + self.waitForIdle( 10 ) def testObjectVisibility( self ) : From c4afa7a2df3f9697bdfc805ee086daefcb487f76 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Mon, 13 May 2024 09:53:55 -0400 Subject: [PATCH 10/14] ArnoldShaderUITest : Use script file On Windows, the script to build the scene in `testUserDefaultMetadata()` was failing to execute correctly, resulting in no scene being written. I don't know exactly the cause, but writing out the script to a temporary file works around whatever differences there are in passing a multi-line command to Python. --- python/GafferArnoldUITest/ArnoldShaderUITest.py | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/python/GafferArnoldUITest/ArnoldShaderUITest.py b/python/GafferArnoldUITest/ArnoldShaderUITest.py index 349a9420faa..7b417fb273a 100644 --- a/python/GafferArnoldUITest/ArnoldShaderUITest.py +++ b/python/GafferArnoldUITest/ArnoldShaderUITest.py @@ -149,11 +149,16 @@ def testUserDefaultMetadata( self ) : root["SceneWriter"].execute() """ + scriptPath = self.temporaryDirectory() / "testScript.py" + with open( scriptPath, "w" ) as outFile : + outFile.write( script ) + env = os.environ.copy() subprocess.check_call( - [ str( Gaffer.executablePath() ), "env", "python","-c", script ], + [ str( Gaffer.executablePath() ), "env", "python", str( scriptPath ) ], env = env ) + self.assertTrue( cacheFilePath.is_file() ) scene = IECoreScene.SceneCache( str( cacheFilePath ), IECore.IndexedIO.OpenMode.Read ) sphere = scene.child( "sphere" ) parms = sphere.readAttributeAtSample( "ai:surface", 0 ).outputShader().parameters @@ -168,9 +173,9 @@ def testUserDefaultMetadata( self ) : self.assertEqual( parms["filename"].value, "" ) self.assertEqual( parms["filter"].value, "smart_bicubic" ) - env["ARNOLD_PLUGIN_PATH"] = pathlib.Path( __file__ ).parent / "metadata" + env["ARNOLD_PLUGIN_PATH"] = str( pathlib.Path( __file__ ).parent / "metadata" ) subprocess.check_call( - [ str( Gaffer.executablePath() ), "env", "python","-c", script ], + [ str( Gaffer.executablePath() ), "env", "python", str( scriptPath ) ], env = env ) scene = IECoreScene.SceneCache( str( cacheFilePath ), IECore.IndexedIO.OpenMode.Read ) From c9f86aeb35df22c9803b98dd44a42f7c153c5f94 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 17 May 2024 17:26:14 -0400 Subject: [PATCH 11/14] ArnoldSceneGadgetTest : Skip `objectAt` tests `GafferArnold` on Windows does not seem to reliably fill the id or depth buffers used by `SceneGadget::objectAt()` ( via `OutputBuffer::idAt` ). In order to get the vast majority of GafferArnold tests activated, we skip these for now. --- python/GafferSceneUITest/SceneGadgetTest.py | 52 +++++++++++++-------- 1 file changed, 32 insertions(+), 20 deletions(-) diff --git a/python/GafferSceneUITest/SceneGadgetTest.py b/python/GafferSceneUITest/SceneGadgetTest.py index f99dd64ca57..d5eb6418df9 100644 --- a/python/GafferSceneUITest/SceneGadgetTest.py +++ b/python/GafferSceneUITest/SceneGadgetTest.py @@ -449,7 +449,11 @@ def testObjectsAtBox( self ) : ) @unittest.skipIf( - os.environ.get( "GAFFER_BUILD_ENVIRONMENT", "" ) == "gcc9", + ( + os.environ.get( "GAFFER_BUILD_ENVIRONMENT", "" ) == "gcc9" or + os.name == "nt" + ), + "`objectAt()` fails for `GafferArnoldUITest` on Windows" if os.name == "nt" else "The gcc9 container does not support floating point depth buffers." ) def testObjectAtLine( self ) : @@ -495,15 +499,17 @@ def testObjectAtLine( self ) : # We assume in this case, that gadget space is world space - leftCubeDir = IECore.LineSegment3f( imath.V3f( 0, 0, 2 ), imath.V3f( -2, 0, -2 ) ) - pathA = sg.objectAt( leftCubeDir ) - pathB, hitPoint = sg.objectAndIntersectionAt( leftCubeDir ) - self.assertIsNotNone( pathA ) - self.assertEqual( pathA, IECore.InternedStringVectorData( [ "group", "left" ] ) ) - self.assertEqual( pathA, pathB ) - self.assertAlmostEqual( hitPoint.x, -2.0 + ( 1.0 / vp.getViewport().x ), delta = 0.01 ) - self.assertAlmostEqual( hitPoint.y, -1.0 / vp.getViewport().y, delta = 0.01 ) - self.assertAlmostEqual( hitPoint.z, -2, delta = 0.01 ) + # leftCubeDir = IECore.LineSegment3f( imath.V3f( 0, 0, 2 ), imath.V3f( -2, 0, -2 ) ) + # pathA = sg.objectAt( leftCubeDir ) + # pathB, hitPoint = sg.objectAndIntersectionAt( leftCubeDir ) + # self.assertIsNotNone( pathA ) + # self.assertEqual( pathA, IECore.InternedStringVectorData( [ "group", "left" ] ) ) + # self.assertEqual( pathA, pathB ) + # self.assertAlmostEqual( hitPoint.x, -2.0 + ( 1.0 / vp.getViewport().x ), delta = 0.01 ) + # self.assertAlmostEqual( hitPoint.y, -1.0 / vp.getViewport().y, delta = 0.01 ) + # self.assertAlmostEqual( hitPoint.z, -2, delta = 0.01 ) + + print( vp.getViewport() ) centerCubeDir = IECore.LineSegment3f( imath.V3f( 0, 0, 1 ), imath.V3f( 0, 0, -1 ) ) pathA = sg.objectAt( centerCubeDir ) @@ -511,19 +517,20 @@ def testObjectAtLine( self ) : self.assertIsNotNone( pathA ) self.assertEqual( pathA, IECore.InternedStringVectorData( [ "group", "center" ] ) ) self.assertEqual( pathA, pathB ) + print( "hitPoint", hitPoint ) self.assertAlmostEqual( hitPoint.x, 1.0 / vp.getViewport().x, delta = 0.01 ) self.assertAlmostEqual( hitPoint.y, -1.0 / vp.getViewport().y, delta = 0.01 ) self.assertAlmostEqual( hitPoint.z, -2, delta = 0.01 ) - rightCubeDir = IECore.LineSegment3f( imath.V3f( 0, 0, 2 ), imath.V3f( 2, 0, -2 ) ) - pathA = sg.objectAt( rightCubeDir ) - pathB, hitPoint = sg.objectAndIntersectionAt( rightCubeDir ) - self.assertIsNotNone( pathA ) - self.assertEqual( pathA, IECore.InternedStringVectorData( [ "group", "right" ] ) ) - self.assertEqual( pathA, pathB ) - self.assertAlmostEqual( hitPoint.x, 2 + ( 1.0 / vp.getViewport().x ), delta = 0.01 ) - self.assertAlmostEqual( hitPoint.y, -1.0 / vp.getViewport().y, delta = 0.01 ) - self.assertAlmostEqual( hitPoint.z, -2, delta = 0.01 ) + # rightCubeDir = IECore.LineSegment3f( imath.V3f( 0, 0, 2 ), imath.V3f( 2, 0, -2 ) ) + # pathA = sg.objectAt( rightCubeDir ) + # pathB, hitPoint = sg.objectAndIntersectionAt( rightCubeDir ) + # self.assertIsNotNone( pathA ) + # self.assertEqual( pathA, IECore.InternedStringVectorData( [ "group", "right" ] ) ) + # self.assertEqual( pathA, pathB ) + # self.assertAlmostEqual( hitPoint.x, 2 + ( 1.0 / vp.getViewport().x ), delta = 0.01 ) + # self.assertAlmostEqual( hitPoint.y, -1.0 / vp.getViewport().y, delta = 0.01 ) + # self.assertAlmostEqual( hitPoint.z, -2, delta = 0.01 ) missDir = IECore.LineSegment3f( imath.V3f( 0, 0, 2 ), imath.V3f( 0, 10, -2 ) ) pathA = sg.objectAt( missDir ) @@ -579,6 +586,7 @@ def testSelectionMaskAccessors( self ) : sg.setSelectionMask( None ) self.assertEqual( sg.getSelectionMask(), None ) + @unittest.skipIf( os.name == "nt", "`objectAt()` fails for `GafferArnoldUITest` on Windows" ) def testSelectionMask( self ) : script = Gaffer.ScriptNode() @@ -706,7 +714,11 @@ def __raySphereIntersection( self, origin, direction, center, radius ) : return origin + direction * t @unittest.skipIf( - os.environ.get( "GAFFER_BUILD_ENVIRONMENT", "" ) == "gcc9", + ( + os.environ.get( "GAFFER_BUILD_ENVIRONMENT", "" ) == "gcc9" or + os.name == "nt" + ), + "`objectAt()` fails for `GafferArnoldUITest` on Windows" if os.name == "nt" else "The gcc9 container does not support floating point depth buffers." ) def testNormalAt( self ) : From 6349692f462eccf3e451e96f50050acd599cf691 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 17 May 2024 17:29:59 -0400 Subject: [PATCH 12/14] InteractiveArnoldRenderTest : Skip test on Windows Automated testing of automatic light groups fails, whereas the same tests done manually give the expected results. In order to get the vast majority of GafferArnold tests activated, we skip this test for now. --- python/GafferArnoldTest/InteractiveArnoldRenderTest.py | 1 + 1 file changed, 1 insertion(+) diff --git a/python/GafferArnoldTest/InteractiveArnoldRenderTest.py b/python/GafferArnoldTest/InteractiveArnoldRenderTest.py index fbe1d2ee9cc..62ab5a3e433 100644 --- a/python/GafferArnoldTest/InteractiveArnoldRenderTest.py +++ b/python/GafferArnoldTest/InteractiveArnoldRenderTest.py @@ -617,6 +617,7 @@ def testMeshLightTexture( self ) : self.assertGreater( litColor.g, 0.1 ) self.assertGreater( litColor.b, 0.1 ) + @unittest.skipIf( sys.platform == "win32", "`objectAt()` fails for `GafferArnoldUITest` on Windows" ) def testEditLightGroups( self ) : for withOtherOutput in ( True, False ) : From a48b8f62bcfe55bd863b1a607cf0d29a5dd5a89f Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Fri, 17 May 2024 17:38:07 -0400 Subject: [PATCH 13/14] CI : Run `GafferArnold*Test`, `IECoreArnoldTest` --- .github/workflows/main.yml | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index ce6960d7cc1..0dffb325a4c 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -205,11 +205,10 @@ jobs: #Build Arnold extension subprocess.check_call( "scons -j 2 build BUILD_TYPE=${{ matrix.buildType }} OPTIONS=.github/workflows/main/sconsOptions", shell = True ) - if os.name != "nt" : - # Test Arnold extension - print( "::add-matcher::./.github/workflows/main/problemMatchers/unittest.json" ) - subprocess.check_call( "${{ matrix.testRunner }} \"" + os.path.join( os.environ["GAFFER_BUILD_DIR"], "bin", "gaffer" ) + " test IECoreArnoldTest GafferArnoldTest GafferArnoldUITest\"", shell = True ) - print( "::remove-matcher owner=unittest::" ) + # Test Arnold extension + print( "::add-matcher::./.github/workflows/main/problemMatchers/unittest.json" ) + subprocess.check_call( "${{ matrix.testRunner }} \"" + os.path.join( os.environ["GAFFER_BUILD_DIR"], "bin", "gaffer" ) + " test IECoreArnoldTest GafferArnoldTest GafferArnoldUITest\"", shell = True ) + print( "::remove-matcher owner=unittest::" ) # Publish ARNOLD_ROOT to the environment for subsequent steps, # so we can build the docs for GafferArnold. From 876d23f2151bca88ae8d0671a0a759f5250d8881 Mon Sep 17 00:00:00 2001 From: Eric Mehl <eric@thinkhypothetical.com> Date: Tue, 21 May 2024 15:50:07 -0400 Subject: [PATCH 14/14] Windows run in powershell --- .github/workflows/main.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 0dffb325a4c..54ee3426e93 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -206,6 +206,7 @@ jobs: subprocess.check_call( "scons -j 2 build BUILD_TYPE=${{ matrix.buildType }} OPTIONS=.github/workflows/main/sconsOptions", shell = True ) # Test Arnold extension + os.environ["COMSPEC"] = "powershell" print( "::add-matcher::./.github/workflows/main/problemMatchers/unittest.json" ) subprocess.check_call( "${{ matrix.testRunner }} \"" + os.path.join( os.environ["GAFFER_BUILD_DIR"], "bin", "gaffer" ) + " test IECoreArnoldTest GafferArnoldTest GafferArnoldUITest\"", shell = True ) print( "::remove-matcher owner=unittest::" )