1 /*
2  * Copyright (c) 2023-2023 Huawei Device Co., Ltd. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without modification,
5  * are permitted provided that the following conditions are met:
6  *
7  * 1. Redistributions of source code must retain the above copyright notice, this list of
8  *    conditions and the following disclaimer.
9  *
10  * 2. Redistributions in binary form must reproduce the above copyright notice, this list
11  *    of conditions and the following disclaimer in the documentation and/or other materials
12  *    provided with the distribution.
13  *
14  * 3. Neither the name of the copyright holder nor the names of its contributors may be used
15  *    to endorse or promote products derived from this software without specific prior written
16  *    permission.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
20  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
22  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
23  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
24  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
25  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
26  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
27  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
28  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  */
30 
31 #include "xts_cmsis.h"
32 
33 UINT16 g_cmsisTestMutexCount;
34 osMutexId_t g_cmsisOsMutexId;
35 osMutexAttr_t g_cmsisMutexAttr;
36 
37 LITE_TEST_SUIT(Cmsis, Cmsismutex, CmsisMutexFuncTestSuite);
38 
CmsisMutexFuncTestSuiteSetUp(void)39 static BOOL CmsisMutexFuncTestSuiteSetUp(void)
40 {
41     return TRUE;
42 }
43 
CmsisMutexFuncTestSuiteTearDown(void)44 static BOOL CmsisMutexFuncTestSuiteTearDown(void)
45 {
46     return TRUE;
47 }
48 
CmsisMutexGetOwnerFunc001(void const *argument)49 static void CmsisMutexGetOwnerFunc001(void const *argument)
50 {
51     (void)argument;
52     osStatus_t ret;
53     osThreadId_t id1;
54     osThreadId_t id2;
55     osThreadAttr_t attr;
56     g_cmsisOsMutexId = osMutexNew(&g_cmsisMutexAttr);
57     ICUNIT_ASSERT_NOT_EQUAL(g_cmsisOsMutexId, NULL, g_cmsisOsMutexId);
58 
59     ret = osMutexAcquire(g_cmsisOsMutexId, LOS_WAIT_FOREVER);
60     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
61 
62     id1 = osMutexGetOwner(g_cmsisOsMutexId);
63     id2 = osThreadGetId();
64     ICUNIT_ASSERT_STRING_EQUAL(id1, id2, id1);
65 
66     attr.name = osThreadGetName(id1);
67     ICUNIT_ASSERT_STRING_EQUAL("testMutexGetOwner001", attr.name, attr.name);
68 
69     ret = osMutexRelease(g_cmsisOsMutexId);
70     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
71 
72     ret = osMutexDelete(g_cmsisOsMutexId);
73     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
74     osThreadExit();
75 }
76 
77 /**
78  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0100
79  * @tc.name      : mutex operation for creat with NULL para
80  * @tc.desc      : [C- SOFTWARE -0200]
81  */
82 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexNew001, Function | MediumTest | Level1)
83 {
84     osStatus_t status;
85     g_cmsisOsMutexId = osMutexNew(NULL);
86     ICUNIT_ASSERT_NOT_EQUAL(g_cmsisOsMutexId, NULL, g_cmsisOsMutexId);
87     (void)osMutexDelete(g_cmsisOsMutexId);
88     status = osDelay(DELAY_TICKS_5);
89     ICUNIT_ASSERT_EQUAL(status, osOK, status);
90     return 0;
91 };
92 
93 /**
94  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0200
95  * @tc.name      : mutex operation for creat
96  * @tc.desc      : [C- SOFTWARE -0200]
97  */
98 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexNew002, Function | MediumTest | Level1)
99 {
100     osStatus_t status;
101     g_cmsisOsMutexId = osMutexNew(&g_cmsisMutexAttr);
102     ICUNIT_ASSERT_NOT_EQUAL(g_cmsisOsMutexId, NULL, g_cmsisOsMutexId);
103     (void)osMutexDelete(g_cmsisOsMutexId);
104     status = osDelay(DELAY_TICKS_5);
105     ICUNIT_ASSERT_EQUAL(status, osOK, status);
106     return 0;
107 };
108 
109 /**
110  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0300
111  * @tc.name      : mutex operation for delete after creat mutex with NULL parameter
112  * @tc.desc      : [C- SOFTWARE -0200]
113  */
114 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexDelete001, Function | MediumTest | Level1)
115 {
116     osStatus_t ret;
117     g_cmsisOsMutexId = osMutexNew(NULL);
118     ICUNIT_ASSERT_NOT_EQUAL(g_cmsisOsMutexId, NULL, g_cmsisOsMutexId);
119     ret = osMutexDelete(g_cmsisOsMutexId);
120     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
121 
122     ret = osMutexDelete(g_cmsisOsMutexId);
123     ICUNIT_ASSERT_EQUAL(ret, osErrorParameter, ret);
124     return 0;
125 };
126 
127 /**
128  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0400
129  * @tc.name      : mutex operation for delete
130  * @tc.desc      : [C- SOFTWARE -0200]
131  */
132 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexDelete002, Function | MediumTest | Level1)
133 {
134     osStatus_t ret;
135     g_cmsisOsMutexId = osMutexNew(&g_cmsisMutexAttr);
136     ICUNIT_ASSERT_NOT_EQUAL(g_cmsisOsMutexId, NULL, g_cmsisOsMutexId);
137     ret = osMutexDelete(g_cmsisOsMutexId);
138     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
139 
140     ret = osMutexDelete(g_cmsisOsMutexId);
141     ICUNIT_ASSERT_EQUAL(ret, osErrorParameter, ret);
142     return 0;
143 };
144 
145 /**
146  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0500
147  * @tc.name      : mutex operation for delete after mutex acquire and release
148  * @tc.desc      : [C- SOFTWARE -0200]
149  */
150 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexDelete003, Function | MediumTest | Level1)
151 {
152     osStatus_t ret;
153     g_cmsisOsMutexId = osMutexNew(NULL);
154     ICUNIT_ASSERT_NOT_EQUAL(g_cmsisOsMutexId, NULL, g_cmsisOsMutexId);
155 
156     osMutexAcquire(g_cmsisOsMutexId, LOS_WAIT_FOREVER);
157     ret = osMutexDelete(g_cmsisOsMutexId);
158     ICUNIT_ASSERT_EQUAL(ret, osErrorResource, ret);
159 
160     (void)osMutexRelease(g_cmsisOsMutexId);
161     ret = osMutexDelete(g_cmsisOsMutexId);
162     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
163     return 0;
164 };
165 
166 /**
167  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0600
168  * @tc.name      : mutex delete operation with mutex_id = NULL
169  * @tc.desc      : [C- SOFTWARE -0200]
170  */
171 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexDelete004, Function | MediumTest | Level1)
172 {
173     osStatus_t ret = osMutexDelete(NULL);
174     ICUNIT_ASSERT_EQUAL(ret, osErrorParameter, ret);
175     return 0;
176 };
177 
178 /**
179  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0700
180  * @tc.name      : mutex acquire operation with mutex_id = NULL
181  * @tc.desc      : [C- SOFTWARE -0200]
182  */
183 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexAcquire001, Function | MediumTest | Level1)
184 {
185     osStatus_t ret = osMutexAcquire(NULL, LOS_WAIT_FOREVER);
186     ICUNIT_ASSERT_EQUAL(ret, osErrorParameter, ret);
187     return 0;
188 };
189 
190 /**
191  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0800
192  * @tc.name      : mutex operation for acquire
193  * @tc.desc      : [C- SOFTWARE -0200]
194  */
195 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexAcquire002, Function | MediumTest | Level1)
196 {
197     osStatus_t ret;
198     g_cmsisOsMutexId = osMutexNew(&g_cmsisMutexAttr);
199     ICUNIT_ASSERT_NOT_EQUAL(g_cmsisOsMutexId, NULL, g_cmsisOsMutexId);
200 
201     ret = osMutexAcquire(g_cmsisOsMutexId, LOS_WAIT_FOREVER);
202     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
203 
204     (void)osMutexRelease(g_cmsisOsMutexId);
205     ret = osMutexDelete(g_cmsisOsMutexId);
206     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
207     return 0;
208 };
209 
210 /**
211  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_0900
212  * @tc.name      : mutex operation for release
213  * @tc.desc      : [C- SOFTWARE -0200]
214  */
215 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexRelease001, Function | MediumTest | Level1)
216 {
217     osStatus_t ret;
218     g_cmsisOsMutexId = osMutexNew(&g_cmsisMutexAttr);
219     ICUNIT_ASSERT_NOT_EQUAL(g_cmsisOsMutexId, NULL, g_cmsisOsMutexId);
220 
221     ret = osMutexAcquire(g_cmsisOsMutexId, LOS_WAIT_FOREVER);
222     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
223 
224     ret = osMutexDelete(g_cmsisOsMutexId);
225     ICUNIT_ASSERT_EQUAL(ret, osErrorResource, ret);
226 
227     ret = osMutexRelease(g_cmsisOsMutexId);
228     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
229 
230     ret = osMutexDelete(g_cmsisOsMutexId);
231     ICUNIT_ASSERT_EQUAL(ret, osOK, ret);
232     return 0;
233 };
234 
235 /**
236  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_1000
237  * @tc.name      : mutex release operation with mutex_id = NULL
238  * @tc.desc      : [C- SOFTWARE -0200]
239  */
240 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexRelease002, Function | MediumTest | Level1)
241 {
242     osStatus_t ret = osMutexRelease(NULL);
243     ICUNIT_ASSERT_EQUAL(ret, osErrorParameter, ret);
244     return 0;
245 };
246 
247 /**
248  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_1100
249  * @tc.name      : mutex operation for get owner
250  * @tc.desc      : [C- SOFTWARE -0200]
251  */
252 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexGetOwner001, Function | MediumTest | Level1)
253 {
254     osThreadId_t id;
255     osThreadAttr_t osAttr;
256     osAttr.name = "testMutexGetOwner001";
257     osAttr.attr_bits = 0U;
258     osAttr.cb_mem = NULL;
259     osAttr.cb_size = 0U;
260     osAttr.stack_mem = NULL;
261     osAttr.stack_size = TEST_TASK_STACK_SIZE;
262     osAttr.priority = osPriorityAboveNormal;
263     id = osThreadNew((osThreadFunc_t)CmsisMutexGetOwnerFunc001, NULL, &osAttr);
264     ICUNIT_ASSERT_NOT_EQUAL(id, NULL, id);
265     return 0;
266 };
267 
268 /**
269  * @tc.number    : SUB_KERNEL_CMSIS_MUTEX_OPERATION_1200
270  * @tc.name      : mutex get owner operation with mutex_id = NULL
271  * @tc.desc      : [C- SOFTWARE -0200]
272  */
273 LITE_TEST_CASE(CmsisMutexFuncTestSuite, testOsMutexGetOwner002, Function | MediumTest | Level1)
274 {
275     osThreadId_t id = osMutexGetOwner(NULL);
276     ICUNIT_ASSERT_EQUAL(id, NULL, id);
277     return 0;
278 };
279 
280 RUN_TEST_SUITE(CmsisMutexFuncTestSuite);
281 
CmsisMutexFuncTest(void)282 void CmsisMutexFuncTest(void)
283 {
284     RUN_ONE_TESTCASE(testOsMutexNew001);
285     RUN_ONE_TESTCASE(testOsMutexNew002);
286     RUN_ONE_TESTCASE(testOsMutexDelete001);
287     RUN_ONE_TESTCASE(testOsMutexDelete002);
288     RUN_ONE_TESTCASE(testOsMutexDelete003);
289     RUN_ONE_TESTCASE(testOsMutexDelete004);
290     RUN_ONE_TESTCASE(testOsMutexAcquire001);
291     RUN_ONE_TESTCASE(testOsMutexAcquire002);
292     RUN_ONE_TESTCASE(testOsMutexRelease001);
293     RUN_ONE_TESTCASE(testOsMutexRelease002);
294     RUN_ONE_TESTCASE(testOsMutexGetOwner001);
295     RUN_ONE_TESTCASE(testOsMutexGetOwner002);
296 }
297