foxBMS - Unit Tests  1.6.0
The foxBMS Unit Tests API Documentation
test_can_cbs_tx_pack-state-estimation.c
Go to the documentation of this file.
1 /**
2  *
3  * @copyright © 2010 - 2023, 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_can_cbs_tx_pack-state-estimation.c
44  * @author foxBMS Team
45  * @date 2021-07-27 (date of creation)
46  * @updated 2023-10-12 (date of last update)
47  * @version v1.6.0
48  * @ingroup UNIT_TEST_IMPLEMENTATION
49  * @prefix TEST
50  *
51  * @brief Tests for the CAN driver callbacks
52  *
53  */
54 
55 /*========== Includes =======================================================*/
56 #include "unity.h"
57 #include "Mockbms.h"
58 #include "Mockcan.h"
59 #include "Mockdatabase.h"
60 #include "Mockdiag.h"
61 #include "Mockfoxmath.h"
62 #include "Mockimd.h"
63 #include "Mockos.h"
64 
65 #include "database_cfg.h"
66 
67 #include "can_cbs_tx.h"
69 #include "can_helper.h"
70 
71 #include <stdbool.h>
72 
73 /*========== Unit Testing Framework Directives ==============================*/
74 TEST_SOURCE_FILE("can_cbs_tx_pack-state-estimation.c")
75 
76 TEST_INCLUDE_PATH("../../src/app/application/bms")
77 TEST_INCLUDE_PATH("../../src/app/driver/can")
78 TEST_INCLUDE_PATH("../../src/app/driver/can/cbs")
79 TEST_INCLUDE_PATH("../../src/app/driver/can/cbs/tx")
80 TEST_INCLUDE_PATH("../../src/app/driver/config")
81 TEST_INCLUDE_PATH("../../src/app/driver/contactor")
82 TEST_INCLUDE_PATH("../../src/app/driver/foxmath")
83 TEST_INCLUDE_PATH("../../src/app/driver/imd")
84 TEST_INCLUDE_PATH("../../src/app/driver/sps")
85 TEST_INCLUDE_PATH("../../src/app/engine/diag")
86 TEST_INCLUDE_PATH("../../src/app/task/config")
87 
88 /*========== Definitions and Implementations for Unit Test ==================*/
89 
107 
109 
112  .pTableCellVoltage = &can_tableCellVoltages,
113  .pTableCellTemperature = &can_tableTemperatures,
114  .pTableMinMax = &can_tableMinimumMaximumValues,
115  .pTableCurrentSensor = &can_tableCurrentSensor,
116  .pTableOpenWire = &can_tableOpenWire,
117  .pTableStateRequest = &can_tableStateRequest,
118  .pTablePackValues = &can_tablePackValues,
119  .pTableSof = &can_tableSof,
120  .pTableSoc = &can_tableSoc,
121  .pTableSoe = &can_tableSoe,
122  .pTableErrorState = &can_tableErrorState,
123  .pTableInsulation = &can_tableInsulation,
124  .pTableMsl = &can_tableMslFlags,
125  .pTableRsl = &can_tableRslFlags,
126  .pTableMol = &can_tableMolFlags,
127  .pTableAerosolSensor = &can_tableAerosolSensor,
128 };
129 
130 /*========== Setup and Teardown =============================================*/
131 void setUp(void) {
132 }
133 
134 void tearDown(void) {
135 }
136 
137 /*========== Test Cases =====================================================*/
139  CAN_MESSAGE_PROPERTIES_s testMessage = {
142  .dlc = 8u,
144  };
145  uint8_t data[8] = {0};
146 
147  for (uint8_t s = 0u; s < BS_NR_OF_STRINGS; s++) {
148  can_kShim.pTableSoc->minimumSoc_perc[s] = 71.2f;
149  can_kShim.pTableSoc->maximumSoc_perc[s] = 74.2f;
150  can_kShim.pTableSoe->minimumSoe_perc[s] = 74.6f;
151  can_kShim.pTableSoe->maximumSoe_perc[s] = 78.1f;
153  }
154 
155  DATA_Read2DataBlocks_IgnoreAndReturn(0u);
156  /* System is currently charging */
157  BMS_GetBatterySystemState_IgnoreAndReturn(BMS_CHARGING);
158  /* All strings connected */
159  for (uint8_t s = 0; s < BS_NR_OF_STRINGS; s++) {
160  BMS_IsStringClosed_IgnoreAndReturn(true);
161  }
162  BMS_GetNumberOfConnectedStrings_IgnoreAndReturn(BS_NR_OF_STRINGS);
163  BMS_GetBatterySystemState_IgnoreAndReturn(BMS_CHARGING);
164  BMS_GetNumberOfConnectedStrings_IgnoreAndReturn(BS_NR_OF_STRINGS);
165  BMS_GetNumberOfConnectedStrings_IgnoreAndReturn(BS_NR_OF_STRINGS);
166  BMS_GetNumberOfConnectedStrings_IgnoreAndReturn(BS_NR_OF_STRINGS);
167 
168  CANTX_PackStateEstimation(testMessage, data, NULL_PTR, &can_kShim);
169 
170  /** Values of:
171  * pack SOC: 74.2%
172  * pack SOE: 78.1%
173  * pack Energy: 19.2kWh
174  * pack SOH: 100.0%
175  */
176  TEST_ASSERT_EQUAL(0x73, data[0]);
177  TEST_ASSERT_EQUAL(0xED, data[1]);
178  TEST_ASSERT_EQUAL(0xE8, data[2]);
179  TEST_ASSERT_EQUAL(0x2F, data[3]);
180  TEST_ASSERT_EQUAL(0xA0, data[4]);
181  TEST_ASSERT_EQUAL(0x00, data[5]);
182  TEST_ASSERT_EQUAL(0x07, data[6]);
183  TEST_ASSERT_EQUAL(0x80, data[7]);
184 }
185 
187  CAN_MESSAGE_PROPERTIES_s testMessage = {
190  .dlc = 8u,
192  };
193 
194  uint8_t data[8] = {0};
195 
196  for (uint8_t s = 0u; s < BS_NR_OF_STRINGS; s++) {
197  can_kShim.pTableSoc->minimumSoc_perc[s] = 74.2f;
198  can_kShim.pTableSoc->maximumSoc_perc[s] = 78.2f;
199  can_kShim.pTableSoe->minimumSoe_perc[s] = 78.1f;
200  can_kShim.pTableSoe->maximumSoe_perc[s] = 83.1f;
202  }
203 
204  DATA_Read2DataBlocks_IgnoreAndReturn(0u);
205  /* System is currently charging */
206  BMS_GetBatterySystemState_IgnoreAndReturn(BMS_DISCHARGING);
207  /* All strings connected */
208  for (uint8_t s = 0; s < BS_NR_OF_STRINGS; s++) {
209  BMS_IsStringClosed_IgnoreAndReturn(true);
210  }
211  BMS_GetNumberOfConnectedStrings_IgnoreAndReturn(BS_NR_OF_STRINGS);
212  BMS_GetBatterySystemState_IgnoreAndReturn(BMS_DISCHARGING);
213  BMS_GetNumberOfConnectedStrings_IgnoreAndReturn(BS_NR_OF_STRINGS);
214  BMS_GetNumberOfConnectedStrings_IgnoreAndReturn(BS_NR_OF_STRINGS);
215  BMS_GetNumberOfConnectedStrings_IgnoreAndReturn(BS_NR_OF_STRINGS);
216 
217  CANTX_PackStateEstimation(testMessage, data, NULL_PTR, &can_kShim);
218 
219  /** Values of:
220  * pack SOC: 74.2%
221  * pack SOE: 78.1%
222  * pack Energy: 19.2kWh
223  * pack SOH: 100.0%
224  */
225  TEST_ASSERT_EQUAL(0x73, data[0]);
226  TEST_ASSERT_EQUAL(0xED, data[1]);
227  TEST_ASSERT_EQUAL(0xE8, data[2]);
228  TEST_ASSERT_EQUAL(0x2F, data[3]);
229  TEST_ASSERT_EQUAL(0xA0, data[4]);
230  TEST_ASSERT_EQUAL(0x00, data[5]);
231  TEST_ASSERT_EQUAL(0x07, data[6]);
232  TEST_ASSERT_EQUAL(0x80, data[7]);
233 }
#define BS_NR_OF_STRINGS
Number of parallel strings in the battery pack.
@ BMS_DISCHARGING
Definition: bms.h:74
@ BMS_CHARGING
Definition: bms.h:73
CAN callbacks header.
uint32_t CANTX_PackStateEstimation(CAN_MESSAGE_PROPERTIES_s message, uint8_t *pCanData, uint8_t *pMuxId, const CAN_SHIM_s *const kpkCanShim)
can tx callback function for state estimation values
Header for the driver for the CAN module.
#define CANTX_PACK_STATE_ESTIMATION_ID_TYPE
#define CANTX_PACK_STATE_ESTIMATION_ENDIANNESS
#define CANTX_PACK_STATE_ESTIMATION_ID
Headers for the helper functions for the CAN module.
Database configuration header.
@ DATA_BLOCK_ID_MIN_MAX
Definition: database_cfg.h:99
@ DATA_BLOCK_ID_SOE
Definition: database_cfg.h:109
@ DATA_BLOCK_ID_ERROR_STATE
Definition: database_cfg.h:95
@ DATA_BLOCK_ID_RSL_FLAG
Definition: database_cfg.h:106
@ DATA_BLOCK_ID_INSULATION_MONITORING
Definition: database_cfg.h:97
@ DATA_BLOCK_ID_STATE_REQUEST
Definition: database_cfg.h:112
@ DATA_BLOCK_ID_CELL_VOLTAGE
Definition: database_cfg.h:89
@ DATA_BLOCK_ID_CURRENT_SENSOR
Definition: database_cfg.h:93
@ DATA_BLOCK_ID_OPEN_WIRE_BASE
Definition: database_cfg.h:103
@ DATA_BLOCK_ID_SOF
Definition: database_cfg.h:110
@ DATA_BLOCK_ID_MSL_FLAG
Definition: database_cfg.h:102
@ DATA_BLOCK_ID_PACK_VALUES
Definition: database_cfg.h:105
@ DATA_BLOCK_ID_MOL_FLAG
Definition: database_cfg.h:100
@ DATA_BLOCK_ID_CELL_TEMPERATURE
Definition: database_cfg.h:86
@ DATA_BLOCK_ID_SOC
Definition: database_cfg.h:108
@ DATA_BLOCK_ID_AEROSOL_SENSOR
Definition: database_cfg.h:80
static DIAG_DIAGNOSIS_STATE_s diag
Definition: diag.c:71
#define NULL_PTR
Null pointer.
Definition: fstd_types.h:77
DATA_BLOCK_SOE_s * pTableSoe
Definition: can_cfg.h:191
OS_QUEUE * pQueueImd
Definition: can_cfg.h:178
DATA_BLOCK_SOC_s * pTableSoc
Definition: can_cfg.h:190
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:635
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:153
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:135
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:219
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:337
DATA_BLOCK_ID_e uniqueId
Definition: database_cfg.h:125
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:167
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:497
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:455
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:310
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:195
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:477
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:517
float_t minimumSoc_perc[BS_NR_OF_STRINGS]
Definition: database_cfg.h:519
float_t maximumSoc_perc[BS_NR_OF_STRINGS]
Definition: database_cfg.h:520
uint32_t minimumSoe_Wh[BS_NR_OF_STRINGS]
Definition: database_cfg.h:545
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:539
float_t maximumSoe_perc[BS_NR_OF_STRINGS]
Definition: database_cfg.h:542
float_t minimumSoe_perc[BS_NR_OF_STRINGS]
Definition: database_cfg.h:541
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:427
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:553
static DATA_BLOCK_CELL_VOLTAGE_s can_tableCellVoltages
static DATA_BLOCK_MSL_FLAG_s can_tableMslFlags
static DATA_BLOCK_MIN_MAX_s can_tableMinimumMaximumValues
static DATA_BLOCK_OPEN_WIRE_s can_tableOpenWire
static DATA_BLOCK_PACK_VALUES_s can_tablePackValues
void testCAN_TxStateEstimationDischarging(void)
static DATA_BLOCK_MOL_FLAG_s can_tableMolFlags
static DATA_BLOCK_AEROSOL_SENSOR_s can_tableAerosolSensor
static DATA_BLOCK_ERROR_STATE_s can_tableErrorState
void testCAN_TxStateEstimationCharging(void)
const CAN_SHIM_s can_kShim
static DATA_BLOCK_CELL_TEMPERATURE_s can_tableTemperatures
static DATA_BLOCK_SOE_s can_tableSoe
static DATA_BLOCK_RSL_FLAG_s can_tableRslFlags
static DATA_BLOCK_STATE_REQUEST_s can_tableStateRequest
static DATA_BLOCK_INSULATION_MONITORING_s can_tableInsulation
static DATA_BLOCK_SOF_s can_tableSof
static DATA_BLOCK_SOC_s can_tableSoc
static DATA_BLOCK_CURRENT_SENSOR_s can_tableCurrentSensor