diff --git a/Core/include/Acts/Geometry/CuboidVolumeBounds.hpp b/Core/include/Acts/Geometry/CuboidVolumeBounds.hpp index 124d1b7d64364e73fd2adab2effec2874a8b52cb..6e8f60f13d2633bcc444019b2e6104e7e6395741 100644 --- a/Core/include/Acts/Geometry/CuboidVolumeBounds.hpp +++ b/Core/include/Acts/Geometry/CuboidVolumeBounds.hpp @@ -159,7 +159,8 @@ inline std::vector<double> CuboidVolumeBounds::values() const { } inline void CuboidVolumeBounds::checkConsistency() noexcept(false) { - if (get(eHalfLengthX) * get(eHalfLengthY) * get(eHalfLengthZ) <= 0.) { + if (get(eHalfLengthX) <= 0 or get(eHalfLengthY) <= 0 or + get(eHalfLengthZ) <= 0.) { throw std::invalid_argument( "CuboidVolumeBounds: invalid input, zero or negative."); } diff --git a/Tests/UnitTests/Core/Geometry/CuboidVolumeBoundsTests.cpp b/Tests/UnitTests/Core/Geometry/CuboidVolumeBoundsTests.cpp index b3b3da779f4d477e6d2239371aa6f21419de892a..504f4373d0200fc1adb0f912727e05a332e47479 100644 --- a/Tests/UnitTests/Core/Geometry/CuboidVolumeBoundsTests.cpp +++ b/Tests/UnitTests/Core/Geometry/CuboidVolumeBoundsTests.cpp @@ -47,12 +47,18 @@ BOOST_AUTO_TEST_CASE(CuboidVolumeRecreation) { BOOST_AUTO_TEST_CASE(CuboidVolumeException) { // Test exception negative x BOOST_CHECK_THROW(CuboidVolumeBounds(-hx, hy, hz), std::logic_error); - // Test exception negative y BOOST_CHECK_THROW(CuboidVolumeBounds(hx, -hy, hz), std::logic_error); - // Test exception negative z BOOST_CHECK_THROW(CuboidVolumeBounds(hx, hy, -hz), std::logic_error); + // Other iterations 0 + BOOST_CHECK_THROW(CuboidVolumeBounds(-hx, hy, -hz), std::logic_error); + // Other iterations 1 + BOOST_CHECK_THROW(CuboidVolumeBounds(-hx, -hy, hz), std::logic_error); + // Other iterations 2 + BOOST_CHECK_THROW(CuboidVolumeBounds(hx, -hy, -hz), std::logic_error); + // Other iterations : all + BOOST_CHECK_THROW(CuboidVolumeBounds(-hx, -hy, -hz), std::logic_error); } BOOST_AUTO_TEST_CASE(CuboidVolumeProperties) {