address PR comments

main
amzn-sean 5 years ago
parent be7d34b856
commit 24167e7c02

@ -102,32 +102,27 @@ def C18243589_Joints_BallSoftLimitsConstrained():
normalizedStartPos = JointsHelper.getRelativeVector(lead.position, follower.position) normalizedStartPos = JointsHelper.getRelativeVector(lead.position, follower.position)
normalizedStartPos = normalizedStartPos.GetNormalizedSafe() normalizedStartPos = normalizedStartPos.GetNormalizedSafe()
#the targeted angle to reach between the initial vector and the current follower-lead vector #the targeted angle to reach between the initial vector and the current follower-lead vector
targetAngleDeg = 45 TARGET_ANGLE_DEG = 45
targetAngle = math.radians(targetAngleDeg) targetAngle = math.radians(TARGET_ANGLE_DEG)
maxTotalWaitTime = 2.0 #seconds
waitTime = 0.0
waitStep = 0.2
angleAchieved = 0.0 angleAchieved = 0.0
while waitTime < maxTotalWaitTime:
waitTime = waitTime + waitStep
general.idle_wait(waitStep) # wait for lead and follower to move
def checkAngleMet():
#calculate the current follower-lead vector #calculate the current follower-lead vector
normalVec = JointsHelper.getRelativeVector(lead.position, follower.position) normalVec = JointsHelper.getRelativeVector(lead.position, follower.position)
normalVec = normalVec.GetNormalizedSafe() normalVec = normalVec.GetNormalizedSafe()
#dot product + acos to get the angle #dot product + acos to get the angle
angleAchieved = math.acos(normalizedStartPos.Dot(normalVec)) angleAchieved = math.acos(normalizedStartPos.Dot(normalVec))
#is it above target? #is it above target?
if angleAchieved > targetAngle: return angleAchieved > targetAngle
followerMovedAboveJoint = True
break MAX_WAIT_TIME = 2.0 #seconds
followerMovedAboveJoint = helper.wait_for_condition(checkAngleMet, MAX_WAIT_TIME)
# 5) Check to see if lead and follower behaved as expected # 5) Check to see if lead and follower behaved as expected
Report.info_vector3(lead.position, "lead position after {:.2f} second:".format(waitTime)) Report.info_vector3(lead.position, "lead position:")
Report.info_vector3(follower.position, "follower position after {:.2f} second:".format(waitTime)) Report.info_vector3(follower.position, "follower position:")
angleAchievedDeg = math.degrees(angleAchieved) angleAchievedDeg = math.degrees(angleAchieved)
Report.info("Angle achieved {:.2f} Target {:.2f}".format(angleAchievedDeg, targetAngleDeg)) Report.info(f"Angle achieved {angleAchievedDeg:.2f} Target {TARGET_ANGLE_DEG:.2f}")
leadPositionDelta = lead.position.Subtract(leadInitialPosition) leadPositionDelta = lead.position.Subtract(leadInitialPosition)
leadRemainedStill = JointsHelper.vector3SmallerThanScalar(leadPositionDelta, FLOAT_EPSILON) leadRemainedStill = JointsHelper.vector3SmallerThanScalar(leadPositionDelta, FLOAT_EPSILON)

@ -254,6 +254,8 @@ class TestAutomation(TestAutomationBase):
from . import C4044697_Material_PerfaceMaterialValidation as test_module from . import C4044697_Material_PerfaceMaterialValidation as test_module
self._run_test(request, workspace, editor, test_module) self._run_test(request, workspace, editor, test_module)
@pytest.mark.xfail(
reason="This test will sometimes fail as the ball will continue to roll before the timeout is reached.")
@revert_physics_config @revert_physics_config
def test_C4976202_RigidBody_StopsWhenBelowKineticThreshold(self, request, workspace, editor, launcher_platform): def test_C4976202_RigidBody_StopsWhenBelowKineticThreshold(self, request, workspace, editor, launcher_platform):
from . import C4976202_RigidBody_StopsWhenBelowKineticThreshold as test_module from . import C4976202_RigidBody_StopsWhenBelowKineticThreshold as test_module
@ -468,12 +470,12 @@ class TestAutomation(TestAutomationBase):
from . import C6090547_ForceRegion_ParentChildForceRegions as test_module from . import C6090547_ForceRegion_ParentChildForceRegions as test_module
self._run_test(request, workspace, editor, test_module) self._run_test(request, workspace, editor, test_module)
@revert_physics_config @revert_physics_config
def test_C19578021_ShapeCollider_CanBeAdded(self, request, workspace, editor, launcher_platform): def test_C19578021_ShapeCollider_CanBeAdded(self, request, workspace, editor, launcher_platform):
from . import C19578021_ShapeCollider_CanBeAdded as test_module from . import C19578021_ShapeCollider_CanBeAdded as test_module
self._run_test(request, workspace, editor, test_module) self._run_test(request, workspace, editor, test_module)
@revert_physics_config @revert_physics_config
def test_C15425929_Undo_Redo(self, request, workspace, editor, launcher_platform): def test_C15425929_Undo_Redo(self, request, workspace, editor, launcher_platform):
from . import C15425929_Undo_Redo as test_module from . import C15425929_Undo_Redo as test_module
self._run_test(request, workspace, editor, test_module) self._run_test(request, workspace, editor, test_module)

Loading…
Cancel
Save