1 /*
2 * Copyright (c) 2022 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16 #include <hilog_adapter.h>
17 #include <stdlib.h>
18 #include "functionalext.h"
19 #include "test.h"
20
21 #define MUSL_LOG_TYPE LOG_CORE
22 #define MUSL_LOG_DOMAIN 0xD003F00
23 #define MUSL_LOG_TAG "MUSL"
24 #define LOG_ERROR 6
25 #define CLOSE_FD_COUNT 1024
26
27 #define ENABLE_LOG "param set musl.log.enable true"
28 #define LOG_LEVEL_ERROR "param set musl.log.level ERROR"
29
30 #define MUSL_LOGE(...) ((void)HiLogAdapterPrint(MUSL_LOG_TYPE, LOG_ERROR, MUSL_LOG_DOMAIN, MUSL_LOG_TAG, __VA_ARGS__))
31
32 /**
33 * @tc.name : reboot_0010
34 * @tc.desc : Test HiLogAdapterPrint after musl_log_reset
35 * @tc.level : Level 2
36 */
HiLogAdapterPrint_0010(void)37 static void HiLogAdapterPrint_0010(void)
38 {
39 musl_log_reset();
40 int ret = HiLogAdapterPrint(MUSL_LOG_TYPE, LOG_ERROR, MUSL_LOG_DOMAIN, MUSL_LOG_TAG, "a");
41 EXPECT_NE("HiLogAdapterPrint_0010", ret, 0);
42 ret = HiLogAdapterPrint(MUSL_LOG_TYPE, LOG_INFO, MUSL_LOG_DOMAIN, MUSL_LOG_TAG, "b");
43 EXPECT_EQ("HiLogAdapterPrint_0010", ret, -1);
44 }
45
HilogAdapterPrint_0020(void)46 static void HilogAdapterPrint_0020(void)
47 {
48 musl_log_reset();
49 for (int i = 2; i < CLOSE_FD_COUNT; ++i) {
50 close(i);
51 }
52 int ret = HiLogAdapterPrint(MUSL_LOG_TYPE, LOG_ERROR, MUSL_LOG_DOMAIN, MUSL_LOG_TAG, "c");
53 EXPECT_GT("HiLogAdapterPrint_0020", ret, 0);
54 }
55
main(void)56 int main(void)
57 {
58 system(ENABLE_LOG);
59 system(LOG_LEVEL_ERROR);
60 HiLogAdapterPrint_0010();
61 HilogAdapterPrint_0020();
62
63 return t_status;
64 }
65