Skip to content

Commit

Permalink
Fix #812 Add Perf API functional tests
Browse files Browse the repository at this point in the history
and add Perf Trigger and Perf Start commands to functional tests workflow
  • Loading branch information
pepepr08 committed Aug 11, 2021
1 parent eb9c523 commit ffe7df7
Show file tree
Hide file tree
Showing 5 changed files with 72 additions and 0 deletions.
3 changes: 3 additions & 0 deletions .github/workflows/functional-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -63,10 +63,13 @@ jobs:
- name: List cpu1
run: ls build/exe/cpu1/

# Run cFS, send commands to set perf trigger and start perf data, and run functional tests
- name: Run cFS
run: |
./core-cpu1 &
sleep 10
../host/cmdUtil --pktid=0x1806 --cmdcode=17 --endian=LE --uint32=3 --uint32=0x40000000 &
../host/cmdUtil --pktid=0x1806 --cmdcode=14 --endian=LE --uint32=2 &
../host/cmdUtil --pktid=0x1806 --cmdcode=4 --endian=LE --string="20:CFE_TEST_APP" --string="20:CFE_TestMain" --string="64:cfe_testcase" --uint32=16384 --uint8=0 --uint8=0 --uint16=100 &
sleep 30
Expand Down
1 change: 1 addition & 0 deletions modules/cfe_testcase/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ add_cfe_app(cfe_testcase
src/es_cds_test.c
src/es_counter_test.c
src/es_misc_test.c
src/es_perf_test.c
src/es_mempool_test.c
src/es_resource_id_test.c
src/evs_filters_test.c
Expand Down
1 change: 1 addition & 0 deletions modules/cfe_testcase/src/cfe_test.c
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,7 @@ void CFE_TestMain(void)
ESMemPoolTestSetup();
ESMiscTestSetup();
ESResourceIDTestSetup();
ESPerfTestSetup();
ESTaskTestSetup();
EVSFiltersTestSetup();
EVSSendTestSetup();
Expand Down
1 change: 1 addition & 0 deletions modules/cfe_testcase/src/cfe_test.h
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,7 @@ void ESInfoTestSetup(void);
void ESMemPoolTestSetup(void);
void ESMiscTestSetup(void);
void ESResourceIDTestSetup(void);
void ESPerfTestSetup(void);
void ESTaskTestSetup(void);
void EVSFiltersTestSetup(void);
void EVSSendTestSetup(void);
Expand Down
66 changes: 66 additions & 0 deletions modules/cfe_testcase/src/es_perf_test.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
/*************************************************************************
**
** GSC-18128-1, "Core Flight Executive Version 6.7"
**
** Copyright (c) 2006-2019 United States Government as represented by
** the Administrator of the National Aeronautics and Space Administration.
** All Rights Reserved.
**
** Licensed under the Apache License, Version 2.0 (the "License");
** you may not use this file except in compliance with the License.
** You may obtain a copy of the License at
**
** http://www.apache.org/licenses/LICENSE-2.0
**
** Unless required by applicable law or agreed to in writing, software
** distributed under the License is distributed on an "AS IS" BASIS,
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
** See the License for the specific language governing permissions and
** limitations under the License.
**
** File: es_perf_test.c
**
** Purpose:
** Functional test of ES Performance APIs
**
*************************************************************************/

/*
* Includes
*/

#include "cfe_test.h"

void TestPerfLogApi(void)
{
UtPrintf("Testing: CFE_ES_PerfLogEntry");
UtAssert_VOIDCALL(CFE_ES_PerfLogEntry(0));
UtAssert_VOIDCALL(CFE_ES_PerfLogEntry(CFE_MISSION_ES_PERF_MAX_IDS - 1));
UtAssert_VOIDCALL(CFE_ES_PerfLogEntry(CFE_MISSION_ES_PERF_MAX_IDS));

UtPrintf("Testing: CFE_ES_PerfLogExit");
UtAssert_VOIDCALL(CFE_ES_PerfLogExit(0));
UtAssert_VOIDCALL(CFE_ES_PerfLogExit(CFE_MISSION_ES_PERF_MAX_IDS - 1));
UtAssert_VOIDCALL(CFE_ES_PerfLogExit(CFE_MISSION_ES_PERF_MAX_IDS));

UtPrintf("Testing: CFE_ES_PerfLogAdd");
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(0, 0));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(0, 1));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(0, 0xFFFFFFFF));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(CFE_MISSION_ES_PERF_MAX_IDS - 1, 0));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(CFE_MISSION_ES_PERF_MAX_IDS - 1, 1));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(CFE_MISSION_ES_PERF_MAX_IDS - 1, 0xFFFFFFFF));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(CFE_MISSION_ES_PERF_MAX_IDS, 0));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(CFE_MISSION_ES_PERF_MAX_IDS, 1));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(CFE_MISSION_ES_PERF_MAX_IDS, 0xFFFFFFFF));

/* This commands should trigger and stop perf data (based on value commanded in functional test) */
UtPrintf("Testing: CFE_ES_PerfLogAdd Triggered");
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(126, 0));
UtAssert_VOIDCALL(CFE_ES_PerfLogAdd(126, 1));
}

void ESPerfTestSetup(void)
{
UtTest_Add(TestPerfLogApi, NULL, NULL, "Test Performance API");
}

0 comments on commit ffe7df7

Please sign in to comment.