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