2019-12-17 06:06:29 -08:00
|
|
|
/*
|
|
|
|
* @author Matthew Kennedy, (c) 2019
|
|
|
|
*/
|
|
|
|
|
2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2019-12-17 06:06:29 -08:00
|
|
|
#include "resistance_func.h"
|
|
|
|
|
|
|
|
TEST(resistance, OutOfRange)
|
|
|
|
{
|
|
|
|
ResistanceFunc f;
|
2023-06-10 13:36:03 -07:00
|
|
|
f.configure(5, 10000, false);
|
2019-12-17 06:06:29 -08:00
|
|
|
|
|
|
|
// Something in the middle should be valid
|
|
|
|
{
|
|
|
|
auto r = f.convert(2.5f);
|
|
|
|
ASSERT_TRUE(r.Valid);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Something near 0.05v should be valid
|
|
|
|
{
|
|
|
|
auto r = f.convert(0.051f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Something just under 0.05v should be invalid
|
|
|
|
{
|
|
|
|
auto r = f.convert(0.049f);
|
|
|
|
EXPECT_FALSE(r.Valid);
|
|
|
|
}
|
|
|
|
|
2020-04-07 13:07:09 -07:00
|
|
|
// Something near 0.98 * 5v should be valid
|
2019-12-17 06:06:29 -08:00
|
|
|
{
|
2020-04-07 13:07:09 -07:00
|
|
|
auto r = f.convert(0.97f * 5);
|
2019-12-17 06:06:29 -08:00
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
}
|
|
|
|
|
2020-04-07 13:07:09 -07:00
|
|
|
// Something just above 0.98 * 5v should be invalid
|
2019-12-17 06:06:29 -08:00
|
|
|
{
|
2020-04-07 13:07:09 -07:00
|
|
|
auto r = f.convert(0.99f * 5);
|
2019-12-17 06:06:29 -08:00
|
|
|
EXPECT_FALSE(r.Valid);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(resistance, InRange)
|
|
|
|
{
|
|
|
|
ResistanceFunc f;
|
2023-06-10 13:36:03 -07:00
|
|
|
f.configure(5, 10000, false);
|
2019-12-17 06:06:29 -08:00
|
|
|
|
|
|
|
// 1 volt -> 2500 ohms low side
|
|
|
|
{
|
|
|
|
auto r = f.convert(1.0f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(r.Value, 2500);
|
|
|
|
}
|
|
|
|
|
|
|
|
// 2 volt -> 6666.667 ohm ohms low side
|
|
|
|
// 20k/3 gives us an exact result
|
|
|
|
{
|
|
|
|
auto r = f.convert(2.0f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(r.Value, 20000.0f / 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
// 3 volt -> 15000 ohms low side
|
|
|
|
{
|
|
|
|
auto r = f.convert(3.0f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(r.Value, 15000);
|
|
|
|
}
|
|
|
|
|
|
|
|
// 4 volt -> 40000 ohms low side
|
|
|
|
{
|
|
|
|
auto r = f.convert(4.0f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(r.Value, 40000);
|
|
|
|
}
|
|
|
|
}
|
2023-06-10 13:36:03 -07:00
|
|
|
|
|
|
|
TEST(resistance, PulldownMode)
|
|
|
|
{
|
|
|
|
ResistanceFunc f;
|
|
|
|
f.configure(5, 10000, true);
|
|
|
|
|
|
|
|
// 4 volt -> 2500 ohms high side
|
|
|
|
{
|
|
|
|
auto r = f.convert(4.0f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(r.Value, 2500);
|
|
|
|
}
|
|
|
|
|
|
|
|
// 3 volt -> 6666.667 ohm ohms high side
|
|
|
|
// 20k/3 gives us an exact result
|
|
|
|
{
|
|
|
|
auto r = f.convert(3.0f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(r.Value, 20000.0f / 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
// 2 volt -> 15000 ohms high side
|
|
|
|
{
|
|
|
|
auto r = f.convert(2.0f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(r.Value, 15000);
|
|
|
|
}
|
|
|
|
|
|
|
|
// 1 volt -> 40000 ohms high side
|
|
|
|
{
|
|
|
|
auto r = f.convert(1.0f);
|
|
|
|
EXPECT_TRUE(r.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(r.Value, 40000);
|
|
|
|
}
|
|
|
|
}
|