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

merge 1.5.9 #654

Merged
merged 9 commits into from
Oct 29, 2023

docs(changelog): Fixes in 1.5.9

922bde8
Select commit
Loading
Failed to load commit list.
Sign in for the full log view
Merged

merge 1.5.9 #654

docs(changelog): Fixes in 1.5.9
922bde8
Select commit
Loading
Failed to load commit list.
This check has been archived and is scheduled for deletion. Learn more about checks retention
GitHub Actions / Test Results completed Oct 29, 2023 in 0s

✅ Test Results - 266/266 - Passed in 59.288s

✅ editmode-results.xml - 266/266 - Passed in 59.288s

Details

✅ editmode-results.xml - 266/266 - Passed in 59.288s
  • ✅ Anatawa12.AvatarOptimizer.Test.AnimatorParserTest.AnimationPropertyTest.TestEquals - 10/10 - Passed in 0.019s
    • TestEquals(ConstantAlways(0),ConstantAlways(0)) - Passed in 0.016s
    • TestEquals(ConstantAlways(1),ConstantAlways(1)) - Passed in 0.001s
    • TestEquals(ConstantAlways(NaN),ConstantAlways(NaN)) - Passed in 0.000s
    • TestEquals(ConstantAlways(-Infinity),ConstantAlways(-Infinity)) - Passed in 0.000s
    • TestEquals(ConstantPartially(0),ConstantPartially(0)) - Passed in 0.000s
    • TestEquals(ConstantPartially(1),ConstantPartially(1)) - Passed in 0.001s
    • TestEquals(ConstantPartially(NaN),ConstantPartially(NaN)) - Passed in 0.000s
    • TestEquals(ConstantPartially(-Infinity),ConstantPartially(-Infinity)) - Passed in 0.000s
    • TestEquals(Variable,Variable) - Passed in 0.000s
    • TestEquals(null,null) - Passed in 0.000s
  • ✅ Anatawa12.AvatarOptimizer.Test.AnimatorParserTest.AnimationPropertyTest.TestNotEquals - 4/4 - Passed in 0.002s
    • TestNotEquals(ConstantAlways(0),ConstantAlways(1)) - Passed in 0.001s
    • TestNotEquals(ConstantAlways(1),ConstantPartially(1)) - Passed in 0.000s
    • TestNotEquals(ConstantAlways(0),Variable) - Passed in 0.000s
    • TestNotEquals(null,Variable) - Passed in 0.000s
  • ✅ Anatawa12.AvatarOptimizer.Test.AnimatorParserTest.AnimationTest.TestParsingConstSourceAnimation - 19/19 - Passed in 0.071s
    • TestParsingConstSourceAnimation("Animate0To100","blendShape.shape0",100.0f) - Passed in 0.056s
    • TestParsingConstSourceAnimation("Animate1To100","blendShape.shape1",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate3To100","blendShape.shape3",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate4To100","blendShape.shape4",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate5To0","blendShape.shape5",0.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate5To100","blendShape.shape5",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate6To0","blendShape.shape6",0.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate6To100","blendShape.shape6",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate7To100","blendShape.shape7",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate8To100","blendShape.shape8",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate9To100","blendShape.shape9",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate10To100","blendShape.shape10",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate11To100","blendShape.shape11",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate12To10","blendShape.shape12",10.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate13To10","blendShape.shape13",10.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate14To10","blendShape.shape14",10.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate15To10","blendShape.shape15",10.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate16To100","blendShape.shape16",100.0f) - Passed in 0.001s
    • TestParsingConstSourceAnimation("Animate17To100","blendShape.shape17",100.0f) - Passed in 0.001s
  • ✅ Anatawa12.AvatarOptimizer.Test.AnimatorParserTest.AnimationTest.TestParsingVariableSourceAnimation - 3/3 - Passed in 0.004s
    • TestParsingVariableSourceAnimation("Animate1ToVariable","blendShape.shape1") - Passed in 0.002s
    • TestParsingVariableSourceAnimation("Animate2ToVariable","blendShape.shape2") - Passed in 0.001s
    • TestParsingVariableSourceAnimation("Animate15ToVariable","blendShape.shape15") - Passed in 0.001s
  • ✅ Anatawa12.AvatarOptimizer.Test.AnimatorParserTest.AnimationTest.VerifyConstSourceAnimation - 19/19 - Passed in 0.018s
    • VerifyConstSourceAnimation("Animate0To100","blendShape.shape0",100.0f) - Passed in 0.010s
    • VerifyConstSourceAnimation("Animate1To100","blendShape.shape1",100.0f) - Passed in 0.001s
    • VerifyConstSourceAnimation("Animate3To100","blendShape.shape3",100.0f) - Passed in 0.001s
    • VerifyConstSourceAnimation("Animate4To100","blendShape.shape4",100.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate5To0","blendShape.shape5",0.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate5To100","blendShape.shape5",100.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate6To0","blendShape.shape6",0.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate6To100","blendShape.shape6",100.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate7To100","blendShape.shape7",100.0f) - Passed in 0.001s
    • VerifyConstSourceAnimation("Animate8To100","blendShape.shape8",100.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate9To100","blendShape.shape9",100.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate10To100","blendShape.shape10",100.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate11To100","blendShape.shape11",100.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate12To10","blendShape.shape12",10.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate13To10","blendShape.shape13",10.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate14To10","blendShape.shape14",10.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate15To10","blendShape.shape15",10.0f) - Passed in 0.000s
    • VerifyConstSourceAnimation("Animate16To100","blendShape.shape16",100.0f) - Passed in 0.001s
    • VerifyConstSourceAnimation("Animate17To100","blendShape.shape17",100.0f) - Passed in 0.000s
  • ✅ Anatawa12.AvatarOptimizer.Test.AnimatorParserTest.AnimationTest.VerifyVariableSourceAnimation - 3/3 - Passed in 0.009s
    • VerifyVariableSourceAnimation("Animate1ToVariable","blendShape.shape1") - Passed in 0.008s
    • VerifyVariableSourceAnimation("Animate2ToVariable","blendShape.shape2") - Passed in 0.000s
    • VerifyVariableSourceAnimation("Animate15ToVariable","blendShape.shape15") - Passed in 0.000s
  • ✅ Anatawa12.AvatarOptimizer.Test.AnimatorParserTest.AnimatorTest - 26/26 - Passed in 0.094s
    • TestLayer00_BaseAnimate0ToConst100 - Passed in 0.015s
    • TestLayer01_Animate1ToVariable - Passed in 0.001s
    • TestLayer02_Animate2ToVariable - Passed in 0.001s
    • TestLayer03_Animate3ToConst100Non0_1Weight - Passed in 0.001s
    • TestLayer04_Animate4ToConst100WithMultipleState - Passed in 0.012s
    • TestLayer05_Animate5To100_0WithMultipleState - Passed in 0.001s
    • TestLayer06_Animate6To100_0WithSubStateMachine - Passed in 0.002s
    • TestLayer07_Animate7To100With1DBlendTree - Passed in 0.004s
    • TestLayer08_Animate8To100WithSimpleDirectional2DBlendTree - Passed in 0.001s
    • TestLayer09_Animate9To100WithFreedomDirection2DBlendTree - Passed in 0.002s
    • TestLayer10_Animate10To100WithFreeformCartesian2DBlendTree - Passed in 0.001s
    • TestLayer11_Animate11To100Partially - Passed in 0.002s
    • TestLayer12_AnimateOverride1To100 - Passed in 0.001s
    • TestLayer13_Animate12ToConst10 - Passed in 0.001s
    • TestLayer14_Animate12ToConst10Additive - Passed in 0.001s
    • TestLayer15_Animate13ToConst10 - Passed in 0.001s
    • TestLayer16_Animate13ToConst10AdditivePartially - Passed in 0.001s
    • TestLayer17_Animate14ToConst10AdditivePartially - Passed in 0.001s
    • TestLayer18_Animate15ToConst10 - Passed in 0.001s
    • TestLayer19_Animate15ToVariableAdditive - Passed in 0.001s
    • TestLayer20_Animate16ToConst100Weight0 - Passed in 0.001s
    • TestLayer21_Animate16ToConst100Weight0 - Passed in 0.001s
    • TestOneLayerOverrides - Passed in 0.019s
    • TestParseWhole - Passed in 0.011s
    • TestParseWholeWithExternalWeightChanges - Passed in 0.011s
    • TestTwoLayerOverrides - Passed in 0.002s
  • ✅ Anatawa12.AvatarOptimizer.Test.BuildAssetBundle - 1/1 - Passed in 24.495s
    • Build - Passed in 24.495s
  • ✅ Anatawa12.AvatarOptimizer.Test.ComponentSettingsTest.CheckAddComponentMenuIsInAvatarOptimizer - 15/15 - Passed in 0.009s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.ApplyOnPlay.GlobalActivator) - Passed in 0.003s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.ClearEndpointPosition) - Passed in 0.001s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.FreezeBlendShape) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.InternalAutoFreezeMeaninglessBlendShape) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.Activator) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.AvatarActivator) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.MakeChildren) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.MergeBone) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.MergePhysBone) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.MergeSkinnedMesh) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.MergeToonLitMaterial) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.RemoveMeshByBlendShape) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.RemoveMeshInBox) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.TraceAndOptimize) - Passed in 0.000s
    • CheckAddComponentMenuIsInAvatarOptimizer(Anatawa12.AvatarOptimizer.UnusedBonesByReferencesTool) - Passed in 0.000s
  • ✅ Anatawa12.AvatarOptimizer.Test.ComponentSettingsTest.CheckDisallowMultipleComponentIsSpecified - 15/15 - Passed in 0.005s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.ApplyOnPlay.GlobalActivator) - Passed in 0.001s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.ClearEndpointPosition) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.FreezeBlendShape) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.InternalAutoFreezeMeaninglessBlendShape) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.Activator) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.AvatarActivator) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.MakeChildren) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.MergeBone) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.MergePhysBone) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.MergeSkinnedMesh) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.MergeToonLitMaterial) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.RemoveMeshByBlendShape) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.RemoveMeshInBox) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.TraceAndOptimize) - Passed in 0.000s
    • CheckDisallowMultipleComponentIsSpecified(Anatawa12.AvatarOptimizer.UnusedBonesByReferencesTool) - Passed in 0.000s
  • ✅ Anatawa12.AvatarOptimizer.Test.ComponentSettingsTest.CheckHelpURLAttribute - 15/15 - Passed in 0.006s
    • CheckHelpURLAttribute(Anatawa12.ApplyOnPlay.GlobalActivator) - Passed in 0.001s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.ClearEndpointPosition) - Passed in 0.001s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.FreezeBlendShape) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.InternalAutoFreezeMeaninglessBlendShape) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.Activator) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.AvatarActivator) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.MakeChildren) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.MergeBone) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.MergePhysBone) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.MergeSkinnedMesh) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.MergeToonLitMaterial) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.RemoveMeshByBlendShape) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.RemoveMeshInBox) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.TraceAndOptimize) - Passed in 0.000s
    • CheckHelpURLAttribute(Anatawa12.AvatarOptimizer.UnusedBonesByReferencesTool) - Passed in 0.000s
  • ✅ Anatawa12.AvatarOptimizer.Test.ComponentSettingsTest.CheckNotKeyable - 15/15 - Passed in 0.034s
    • CheckNotKeyable(Anatawa12.ApplyOnPlay.GlobalActivator) - Passed in 0.005s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.ClearEndpointPosition) - Passed in 0.004s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.FreezeBlendShape) - Passed in 0.004s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.InternalAutoFreezeMeaninglessBlendShape) - Passed in 0.001s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.Activator) - Passed in 0.001s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.AvatarActivator) - Passed in 0.001s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.MakeChildren) - Passed in 0.001s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.MergeBone) - Passed in 0.001s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.MergePhysBone) - Passed in 0.006s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.MergeSkinnedMesh) - Passed in 0.003s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.MergeToonLitMaterial) - Passed in 0.001s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.RemoveMeshByBlendShape) - Passed in 0.001s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.RemoveMeshInBox) - Passed in 0.002s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.TraceAndOptimize) - Passed in 0.001s
    • CheckNotKeyable(Anatawa12.AvatarOptimizer.UnusedBonesByReferencesTool) - Passed in 0.001s
  • ✅ Anatawa12.AvatarOptimizer.Test.MergePhysBoneTest - 2/2 - Passed in 0.062s
    • CopyTest - Passed in 0.055s
    • OverrideTest - Passed in 0.007s
  • ✅ Anatawa12.AvatarOptimizer.Test.MeshInfo2Test.BlendShapeLerp - 40/40 - Passed in 0.242s
    • BlendShapeLerp("single-negative",-200,-20) - Passed in 0.197s
    • BlendShapeLerp("single-negative",-100,-10) - Passed in 0.001s
    • BlendShapeLerp("single-negative",-25,-2.5f) - Passed in 0.001s
    • BlendShapeLerp("single-negative",0,0) - Passed in 0.001s
    • BlendShapeLerp("single-negative",25,2.5f) - Passed in 0.001s
    • BlendShapeLerp("single-negative",100,10) - Passed in 0.001s
    • BlendShapeLerp("single-negative",200,20) - Passed in 0.001s
    • BlendShapeLerp("single-positive",-200,-20) - Passed in 0.001s
    • BlendShapeLerp("single-positive",-100,-10) - Passed in 0.001s
    • BlendShapeLerp("single-positive",-25,-2.5f) - Passed in 0.001s
    • BlendShapeLerp("single-positive",0,0) - Passed in 0.001s
    • BlendShapeLerp("single-positive",25,2.5f) - Passed in 0.001s
    • BlendShapeLerp("single-positive",100,10) - Passed in 0.001s
    • BlendShapeLerp("single-positive",200,20) - Passed in 0.001s
    • BlendShapeLerp("two-positive-frame",-100,-10) - Passed in 0.004s
    • BlendShapeLerp("two-positive-frame",-25,-2.5f) - Passed in 0.001s
    • BlendShapeLerp("two-positive-frame",0,0) - Passed in 0.001s
    • BlendShapeLerp("two-positive-frame",25,2.5f) - Passed in 0.001s
    • BlendShapeLerp("two-positive-frame",100,10) - Passed in 0.001s
    • BlendShapeLerp("two-positive-frame",150,55) - Passed in 0.001s
    • BlendShapeLerp("two-positive-frame",200,100) - Passed in 0.009s
    • BlendShapeLerp("two-positive-frame",250,145) - Passed in 0.001s
    • BlendShapeLerp("two-negative-frame",-250,-145) - Passed in 0.001s
    • BlendShapeLerp("two-negative-frame",-200,-100) - Passed in 0.001s
    • BlendShapeLerp("two-negative-frame",-150,-55) - Passed in 0.001s
    • BlendShapeLerp("two-negative-frame",-100,-10) - Passed in 0.001s
    • BlendShapeLerp("two-negative-frame",-25,-2.5f) - Passed in 0.001s
    • BlendShapeLerp("two-negative-frame",0,0) - Passed in 0.001s
    • BlendShapeLerp("two-negative-frame",25,2.5f) - Passed in 0.001s
    • BlendShapeLerp("two-negative-frame",100,10) - Passed in 0.001s
    • BlendShapeLerp("two-0-50-frame",-25,-2) - Passed in 0.001s
    • BlendShapeLerp("two-0-50-frame",0,0) - Passed in 0.001s
    • BlendShapeLerp("two-0-50-frame",25,0) - Passed in 0.001s
    • BlendShapeLerp("two-0-50-frame",50,1) - Passed in 0.001s
    • BlendShapeLerp("two-0-50-frame",75,2) - Passed in 0.009s
    • BlendShapeLerp("single-0",-100,float.PositiveInfinity) - Passed in 0.001s
    • BlendShapeLerp("single-0",-1,float.PositiveInfinity) - Passed in 0.001s
    • BlendShapeLerp("single-0",0,0) - Passed in 0.001s
    • BlendShapeLerp("single-0",1,float.NegativeInfinity) - Passed in 0.001s
    • BlendShapeLerp("single-0",100,float.NegativeInfinity) - Passed in 0.001s
  • ✅ Anatawa12.AvatarOptimizer.Test.MeshInfo2Test.ParseAndEmit - 6/6 - Passed in 0.105s
    • ParseAndEmit("single-negative") - Passed in 0.093s
    • ParseAndEmit("single-positive") - Passed in 0.001s
    • ParseAndEmit("single-0") - Passed in 0.007s
    • ParseAndEmit("two-positive-frame") - Passed in 0.002s
    • ParseAndEmit("two-negative-frame") - Passed in 0.001s
    • ParseAndEmit("two-0-50-frame") - Passed in 0.001s
  • ✅ Anatawa12.AvatarOptimizer.Test.MeshInfo2Test - 1/1 - Passed in 0.005s
    • RootBoneWithNoneMeshSkinnedMeshRenderer - Passed in 0.005s
  • ✅ Anatawa12.AvatarOptimizer.Test.ObjectMappingTest - 14/14 - Passed in 0.069s
    • CopyProperty - Passed in 0.043s
    • MoveObjectTest - Passed in 0.006s
    • MovePropertyOfGameObject - Passed in 0.002s
    • RecordMoveComponentTest - Passed in 0.003s
    • RecordMoveProperty - Passed in 0.002s
    • RecordMovePropertyTest - Passed in 0.001s
    • RecordMovePropertyThenComponentThenPropertyTest - Passed in 0.006s
    • RecordMovePropertyThenGameObjectThenPropertyTest - Passed in 0.001s
    • RecordMovePropertyTwiceTest - Passed in 0.001s
    • RecordRemoveComponentTest - Passed in 0.001s
    • RecordRemoveGameObject - Passed in 0.001s
    • RecordRemovePropertyTest - Passed in 0.001s
    • RecordRemovePropertyThenMergeComponent - Passed in 0.001s
    • RecordSwapPropertyTest - Passed in 0.001s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.InstanceAdd - 6/6 - Passed in 3.251s
    • InstanceAdd("mainSet",AddedTwice) - Passed in 0.625s
    • InstanceAdd("removedInInstance",Natural) - Passed in 0.478s
    • InstanceAdd("addedInInstance",NewElement) - Passed in 0.492s
    • InstanceAdd("addedTwiceInInstance",AddedTwice) - Passed in 0.497s
    • InstanceAdd("fakeRemovedInInstance",NewElement) - Passed in 0.618s
    • InstanceAdd("notExists",NewElement) - Passed in 0.540s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.InstanceEnsureAdded - 6/6 - Passed in 3.494s
    • InstanceEnsureAdded("mainSet",Natural) - Passed in 0.560s
    • InstanceEnsureAdded("removedInInstance",Natural) - Passed in 0.598s
    • InstanceEnsureAdded("addedInInstance",NewElement) - Passed in 0.568s
    • InstanceEnsureAdded("addedTwiceInInstance",AddedTwice) - Passed in 0.608s
    • InstanceEnsureAdded("fakeRemovedInInstance",NewElement) - Passed in 0.577s
    • InstanceEnsureAdded("notExists",NewElement) - Passed in 0.583s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.InstanceEnsureRemoved - 6/6 - Passed in 3.430s
    • InstanceEnsureRemoved("mainSet",Removed) - Passed in 0.536s
    • InstanceEnsureRemoved("removedInInstance",Removed) - Passed in 0.598s
    • InstanceEnsureRemoved("addedInInstance",NewSlot) - Passed in 0.587s
    • InstanceEnsureRemoved("addedTwiceInInstance",Removed) - Passed in 0.583s
    • InstanceEnsureRemoved("fakeRemovedInInstance",FakeRemoved) - Passed in 0.543s
    • InstanceEnsureRemoved("notExists",NewSlot) - Passed in 0.583s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.InstanceRemove - 6/6 - Passed in 3.440s
    • InstanceRemove("mainSet",Removed) - Passed in 0.541s
    • InstanceRemove("removedInInstance",Removed) - Passed in 0.601s
    • InstanceRemove("addedInInstance",NewSlot) - Passed in 0.562s
    • InstanceRemove("addedTwiceInInstance",Removed) - Passed in 0.603s
    • InstanceRemove("fakeRemovedInInstance",FakeRemoved) - Passed in 0.525s
    • InstanceRemove("notExists",FakeRemoved) - Passed in 0.608s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.PrefabAdd - 2/2 - Passed in 1.145s
    • PrefabAdd("mainSet",Natural) - Passed in 0.585s
    • PrefabAdd("notExists",Natural) - Passed in 0.560s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.PrefabEnsureAdded - 2/2 - Passed in 1.164s
    • PrefabEnsureAdded("mainSet",Natural) - Passed in 0.598s
    • PrefabEnsureAdded("notExists",Natural) - Passed in 0.566s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.PrefabEnsureRemoved - 2/2 - Passed in 1.120s
    • PrefabEnsureRemoved("mainSet",NewSlot) - Passed in 0.559s
    • PrefabEnsureRemoved("notExists",NewSlot) - Passed in 0.562s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.PrefabRemove - 2/2 - Passed in 1.131s
    • PrefabRemove("mainSet",NewSlot) - Passed in 0.583s
    • PrefabRemove("notExists",NewSlot) - Passed in 0.547s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.SetExistenceInstance - 12/12 - Passed in 7.687s
    • SetExistenceInstance("mainSet",True,Natural) - Passed in 0.565s
    • SetExistenceInstance("mainSet",False,Removed) - Passed in 0.622s
    • SetExistenceInstance("removedInInstance",True,AddedTwice) - Passed in 0.519s
    • SetExistenceInstance("removedInInstance",False,Removed) - Passed in 0.618s
    • SetExistenceInstance("addedInInstance",True,NewElement) - Passed in 0.566s
    • SetExistenceInstance("addedInInstance",False,FakeRemoved) - Passed in 0.616s
    • SetExistenceInstance("addedTwiceInInstance",True,AddedTwice) - Passed in 0.525s
    • SetExistenceInstance("addedTwiceInInstance",False,Removed) - Passed in 0.613s
    • SetExistenceInstance("fakeRemovedInInstance",True,NewElement) - Passed in 0.535s
    • SetExistenceInstance("fakeRemovedInInstance",False,FakeRemoved) - Passed in 0.606s
    • SetExistenceInstance("notExists",True,NewElement) - Passed in 0.919s
    • SetExistenceInstance("notExists",False,NewSlot) - Passed in 0.983s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil.SetExistencePrefab - 4/4 - Passed in 3.290s
    • SetExistencePrefab("mainSet",True,Natural) - Passed in 0.981s
    • SetExistencePrefab("mainSet",False,NewSlot) - Passed in 0.980s
    • SetExistencePrefab("notExists",True,Natural) - Passed in 0.853s
    • SetExistencePrefab("notExists",False,NewSlot) - Passed in 0.476s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.EditorUtil - 6/6 - Passed in 3.417s
    • InstanceClear - Passed in 0.613s
    • InstanceElements - Passed in 0.555s
    • PrefabClear - Passed in 0.611s
    • PrefabElements - Passed in 0.546s
    • PrefabVariantElements - Passed in 0.592s
    • VariantClear - Passed in 0.499s
  • ✅ Anatawa12.AvatarOptimizer.Test.PrefabSafeSet.PrefabSafeSetBasics - 2/2 - Passed in 1.060s
    • GetAsList - Passed in 0.534s
    • GetAsSet - Passed in 0.526s
  • ✅ Anatawa12.AvatarOptimizer.Test.RunTest - 1/1 - Passed in 0.001s
    • Successful - Passed in 0.001s
  • ✅ Anatawa12.AvatarOptimizer.Test.UtilsTest - 1/1 - Passed in 0.004s
    • FindSubProps - Passed in 0.004s