From 557929a0caed3573656671d09707ebc69e291cde Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?St=C3=A9phane=20Del=20Pino?= <stephane.delpino44@gmail.com>
Date: Fri, 11 Jun 2021 11:28:32 +0200
Subject: [PATCH] Improve error messages and add bound violation tests

---
 src/analysis/Polynomial1D.hpp |  4 ++--
 tests/test_Polynomial1D.cpp   | 11 ++++++++++-
 2 files changed, 12 insertions(+), 3 deletions(-)

diff --git a/src/analysis/Polynomial1D.hpp b/src/analysis/Polynomial1D.hpp
index 20d4cf90a..894ffa8d8 100644
--- a/src/analysis/Polynomial1D.hpp
+++ b/src/analysis/Polynomial1D.hpp
@@ -202,14 +202,14 @@ class [[nodiscard]] Polynomial1D
   PUGS_INLINE
   double& coefficient(const size_t i)
   {
-    Assert(i < m_coefficients.size());
+    Assert(i < m_coefficients.size(), "invalid coefficient number");
     return m_coefficients[i];
   }
 
   PUGS_INLINE
   const double& coefficient(const size_t i) const
   {
-    Assert(i < m_coefficients.size());
+    Assert(i < m_coefficients.size(), "invalid coefficient number");
     return m_coefficients[i];
   }
 
diff --git a/tests/test_Polynomial1D.cpp b/tests/test_Polynomial1D.cpp
index 110cfadf7..cecd35b36 100644
--- a/tests/test_Polynomial1D.cpp
+++ b/tests/test_Polynomial1D.cpp
@@ -254,6 +254,15 @@ TEST_CASE("Polynomial1D", "[analysis]")
   }
 
 #ifndef NDEBUG
-  SECTION("checking for bounds validation") {}
+  SECTION("checking for bounds validation")
+  {
+    Polynomial1D p({-1, 0, 0, 1});
+    REQUIRE_THROWS_AS(p.coefficient(4), AssertError);
+
+    const Polynomial1D q({-1, 0, 0, 1});
+    REQUIRE_THROWS_AS(q.coefficient(4), AssertError);
+
+    REQUIRE_THROWS_AS(Polynomial1D{std::vector<double>{}}, AssertError);
+  }
 #endif   // NDEBUG
 }
-- 
GitLab