Base: add unit tests
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
#include "gtest/gtest.h"
|
||||
#include <Base/Tools.h>
|
||||
#include <bitset>
|
||||
|
||||
// NOLINTBEGIN(cppcoreguidelines-*,readability-*)
|
||||
TEST(BaseToolsSuite, TestUniqueName1)
|
||||
{
|
||||
EXPECT_EQ(Base::Tools::getUniqueName("Body", {}), "Body");
|
||||
@@ -41,6 +43,99 @@ TEST(BaseToolsSuite, TestUniqueName8)
|
||||
EXPECT_EQ(Base::Tools::getUniqueName("Body12345", {"Body"}, 3), "Body12346");
|
||||
}
|
||||
|
||||
TEST(Tools, TestIota)
|
||||
{
|
||||
Base::iotaGen<int> iota(1);
|
||||
std::vector<int> vec(5);
|
||||
std::generate(vec.begin(), vec.end(), iota);
|
||||
std::vector<int> out = {1, 2, 3, 4, 5};
|
||||
EXPECT_EQ(vec, out);
|
||||
}
|
||||
|
||||
TEST(Tools, TestClamp)
|
||||
{
|
||||
EXPECT_EQ(Base::clamp<int>(2, 1, 3), 2);
|
||||
EXPECT_EQ(Base::clamp<int>(4, 1, 3), 3);
|
||||
EXPECT_EQ(Base::clamp<int>(0, 1, 3), 1);
|
||||
|
||||
EXPECT_DOUBLE_EQ(Base::clamp<double>(2, 1.5, 3.1), 2.0);
|
||||
EXPECT_DOUBLE_EQ(Base::clamp<double>(4, 1.5, 3.1), 3.1);
|
||||
EXPECT_DOUBLE_EQ(Base::clamp<double>(0, 1.5, 3.1), 1.5);
|
||||
}
|
||||
|
||||
TEST(Tools, TestSignum)
|
||||
{
|
||||
EXPECT_EQ(Base::sgn<int>(0), 0);
|
||||
EXPECT_EQ(Base::sgn<int>(2), 1);
|
||||
EXPECT_EQ(Base::sgn<int>(-2), -1);
|
||||
EXPECT_DOUBLE_EQ(Base::sgn<double>(0.1), 1.0);
|
||||
EXPECT_DOUBLE_EQ(Base::sgn<double>(2.0), 1.0);
|
||||
EXPECT_DOUBLE_EQ(Base::sgn<double>(-2.0), -1.0);
|
||||
EXPECT_DOUBLE_EQ(Base::sgn<double>(0.0), 0.0);
|
||||
}
|
||||
|
||||
TEST(Tools, TestRadian)
|
||||
{
|
||||
EXPECT_EQ(Base::toRadians<int>(90), 1);
|
||||
EXPECT_DOUBLE_EQ(Base::toRadians<double>(180), M_PI);
|
||||
EXPECT_DOUBLE_EQ(Base::toRadians<double>(90.0), M_PI / 2.0);
|
||||
EXPECT_DOUBLE_EQ(Base::toRadians<double>(0.0), 0.0);
|
||||
}
|
||||
|
||||
TEST(Tools, TestDegree)
|
||||
{
|
||||
EXPECT_EQ(Base::toDegrees<int>(3), 171);
|
||||
EXPECT_DOUBLE_EQ(Base::toDegrees<double>(M_PI), 180.0);
|
||||
EXPECT_DOUBLE_EQ(Base::toDegrees<double>(M_PI / 2.0), 90.0);
|
||||
EXPECT_DOUBLE_EQ(Base::toDegrees<double>(0.0), 0.0);
|
||||
}
|
||||
|
||||
TEST(Tools, TestToggle)
|
||||
{
|
||||
bool value = true;
|
||||
{
|
||||
Base::FlagToggler<bool> toggle(value);
|
||||
EXPECT_EQ(value, false);
|
||||
}
|
||||
EXPECT_EQ(value, true);
|
||||
}
|
||||
|
||||
TEST(Tools, TestStateLocker)
|
||||
{
|
||||
bool value = true;
|
||||
{
|
||||
Base::StateLocker lock(value);
|
||||
EXPECT_EQ(value, true);
|
||||
}
|
||||
EXPECT_EQ(value, true);
|
||||
{
|
||||
Base::StateLocker lock(value, false);
|
||||
EXPECT_EQ(value, false);
|
||||
}
|
||||
EXPECT_EQ(value, true);
|
||||
}
|
||||
|
||||
TEST(Tools, TestBitsetLocker)
|
||||
{
|
||||
std::bitset<8> value;
|
||||
{
|
||||
Base::BitsetLocker<decltype(value)> lock(value, 1);
|
||||
EXPECT_EQ(value.test(1), true);
|
||||
}
|
||||
EXPECT_EQ(value.test(1), false);
|
||||
{
|
||||
Base::BitsetLocker<decltype(value)> lock(value, 2, false);
|
||||
EXPECT_EQ(value.test(2), false);
|
||||
}
|
||||
EXPECT_EQ(value.test(2), false);
|
||||
|
||||
value.set(3, true);
|
||||
{
|
||||
Base::BitsetLocker<decltype(value)> lock(value, 3, false);
|
||||
EXPECT_EQ(value.test(3), false);
|
||||
}
|
||||
EXPECT_EQ(value.test(3), true);
|
||||
}
|
||||
TEST(BaseToolsSuite, TestQuote)
|
||||
{
|
||||
EXPECT_EQ(Base::Tools::quoted("Test"), "\"Test\"");
|
||||
@@ -50,3 +145,4 @@ TEST(BaseToolsSuite, TestJoinList)
|
||||
{
|
||||
EXPECT_EQ(Base::Tools::joinList({"AB", "CD"}), "AB, CD, ");
|
||||
}
|
||||
// NOLINTEND(cppcoreguidelines-*,readability-*)
|
||||
|
||||
Reference in New Issue
Block a user