foxBMS - Unit Tests  1.6.0
The foxBMS Unit Tests API Documentation
test_os.c File Reference

Test of the os.c module. More...

#include "unity.h"
#include "Mockcan.h"
#include "Mockftask.h"
#include "Mockftask_cfg.h"
#include "Mockportmacro.h"
#include "Mockqueue.h"
#include "Mockrtc.h"
#include "Mocktask.h"
#include "can_cfg.h"
#include "can_cbs_tx_crash-dump.h"
#include "os.h"
#include "test_assert_helper.h"
#include <stdbool.h>
#include <stdint.h>
Include dependency graph for test_os.c:

Go to the source code of this file.

Functions

void setUp (void)
 
void tearDown (void)
 
void testOSTaskInitCallsFTSKFunctions (void)
 
void testOS_IncrementTimer (void)
 
void testOS_TriggerTimerOverflow (void)
 
void testOS_CheckTimeHasPassedNoTime (void)
 
void testOS_CheckTimeHasPassed1ms (void)
 
void testOS_CheckTimeHasPassedTimestampAtMax1ms (void)
 
void testOS_CheckTimeHasPassedTimestampAroundMax1ms (void)
 
void testOS_CheckTimeHasPassedUINT32_MAXms (void)
 
void testOS_CheckTimeHasPassedSelfTestSuccessful (void)
 

Variables

static OS_TIMER_stest_timer
 
OS_QUEUE ftsk_imdCanDataQueue = NULL_PTR
 

Detailed Description

Test of the os.c module.

SPDX-License-Identifier: BSD-3-Clause

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
  3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

We kindly request you to use one or more of the following phrases to refer to foxBMS in your hardware, software, documentation or advertising materials:

  • ″This product uses parts of foxBMS®″
  • ″This product includes parts of foxBMS®″
  • ″This product is derived from foxBMS®″
Author
foxBMS Team
Date
2020-03-13 (date of creation)
Updated
2023-10-12 (date of last update)
Version
v1.6.0
Prefix
OS

Definition in file test_os.c.

Function Documentation

◆ setUp()

void setUp ( void  )

Definition at line 91 of file test_os.c.

Here is the call graph for this function:

◆ tearDown()

void tearDown ( void  )

Definition at line 95 of file test_os.c.

◆ testOS_CheckTimeHasPassed1ms()

void testOS_CheckTimeHasPassed1ms ( void  )

check for when 1ms shall pass with OS_CheckTimeHasPassed()

Definition at line 267 of file test_os.c.

Here is the call graph for this function:

◆ testOS_CheckTimeHasPassedNoTime()

void testOS_CheckTimeHasPassedNoTime ( void  )

when no time shall pass, the result of OS_CheckTimeHasPassed() will always be true, independent of the time

Definition at line 246 of file test_os.c.

Here is the call graph for this function:

◆ testOS_CheckTimeHasPassedSelfTestSuccessful()

void testOS_CheckTimeHasPassedSelfTestSuccessful ( void  )

check that the selftest passes

Definition at line 304 of file test_os.c.

Here is the call graph for this function:

◆ testOS_CheckTimeHasPassedTimestampAroundMax1ms()

void testOS_CheckTimeHasPassedTimestampAroundMax1ms ( void  )

check behavior around the wraparound of the timestamp for when 1ms shall pass with OS_CheckTimeHasPassed()

Definition at line 285 of file test_os.c.

Here is the call graph for this function:

◆ testOS_CheckTimeHasPassedTimestampAtMax1ms()

void testOS_CheckTimeHasPassedTimestampAtMax1ms ( void  )

check behavior before the wraparound of the timestamp for when 1ms shall pass with OS_CheckTimeHasPassed()

Definition at line 276 of file test_os.c.

Here is the call graph for this function:

◆ testOS_CheckTimeHasPassedUINT32_MAXms()

void testOS_CheckTimeHasPassedUINT32_MAXms ( void  )

check behavior for the largest time step possible in OS_CheckTimeHasPassed()

Definition at line 291 of file test_os.c.

Here is the call graph for this function:

◆ testOS_IncrementTimer()

void testOS_IncrementTimer ( void  )

Definition at line 109 of file test_os.c.

Here is the call graph for this function:

◆ testOS_TriggerTimerOverflow()

void testOS_TriggerTimerOverflow ( void  )

Definition at line 220 of file test_os.c.

Here is the call graph for this function:

◆ testOSTaskInitCallsFTSKFunctions()

void testOSTaskInitCallsFTSKFunctions ( void  )

Definition at line 100 of file test_os.c.

Here is the call graph for this function:

Variable Documentation

◆ ftsk_imdCanDataQueue

OS_QUEUE ftsk_imdCanDataQueue = NULL_PTR

queue for CAN based IMD devices

Definition at line 88 of file test_os.c.

◆ test_timer

OS_TIMER_s* test_timer
static

Definition at line 87 of file test_os.c.