From 65c7be6eb081a079b16fca8eee2a509e7ad28453 Mon Sep 17 00:00:00 2001 From: "Addisu Z. Taddese" Date: Fri, 19 Jan 2024 10:14:28 -0600 Subject: [PATCH] Fix ModelPhotoShootTest test failures The failures are caused by a change in the DART physics engine (https://github.com/dartsim/dart/pull/1774) which causes joints to recover after reaching or exceeding their position limits. It seems like the model used in this plugin starts off with joint limits violated and recovers after a few iterations. This causes a small movement of the robot. Since the test works by comparing images taken of the robot at the start of simulation and after a few iterations, the small movement causes a discrepancy in the images. The solution here is to run the whole test while simulation is paused. This also cleans up some TestFixture warnings. Signed-off-by: Addisu Z. Taddese --- examples/worlds/model_photo_shoot.sdf | 2 +- test/integration/ModelPhotoShootTest.hh | 12 ++++++++---- test/worlds/model_photo_shoot_random_joints.sdf | 2 +- 3 files changed, 10 insertions(+), 6 deletions(-) diff --git a/examples/worlds/model_photo_shoot.sdf b/examples/worlds/model_photo_shoot.sdf index 0d479debba..c69cea09fd 100644 --- a/examples/worlds/model_photo_shoot.sdf +++ b/examples/worlds/model_photo_shoot.sdf @@ -17,7 +17,7 @@ filename="gz-sim-sensors-system" name="gz::sim::systems::Sensors"> ogre2 - 1, 1, 1 + 1.0 1.0 1.0 https://fuel.gazebosim.org/1.0/OpenRobotics/models/Robonaut diff --git a/test/integration/ModelPhotoShootTest.hh b/test/integration/ModelPhotoShootTest.hh index 5636036267..ab98a3c3f3 100644 --- a/test/integration/ModelPhotoShootTest.hh +++ b/test/integration/ModelPhotoShootTest.hh @@ -230,7 +230,6 @@ class ModelPhotoShootTest : public InternalFixture<::testing::Test> // First run of the server generating images through the plugin. TestFixture fixture(common::joinPaths(std::string(PROJECT_SOURCE_PATH), _sdfWorld)); - fixture.Server()->SetUpdatePeriod(1ns); common::ConnectionPtr postRenderConn; fixture.OnConfigure([&]( @@ -243,7 +242,12 @@ class ModelPhotoShootTest : public InternalFixture<::testing::Test> std::bind(&ModelPhotoShootTest::OnPostRender, this)); }).Finalize(); - fixture.Server()->Run(true, 50, false); + fixture.Server()->SetUpdatePeriod(1ns); + + for (int i = 0; i < 50; ++i) + { + fixture.Server()->RunOnce(true); + } this->LoadPoseValues(); fixture.OnPreUpdate([&](const sim::UpdateInfo &, @@ -285,7 +289,7 @@ class ModelPhotoShootTest : public InternalFixture<::testing::Test> } this->checkRandomJoints = false; } - }).Finalize(); + }); this->takeTestPics = true; @@ -293,7 +297,7 @@ class ModelPhotoShootTest : public InternalFixture<::testing::Test> std::chrono::milliseconds(3000); while (takeTestPics && end_time > std::chrono::steady_clock::now()) { - fixture.Server()->Run(true, 1, false); + fixture.Server()->RunOnce(true); std::this_thread::sleep_for(std::chrono::milliseconds(1)); } testImages("1.png", "1_test.png"); diff --git a/test/worlds/model_photo_shoot_random_joints.sdf b/test/worlds/model_photo_shoot_random_joints.sdf index 11a38b73df..0672f0086a 100644 --- a/test/worlds/model_photo_shoot_random_joints.sdf +++ b/test/worlds/model_photo_shoot_random_joints.sdf @@ -17,7 +17,7 @@ filename="gz-sim-sensors-system" name="gz::sim::systems::Sensors"> ogre2 - 1, 1, 1 + 1.0 1.0 1.0 https://fuel.gazebosim.org/1.0/OpenRobotics/models/Robonaut