• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
3  * Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without modification,
6  * are permitted provided that the following conditions are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright notice, this list of
9  * conditions and the following disclaimer.
10  *
11  * 2. Redistributions in binary form must reproduce the above copyright notice, this list
12  * of conditions and the following disclaimer in the documentation and/or other materials
13  * provided with the distribution.
14  *
15  * 3. Neither the name of the copyright holder nor the names of its contributors may be used
16  * to endorse or promote products derived from this software without specific prior written
17  * permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
23  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
26  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
27  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
28  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
29  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30  */
31 
32 #include "iCunit.h"
33 #include "iCunit.inc"
34 #include "string.h"
35 #include "osTest.h"
36 #include "iCunit_config.h"
37 
38 #include <stdio.h>
39 
40 
41 extern UINT32 g_failResult;
42 extern UINT32 g_passResult;
ICunitSaveErr(iiUINT32 line,iiUINT32 retCode)43 void ICunitSaveErr(iiUINT32 line, iiUINT32 retCode)
44 {
45     iCunit_errLineNo = (iCunit_errLineNo == 0) ? line : iCunit_errLineNo;
46     iCunit_errCode = (iCunit_errCode == 0) ? (iiUINT32)retCode : iCunit_errCode;
47 }
48 
ICunitAddCase(iCHAR * caseName,CASE_FUNCTION caseFunc,iUINT16 testcaseLayer,iUINT16 testcaseModule,iUINT16 testcaseLevel,iUINT16 testcaseType)49 iUINT32 ICunitAddCase(iCHAR *caseName, CASE_FUNCTION caseFunc, iUINT16 testcaseLayer, iUINT16 testcaseModule,
50     iUINT16 testcaseLevel, iUINT16 testcaseType)
51 {
52     iUINT16 idx;
53 
54     if (iCunit_Init_Success) {
55         return (iUINT32)ICUNIT_UNINIT;
56     }
57 
58     idx = 0;
59     if (idx == ICUNIT_CASE_SIZE) {
60         iCunit_ErrLog_AddCase++;
61         return (iUINT32)ICUNIT_CASE_FULL;
62     }
63 
64     iCunit_CaseArray[idx].pcCaseID = caseName;
65     iCunit_CaseArray[idx].pstCaseFunc = caseFunc;
66     iCunit_CaseArray[idx].testcase_layer = testcaseLayer;
67     iCunit_CaseArray[idx].testcase_module = testcaseModule;
68     iCunit_CaseArray[idx].testcase_level = testcaseLevel;
69     iCunit_CaseArray[idx].testcase_type = testcaseType;
70 
71     ICunitRun();
72     return (iUINT32)ICUNIT_SUCCESS;
73 }
74 
ICunitInit()75 iUINT32 ICunitInit()
76 {
77     iCunit_Init_Success = 0x0000;
78     iCunit_Case_Cnt = 0x0000;
79 
80     iCunit_Case_FailedCnt = 0;
81 
82     iCunit_ErrLog_AddCase = 0;
83 
84     (void)memset_s(iCunit_CaseArray, sizeof(iCunit_CaseArray), 0, sizeof(iCunit_CaseArray));
85     return (iUINT32)ICUNIT_SUCCESS;
86 }
87 
88 char *g_strLayer[] = {
89     "LOS", "CMSIS", "POSIX", "LIB", "VFS", "EXTEND",
90     "PARTITION", "CPP", "SHELL", "LINUX", "USB", "DRIVERFRAME", "CONTEXTHUB"
91 };
92 char *g_strModule[] = {
93     "TASK", "MEM", "SEM", "MUX", "EVENT", "QUE", "SWTMR", "HWI", "ATO", "CPUP", "SCATTER", "RUNSTOP", "TIMER", "MMU", "TICKLESS",
94     "ROBIN", "LIBC", "WAIT", "VFAT", "YAFFS", "JFFS", "RAMFS", "NFS", "PROC", "FS",
95     "PTHREAD", "COMP", "HWI_HALFBOTTOM", "WORKQ", "WAKELOCK", "TIMES",
96     "LIBM", "SUPPORT", "STL", "MAIL", "MSG", "CP", "SIGNAL", "SCHED", "MTDCHAR", "TIME", "WRITE", "READ", "DYNLOAD", "REGISTER", "SR", "UNAME", "ERR"
97 };
98 char *g_strLevel[] = {
99     "LEVEL0", "LEVEL1", "LEVEL2", "LEVEL3"
100 };
101 char *g_strType[] = {
102     "FUNCTION", "PRESSURE", "PERFORMANCE"
103 };
104 
ICunitRunF(void)105 iUINT32 ICunitRunF(void)
106 {
107     iUINT32 idx, idx1;
108     ICUNIT_CASE_S *psubCaseArray;
109     iUINT32 caseRet;
110 
111     psubCaseArray = iCunit_CaseArray;
112     idx1 = 1;
113 
114     for (idx = 0; idx < idx1; idx++, psubCaseArray++) {
115         iCunit_errLineNo = 0;
116         iCunit_errCode = 0;
117 
118         caseRet = psubCaseArray->pstCaseFunc();
119         psubCaseArray->errLine = iCunit_errLineNo;
120         psubCaseArray->retCode = (0 == iCunit_errLineNo) ? (caseRet) : (iCunit_errCode);
121 
122         if (0 == iCunit_errLineNo && 0 == caseRet) {
123             g_passResult++;
124             PRINTF("  [Passed]-%s-%s-%s-%s-%s\n", psubCaseArray->pcCaseID, g_strLayer[psubCaseArray->testcase_layer],
125                 g_strModule[psubCaseArray->testcase_module], g_strLevel[psubCaseArray->testcase_level],
126                 g_strType[psubCaseArray->testcase_type]);
127         } else {
128             g_failResult++;
129             iCunit_Case_FailedCnt++;
130             PRINTF("  [Failed]-%s-%s-%s-%s-%s-[Errline: %d RetCode:0x%lx]\n", psubCaseArray->pcCaseID,
131                 g_strLayer[psubCaseArray->testcase_layer], g_strModule[psubCaseArray->testcase_module],
132                 g_strLevel[psubCaseArray->testcase_level], g_strType[psubCaseArray->testcase_type],
133                 psubCaseArray->errLine, psubCaseArray->retCode);
134         }
135     }
136 
137     return (iUINT32)ICUNIT_SUCCESS;
138 }
139 
ICunitRun()140 iUINT32 ICunitRun()
141 {
142     if (iCunit_Init_Success) {
143         return (iUINT32)ICUNIT_UNINIT;
144     }
145 
146     ICunitRunF();
147 
148     return (iUINT32)ICUNIT_SUCCESS;
149 }
150 
151