• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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