Updated tests for the the port a handler function.

This commit is contained in:
jakeg00dwin 2024-10-18 21:44:42 -07:00
parent 3caa74f642
commit 0e7deea6e7
1 changed files with 38 additions and 16 deletions

View File

@ -18,7 +18,6 @@ extern "C"
#include <iotn404.h> //ATtiny404 header fille.
#include "load.h"
#include "MockADC.h"
#include "MockADC.h"
}
TEST_GROUP(test_load)
@ -55,15 +54,25 @@ void setup_adc_expectations(uint8_t adc_pin)
mock().expectOneCall("ADC_Disable");
}
void expect_porta_disabled(uint8_t load_pin)
void expect_porta_disabled(uint8_t load_pin, bool output_level)
{
mock().expectOneCall("RegEdit_IsBitSet")
.withPointerParameter("reg", (void *) &PORTA.OUT)
.withUnsignedIntParameter("bit_num", load_pin)
.andReturnValue(output_level);
mock().expectOneCall("RegEdit_ClearBit")
.withPointerParameter("reg", (void *) &PORTA.OUT)
.withUnsignedIntParameter("bit_num", load_pin);
}
void expect_porta_enabled(uint8_t load_pin)
void expect_porta_enabled(uint8_t load_pin, bool output_level)
{
mock().expectOneCall("RegEdit_IsBitSet")
.withPointerParameter("reg", (void *) &PORTA.OUT)
.withUnsignedIntParameter("bit_num", load_pin)
.andReturnValue(output_level);
mock().expectOneCall("RegEdit_SetBit")
.withPointerParameter("reg", (void *) &PORTA.DIR)
.withUnsignedIntParameter("bit_num", load_pin);
@ -97,7 +106,7 @@ TEST(test_load, PortAHandlerDisabledHigh)
MockADC_PushValue(HIGHTHRESH);
setup_adc_expectations(adc_pin);
expect_porta_disabled(load_pin);
expect_porta_disabled(load_pin, true);
Load_HandleLoadPortA(adc_pin, load_pin);
}
@ -107,41 +116,54 @@ TEST(test_load, PortAHandlerDisabledLow)
MockADC_PushValue(LOWTHRESH);
setup_adc_expectations(adc_pin);
expect_porta_disabled(load_pin);
expect_porta_disabled(load_pin, false);
Load_HandleLoadPortA(adc_pin, load_pin);
}
TEST(test_load, PortAHandlerEnabledBelowTarget)
TEST(test_load, PortAHandlerEnabledRisingEdgeLO)
{
MockADC_PushValue(HYSTERESIS - 1);
//Start from the rising edge.
MockADC_PushValue(HYSTERESIS_LO - 1);
setup_adc_expectations(adc_pin);
expect_porta_enabled(load_pin);
expect_porta_enabled(load_pin, false);
Load_HandleLoadPortA(adc_pin, load_pin);
}
TEST(test_load, PortAHandlerEnabledRisingEdgeHI)
{
//Start from the rising edge above lo.
MockADC_PushValue(HYSTERESIS_HI - 1);
setup_adc_expectations(adc_pin);
expect_porta_enabled(load_pin, true);
Load_HandleLoadPortA(adc_pin, load_pin);
}
TEST(test_load, PortAHandlerDisabledAboveTarget)
{
MockADC_PushValue(HYSTERESIS);
MockADC_PushValue(HYSTERESIS_HI + 1);
setup_adc_expectations(adc_pin);
expect_porta_disabled(load_pin);
expect_porta_disabled(load_pin, true);
Load_HandleLoadPortA(adc_pin, load_pin);
}
TEST(test_load, PortAHandlerDisablesUntilPoweReset)
{
MockADC_PushValue(HYSTERESIS - 1);
MockADC_PushValue(HYSTERESIS_HI - 1);
MockADC_PushValue(HIGHTHRESH);
setup_adc_expectations(adc_pin);
expect_porta_disabled(load_pin);
expect_porta_disabled(load_pin, true);
setup_adc_expectations(adc_pin);
expect_porta_disabled(load_pin);
expect_porta_disabled(load_pin, false);
Load_HandleLoadPortA(adc_pin, load_pin);
Load_HandleLoadPortA(adc_pin, load_pin);
@ -171,7 +193,7 @@ TEST(test_load, PortBHandlerDisabledLow)
TEST(test_load, PortBHandlerEnabledBelowTarget)
{
MockADC_PushValue(HYSTERESIS - 1);
MockADC_PushValue(HYSTERESIS_HI - 1);
setup_adc_expectations(adc_pin);
expect_portb_enabled(load_pin);
@ -182,7 +204,7 @@ TEST(test_load, PortBHandlerEnabledBelowTarget)
TEST(test_load, PortBHandlerDisabledAboveTarget)
{
MockADC_PushValue(HYSTERESIS);
MockADC_PushValue(HYSTERESIS_HI);
setup_adc_expectations(adc_pin);
expect_portb_disabled(load_pin);
@ -192,7 +214,7 @@ TEST(test_load, PortBHandlerDisabledAboveTarget)
TEST(test_load, PortBHandlerDisablesUntilPoweReset)
{
MockADC_PushValue(HYSTERESIS - 1);
MockADC_PushValue(HYSTERESIS_HI - 1);
MockADC_PushValue(HIGHTHRESH);
setup_adc_expectations(adc_pin);