1fa7767c5Sopenharmony_ci/*
2fa7767c5Sopenharmony_ci * Copyright (C) 2023 Huawei Device Co., Ltd.
3fa7767c5Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4fa7767c5Sopenharmony_ci * you may not use this file except in compliance with the License.
5fa7767c5Sopenharmony_ci * You may obtain a copy of the License at
6fa7767c5Sopenharmony_ci *
7fa7767c5Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8fa7767c5Sopenharmony_ci *
9fa7767c5Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10fa7767c5Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11fa7767c5Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12fa7767c5Sopenharmony_ci * See the License for the specific language governing permissions and
13fa7767c5Sopenharmony_ci * limitations under the License.
14fa7767c5Sopenharmony_ci */
15fa7767c5Sopenharmony_ci
16fa7767c5Sopenharmony_ci#ifndef UNITTEST_LOG_H
17fa7767c5Sopenharmony_ci#define UNITTEST_LOG_H
18fa7767c5Sopenharmony_ci
19fa7767c5Sopenharmony_ci#include <cstdio>
20fa7767c5Sopenharmony_ci#include "securec.h"
21fa7767c5Sopenharmony_ci
22fa7767c5Sopenharmony_cinamespace OHOS {
23fa7767c5Sopenharmony_ci#define LOG_MAX_SIZE 200
24fa7767c5Sopenharmony_ci#define UNITTEST_CHECK_AND_RETURN_RET_LOG(cond, ret, fmt, ...)                                                         \
25fa7767c5Sopenharmony_ci    do {                                                                                                               \
26fa7767c5Sopenharmony_ci        if (!(cond)) {                                                                                                 \
27fa7767c5Sopenharmony_ci            char ch[LOG_MAX_SIZE];                                                                                     \
28fa7767c5Sopenharmony_ci            (void)sprintf_s(ch, LOG_MAX_SIZE, fmt, ##__VA_ARGS__);                                                     \
29fa7767c5Sopenharmony_ci            (void)printf("[%s] %s", __func__, ch);                                                                     \
30fa7767c5Sopenharmony_ci            (void)printf("\n");                                                                                        \
31fa7767c5Sopenharmony_ci            return ret;                                                                                                \
32fa7767c5Sopenharmony_ci        }                                                                                                              \
33fa7767c5Sopenharmony_ci    } while (0)
34fa7767c5Sopenharmony_ci
35fa7767c5Sopenharmony_ci#define UNITTEST_CHECK_AND_RETURN_LOG(cond, fmt, ...)                                                                  \
36fa7767c5Sopenharmony_ci    do {                                                                                                               \
37fa7767c5Sopenharmony_ci        if (!(cond)) {                                                                                                 \
38fa7767c5Sopenharmony_ci            char ch[LOG_MAX_SIZE];                                                                                     \
39fa7767c5Sopenharmony_ci            (void)sprintf_s(ch, LOG_MAX_SIZE, fmt, ##__VA_ARGS__);                                                     \
40fa7767c5Sopenharmony_ci            (void)printf("[%s] %s", __func__, ch);                                                                     \
41fa7767c5Sopenharmony_ci            (void)printf("\n");                                                                                        \
42fa7767c5Sopenharmony_ci            return;                                                                                                    \
43fa7767c5Sopenharmony_ci        }                                                                                                              \
44fa7767c5Sopenharmony_ci    } while (0)
45fa7767c5Sopenharmony_ci
46fa7767c5Sopenharmony_ci#define UNITTEST_CHECK_AND_BREAK_LOG(cond, fmt, ...)                                                                   \
47fa7767c5Sopenharmony_ci    if (!(cond)) {                                                                                                     \
48fa7767c5Sopenharmony_ci        char ch[LOG_MAX_SIZE];                                                                                         \
49fa7767c5Sopenharmony_ci        (void)sprintf_s(ch, LOG_MAX_SIZE, fmt, ##__VA_ARGS__);                                                         \
50fa7767c5Sopenharmony_ci        (void)printf("[%s] %s", __func__, ch);                                                                         \
51fa7767c5Sopenharmony_ci        (void)printf("\n");                                                                                            \
52fa7767c5Sopenharmony_ci        break;                                                                                                         \
53fa7767c5Sopenharmony_ci    }
54fa7767c5Sopenharmony_ci
55fa7767c5Sopenharmony_ci#define UNITTEST_CHECK_AND_CONTINUE_LOG(cond, fmt, ...)                                                                \
56fa7767c5Sopenharmony_ci    if (!(cond)) {                                                                                                     \
57fa7767c5Sopenharmony_ci        char ch[LOG_MAX_SIZE];                                                                                         \
58fa7767c5Sopenharmony_ci        (void)sprintf_s(ch, LOG_MAX_SIZE, fmt, ##__VA_ARGS__);                                                         \
59fa7767c5Sopenharmony_ci        (void)printf("[%s] %s", __func__, ch);                                                                         \
60fa7767c5Sopenharmony_ci        (void)printf("\n");                                                                                            \
61fa7767c5Sopenharmony_ci        continue;                                                                                                      \
62fa7767c5Sopenharmony_ci    }
63fa7767c5Sopenharmony_ci
64fa7767c5Sopenharmony_ci#define UNITTEST_INFO_LOG(fmt, ...)                                                                                    \
65fa7767c5Sopenharmony_ci    do {                                                                                                               \
66fa7767c5Sopenharmony_ci        char ch[LOG_MAX_SIZE];                                                                                         \
67fa7767c5Sopenharmony_ci        (void)sprintf_s(ch, LOG_MAX_SIZE, fmt, ##__VA_ARGS__);                                                         \
68fa7767c5Sopenharmony_ci        (void)printf("[%s] %s", __func__, ch);                                                                         \
69fa7767c5Sopenharmony_ci        (void)printf("\n");                                                                                            \
70fa7767c5Sopenharmony_ci    } while (0)
71fa7767c5Sopenharmony_ci} // namespace OHOS
72fa7767c5Sopenharmony_ci
73fa7767c5Sopenharmony_ci#endif // UNITTEST_LOG_H