From fa5d3678467ecf9499c7f25e27e86c973523c8aa Mon Sep 17 00:00:00 2001 From: Steve Peters Date: Fri, 20 Dec 2024 13:50:19 -0800 Subject: [PATCH] Add expectations about auto-inertial warnings (#1520) Signed-off-by: Steve Peters --- src/Link_TEST.cc | 55 ++++++++++++++++++++++++++++++++++++++++-------- 1 file changed, 46 insertions(+), 9 deletions(-) diff --git a/src/Link_TEST.cc b/src/Link_TEST.cc index a2c346c2d..8f32db944 100644 --- a/src/Link_TEST.cc +++ b/src/Link_TEST.cc @@ -389,6 +389,24 @@ TEST(DOMLink, ResolveAutoInertialsWithDifferentDensity) )"; + // Parse first with enforcement policy set to ERR to detect warnings. + { + sdf::Root root; + sdf::ParserConfig sdfParserConfig; + // Set enforcement policy to ERR so we can detect warnings in sdf::Errors. + sdfParserConfig.SetWarningsPolicy(sdf::EnforcementPolicy::ERR); + sdf::Errors errors = root.LoadSdfString(sdfString, sdfParserConfig); + // Expect 1 warning due to an unset collision density. + EXPECT_EQ(1u, errors.size()) << errors; + EXPECT_EQ(sdf::ErrorCode::ELEMENT_MISSING, errors[0].Code()) << errors; + EXPECT_NE(std::string::npos, + errors[0].Message().find( + "Collision is missing a child element. Using a " + "default density value of")) << errors; + EXPECT_NE(nullptr, root.Element()); + } + + // Parse again with default enforcement policy and expect no warnings. sdf::Root root; const sdf::ParserConfig sdfParserConfig; sdf::Errors errors = root.LoadSdfString(sdfString, sdfParserConfig); @@ -755,6 +773,27 @@ TEST(DOMLink, InertialValuesGivenWithAutoSetToTrue) " " " "; + // Parse first with enforcement policy set to ERR to detect warnings. + { + sdf::Root root; + sdf::ParserConfig sdfParserConfig; + // Set enforcement policy to ERR so we can detect warnings in sdf::Errors. + sdfParserConfig.SetWarningsPolicy(sdf::EnforcementPolicy::ERR); + sdf::Errors errors = root.LoadSdfString(sdf, sdfParserConfig); + // Expect 1 warning due to user-specified inertial values when using + // inertial auto=true. + EXPECT_EQ(1u, errors.size()) << errors; + EXPECT_EQ(sdf::ErrorCode::WARNING, errors[0].Code()) << errors; + EXPECT_NE(std::string::npos, + errors[0].Message().find( + "Inertial was used with auto=true for the link named " + "compound_link, but user-defined inertial values were " + "found, which will be overwritten by the computed inertial " + "values")) << errors; + EXPECT_NE(nullptr, root.Element()); + } + + // Parse again with default enforcement policy and expect no warnings. sdf::Root root; const sdf::ParserConfig sdfParserConfig; sdf::Errors errors = root.LoadSdfString(sdf, sdfParserConfig); @@ -933,11 +972,11 @@ TEST(DOMLink, ResolveAutoInertialsWithMassAndMultipleCollisions) TEST(DOMLink, ResolveAutoInertialsWithMassAndDefaultDensity) { // A model with link inertial auto set to true. - // The inertia matrix is specified but should be ignored. // is specified - the auto computed inertial values should // be scaled based on the desired mass. // The model contains two collisions with different sizes. Density // is specified for the top collision but not the bottom collision. + // There should be no parser warnings. // The model should have a lumped center of mass at the link origin. std::string sdf = "" "" @@ -945,12 +984,6 @@ TEST(DOMLink, ResolveAutoInertialsWithMassAndDefaultDensity) " " " " " 12000.0" - " 1 1 1 2 2 2" - " " - " 1" - " 1" - " 1" - " " " " " " " 0.0 0.0 0.5 0 0 0" @@ -974,9 +1007,13 @@ TEST(DOMLink, ResolveAutoInertialsWithMassAndDefaultDensity) ""; sdf::Root root; - const sdf::ParserConfig sdfParserConfig; + sdf::ParserConfig sdfParserConfig; + // Set enforcement policy to ERR so we can detect warnings in sdf::Errors. + sdfParserConfig.SetWarningsPolicy(sdf::EnforcementPolicy::ERR); sdf::Errors errors = root.LoadSdfString(sdf, sdfParserConfig); - EXPECT_TRUE(errors.empty()); + // Expect no warnings due to user-specified inertial values when using + // inertial auto=true. + EXPECT_TRUE(errors.empty()) << errors; EXPECT_NE(nullptr, root.Element()); const sdf::Model *model = root.Model();