foxBMS - Unit Tests  1.3.0
The foxBMS Unit Tests API Documentation
test_bal_cfg.c
Go to the documentation of this file.
1 /**
2  *
3  * @copyright © 2010 - 2022, Fraunhofer-Gesellschaft zur Foerderung der angewandten Forschung e.V.
4  * All rights reserved.
5  *
6  * SPDX-License-Identifier: BSD-3-Clause
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions are met:
10  *
11  * 1. Redistributions of source code must retain the above copyright notice, this
12  * list of conditions and the following disclaimer.
13  *
14  * 2. Redistributions in binary form must reproduce the above copyright notice,
15  * this list of conditions and the following disclaimer in the documentation
16  * and/or other materials provided with the distribution.
17  *
18  * 3. Neither the name of the copyright holder nor the names of its
19  * contributors may be used to endorse or promote products derived from
20  * this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
25  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
26  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
28  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  *
33  * We kindly request you to use one or more of the following phrases to refer to
34  * foxBMS in your hardware, software, documentation or advertising materials:
35  *
36  * - ″This product uses parts of foxBMS®″
37  * - ″This product includes parts of foxBMS®″
38  * - ″This product is derived from foxBMS®″
39  *
40  */
41 
42 /**
43  * @file test_bal_cfg.c
44  * @author foxBMS Team
45  * @date 2022-02-26 (date of creation)
46  * @updated 2022-05-30 (date of last update)
47  * @version v1.3.0
48  * @ingroup UNIT_TEST_IMPLEMENTATION
49  * @prefix TEST
50  *
51  * @brief Test for the balancing configuration
52  *
53  */
54 
55 /*========== Includes =======================================================*/
56 #include "unity.h"
57 #include "Mockos.h"
58 
59 #include "bal_cfg.h"
60 
61 /*========== Definitions and Implementations for Unit Test ==================*/
62 
63 /*========== Setup and Teardown =============================================*/
64 void setUp(void) {
65  OS_EnterTaskCritical_Ignore();
66  OS_ExitTaskCritical_Ignore();
68 }
69 
70 void tearDown(void) {
71 }
72 
73 /*========== Test Cases =====================================================*/
74 
75 /** test #BAL_SetBalancingThreshold() and #BAL_GetBalancingThreshold_mV() */
77  OS_EnterTaskCritical_Ignore();
78  OS_ExitTaskCritical_Ignore();
79  int32_t expectedThreshold_mV = 50;
80  BAL_SetBalancingThreshold(expectedThreshold_mV);
81  TEST_ASSERT_EQUAL(expectedThreshold_mV, BAL_GetBalancingThreshold_mV());
82 
83  expectedThreshold_mV = 150;
84  BAL_SetBalancingThreshold(expectedThreshold_mV);
85  TEST_ASSERT_EQUAL(expectedThreshold_mV, BAL_GetBalancingThreshold_mV());
86 }
87 
88 /** test #BAL_SetBalancingThreshold() with maximum values */
90  OS_EnterTaskCritical_Ignore();
91  OS_ExitTaskCritical_Ignore();
92  int32_t expectedThreshold_mV = BAL_MAXIMUM_THRESHOLD_mV + 1;
93  BAL_SetBalancingThreshold(expectedThreshold_mV);
94  TEST_ASSERT_EQUAL(expectedThreshold_mV - 1, BAL_GetBalancingThreshold_mV());
95 }
96 
97 /** test #BAL_SetBalancingThreshold() with minimum values */
99  OS_EnterTaskCritical_Ignore();
100  OS_ExitTaskCritical_Ignore();
101  int32_t expectedThreshold_mV = BAL_MINIMUM_THRESHOLD_mV - 1;
102  BAL_SetBalancingThreshold(expectedThreshold_mV);
103  TEST_ASSERT_EQUAL(expectedThreshold_mV + 1, BAL_GetBalancingThreshold_mV());
104 }
void BAL_SetBalancingThreshold(int32_t threshold_mV)
set balancing threshold
Definition: bal_cfg.c:73
int32_t BAL_GetBalancingThreshold_mV(void)
get balancing threshold
Definition: bal_cfg.c:86
Header for the configuration for the driver for balancing.
#define BAL_MAXIMUM_THRESHOLD_mV
Definition: bal_cfg.h:77
#define BAL_DEFAULT_THRESHOLD_mV
Definition: bal_cfg.h:74
#define BAL_MINIMUM_THRESHOLD_mV
Definition: bal_cfg.h:80
void testSetAndGetBalancingThreshold(void)
Definition: test_bal_cfg.c:76
void testSetBalancingThresholdMaxValue(void)
Definition: test_bal_cfg.c:89
void setUp(void)
Definition: test_bal_cfg.c:64
void tearDown(void)
Definition: test_bal_cfg.c:70
void testSetBalancingThresholdMinValue(void)
Definition: test_bal_cfg.c:98