Skip to content

Commit

Permalink
Update CI workflow for coverage and manifest check (#170)
Browse files Browse the repository at this point in the history
* Update CI workflow for coverage and manifest check
* Update line and branch coverage min to 100%
* Update github action version
  • Loading branch information
chinglee-iot authored May 22, 2024
1 parent aff376d commit d2fd754
Show file tree
Hide file tree
Showing 4 changed files with 74 additions and 14 deletions.
32 changes: 20 additions & 12 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Clone This Repo
uses: actions/checkout@v3
uses: actions/checkout@v4
- env:
stepName: Build Unit Tests
run: |
Expand Down Expand Up @@ -57,11 +57,13 @@ jobs:
uses: FreeRTOS/CI-CD-Github-Actions/coverage-cop@main
with:
coverage-file: ./build/coverage.info
branch-coverage-min: 100
line-coverage-min: 100

complexity:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
- name: Check complexity - Common
uses: FreeRTOS/CI-CD-Github-Actions/complexity@main
with:
Expand All @@ -70,7 +72,7 @@ jobs:
doxygen:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
- name: Run doxygen build
uses: FreeRTOS/CI-CD-Github-Actions/doxygen@main
with:
Expand All @@ -80,7 +82,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Clone This Repo
uses: actions/checkout@v3
uses: actions/checkout@v4
- name: Run spellings check
uses: FreeRTOS/CI-CD-Github-Actions/spellings@main
with:
Expand All @@ -89,7 +91,7 @@ jobs:
formatting:
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
- name: Check formatting
uses: FreeRTOS/CI-CD-Github-Actions/formatting@main
with:
Expand All @@ -98,9 +100,9 @@ jobs:
git-secrets:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
- name: Checkout awslabs/git-secrets
uses: actions/checkout@v3
uses: actions/checkout@v4
with:
repository: awslabs/git-secrets
ref: master
Expand All @@ -115,11 +117,11 @@ jobs:
memory_statistics:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
with:
submodules: "recursive"
- name: Install Python3
uses: actions/setup-python@v3
uses: actions/setup-python@v5
with:
python-version: "3.11.0"
- name: Measure sizes
Expand All @@ -131,7 +133,7 @@ jobs:
link-verifier:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
- name: Check Links
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
Expand All @@ -140,18 +142,24 @@ jobs:
verify-manifest:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4
with:
submodules: true
fetch-depth: 0

# At time of writing the gitmodules are set not to pull
# Even when using fetch submodules. Need to run this command
# To force it to grab them.
- name: Perform Recursive Clone
shell: bash
run: git submodule update --checkout --init --recursive

- name: Run manifest verifier
uses: FreeRTOS/CI-CD-GitHub-Actions/manifest-verifier@main
with:
path: ./
fail-on-incorrect-version: true


proof_ci:
if: ${{ github.event.pull_request }}
runs-on: cbmc_ubuntu-latest_64-core
Expand Down
9 changes: 9 additions & 0 deletions manifest.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,12 @@ version: "v1.3.0"
description: |
"FreeRTOS Cellular Interface implementation of the 3GPP TS v27.007 standard..\n"
license: "MIT"

dependencies:
- name: "CMock"
version: "v2.5.3"
license: "MIT"
repository:
type: "git"
url: "https://github.com/ThrowTheSwitch/CMock.git"
path: test/unit-test/CMock
45 changes: 44 additions & 1 deletion test/unit-test/cellular_pkthandler_utest.c
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ static int32_t pktRespCBReturn = 0;
static bool passCompareString = false;
static char * pCompareString = NULL;
static int32_t undefinedCallbackContext = 0;
static uint32_t lastDelayTimeMs = 0U;

void cellularAtParseTokenHandler( CellularContext_t * pContext,
char * pInputStr );
Expand Down Expand Up @@ -181,6 +182,7 @@ void setUp()
queueData = 0;
queueReturnFail = 0;
pktRespCBReturn = 0;
lastDelayTimeMs = 0U;
}

/* Called after each test method. */
Expand All @@ -203,7 +205,7 @@ int suiteTearDown( int numFailures )

void dummyDelay( uint32_t milliseconds )
{
( void ) milliseconds;
lastDelayTimeMs = milliseconds;
}

void * mock_malloc( size_t size )
Expand Down Expand Up @@ -1116,6 +1118,47 @@ void test__Cellular_AtcmdDataSend_Happy_Path( void )
TEST_ASSERT_EQUAL( CELLULAR_PKT_STATUS_OK, pktStatus );
}

/**
* @brief Test that happy path case for _Cellular_AtcmdDataSend.
*/
void test__Cellular_AtcmdDataSend_data_send_delay( void )
{
CellularPktStatus_t pktStatus = CELLULAR_PKT_STATUS_OK;
char dataBuf[ CELLULAR_AT_CMD_TYPICAL_MAX_SIZE ] = { '\0' };
uint32_t sentDataLength = 0;
CellularAtDataReq_t atDataReq =
{
( const uint8_t * ) dataBuf,
CELLULAR_AT_CMD_TYPICAL_MAX_SIZE,
&sentDataLength,
NULL,
CELLULAR_AT_CMD_TYPICAL_MAX_SIZE
};

CellularAtReq_t atReq =
{
"AT+COPS?",
CELLULAR_AT_WITH_PREFIX,
"+COPS",
NULL,
NULL,
sizeof( int32_t ),
};
CellularContext_t context;

memset( &context, 0, sizeof( CellularContext_t ) );
_Cellular_PktioSendAtCmd_IgnoreAndReturn( CELLULAR_PKT_STATUS_OK );

/* xQueueReceive true, and the data is CELLULAR_PKT_STATUS_OK. */
_Cellular_PktioSendData_IgnoreAndReturn( CELLULAR_AT_CMD_TYPICAL_MAX_SIZE );
queueData = CELLULAR_PKT_STATUS_OK;

/* Send data with data send delay 100ms. */
pktStatus = _Cellular_AtcmdDataSend( &context, atReq, atDataReq, NULL, NULL, 0, 0, 100U );
TEST_ASSERT_EQUAL( 100U, lastDelayTimeMs );
TEST_ASSERT_EQUAL( CELLULAR_PKT_STATUS_OK, pktStatus );
}

/**
* @brief Test that Test dataReq.pData or dataReq.pSentDataLength null case for _Cellular_AtcmdDataSend.
*/
Expand Down

0 comments on commit d2fd754

Please sign in to comment.