1484543d1Sopenharmony_ci/* 2484543d1Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 3484543d1Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4484543d1Sopenharmony_ci * you may not use this file except in compliance with the License. 5484543d1Sopenharmony_ci * You may obtain a copy of the License at 6484543d1Sopenharmony_ci * 7484543d1Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8484543d1Sopenharmony_ci * 9484543d1Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10484543d1Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11484543d1Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12484543d1Sopenharmony_ci * See the License for the specific language governing permissions and 13484543d1Sopenharmony_ci * limitations under the License. 14484543d1Sopenharmony_ci */ 15484543d1Sopenharmony_ci 16484543d1Sopenharmony_ci#include <cerrno> 17484543d1Sopenharmony_ci#include <fcntl.h> 18484543d1Sopenharmony_ci#include <unistd.h> 19484543d1Sopenharmony_ci#include <gtest/gtest.h> 20484543d1Sopenharmony_ci#include <securec.h> 21484543d1Sopenharmony_ci#include "dfx/log/ffrt_log_api.h" 22484543d1Sopenharmony_ci#include "faultloggerd_client.h" 23484543d1Sopenharmony_ci#include "dfx/bbox/fault_logger_fd_manager.h" 24484543d1Sopenharmony_ci#include "../common.h" 25484543d1Sopenharmony_ci 26484543d1Sopenharmony_cistatic const char* FILE_NAME = "testLogToFaultlogger.txt"; 27484543d1Sopenharmony_ci 28484543d1Sopenharmony_ciusing namespace testing; 29484543d1Sopenharmony_ci#ifdef HWTEST_TESTING_EXT_ENABLE 30484543d1Sopenharmony_ciusing namespace testing::ext; 31484543d1Sopenharmony_ci#endif 32484543d1Sopenharmony_ci 33484543d1Sopenharmony_ciclass FfrtLogTest : public testing::Test { 34484543d1Sopenharmony_ciprotected: 35484543d1Sopenharmony_ci static void SetUpTestCase() 36484543d1Sopenharmony_ci { 37484543d1Sopenharmony_ci } 38484543d1Sopenharmony_ci 39484543d1Sopenharmony_ci static void TearDownTestCase() 40484543d1Sopenharmony_ci { 41484543d1Sopenharmony_ci } 42484543d1Sopenharmony_ci 43484543d1Sopenharmony_ci virtual void SetUp() 44484543d1Sopenharmony_ci { 45484543d1Sopenharmony_ci } 46484543d1Sopenharmony_ci 47484543d1Sopenharmony_ci virtual void TearDown() 48484543d1Sopenharmony_ci { 49484543d1Sopenharmony_ci } 50484543d1Sopenharmony_ci}; 51484543d1Sopenharmony_ci 52484543d1Sopenharmony_ci// FaultLogger获取句柄/写入日志/读取日志/关闭句柄 53484543d1Sopenharmony_ciHWTEST_F(FfrtLogTest, faultLoggerFdManager, TestSize.Level1) 54484543d1Sopenharmony_ci{ 55484543d1Sopenharmony_ci // 获取句柄 56484543d1Sopenharmony_ci FaultLoggerFdManager manager = FaultLoggerFdManager::Instance(); 57484543d1Sopenharmony_ci EXPECT_EQ(manager.GetFaultLoggerFd(), -1); 58484543d1Sopenharmony_ci EXPECT_TRUE(manager.InitFaultLoggerFd() > 0); 59484543d1Sopenharmony_ci 60484543d1Sopenharmony_ci // 写入日志 61484543d1Sopenharmony_ci manager.WriteFaultLogger("test logToFaultlogger arg1[%s],arg2[%d]", "ARG1", 1); 62484543d1Sopenharmony_ci manager.WriteFaultLogger("test logToFaultlogger arg1[%s],arg2[%d]", "ARG1", 1); 63484543d1Sopenharmony_ci 64484543d1Sopenharmony_ci // 关闭句柄 65484543d1Sopenharmony_ci manager.CloseFd(); 66484543d1Sopenharmony_ci EXPECT_EQ(manager.GetFaultLoggerFd(), -1); 67484543d1Sopenharmony_ci 68484543d1Sopenharmony_ci // 读取日志 69484543d1Sopenharmony_ci EXPECT_TRUE(manager.InitFaultLoggerFd() > 0); 70484543d1Sopenharmony_ci int fd = manager.GetFaultLoggerFd(); 71484543d1Sopenharmony_ci const int bufferLen = 2048; 72484543d1Sopenharmony_ci std::array<char, bufferLen> readBuf {}; 73484543d1Sopenharmony_ci int readSize = read(fd, readBuf.data(), bufferLen); 74484543d1Sopenharmony_ci std::string msg = "test logToFaultlogger arg1[ARG1],arg2[1]\ntest logToFaultlogger arg1[ARG1],arg2[1]\n"; 75484543d1Sopenharmony_ci EXPECT_EQ(readSize, msg.size()); 76484543d1Sopenharmony_ci EXPECT_EQ(readBuf.data(), msg); 77484543d1Sopenharmony_ci close(fd); 78484543d1Sopenharmony_ci 79484543d1Sopenharmony_ci // 删除文件 80484543d1Sopenharmony_ci remove(FILE_NAME); 81484543d1Sopenharmony_ci}