106f6ba60Sopenharmony_ci/* 206f6ba60Sopenharmony_ci * Copyright (c) Huawei Technologies Co., Ltd. 2022. All rights reserved. 306f6ba60Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 406f6ba60Sopenharmony_ci * you may not use this file except in compliance with the License. 506f6ba60Sopenharmony_ci * You may obtain a copy of the License at 606f6ba60Sopenharmony_ci * 706f6ba60Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 806f6ba60Sopenharmony_ci * 906f6ba60Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 1006f6ba60Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 1106f6ba60Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1206f6ba60Sopenharmony_ci * See the License for the specific language governing permissions and 1306f6ba60Sopenharmony_ci * limitations under the License. 1406f6ba60Sopenharmony_ci */ 1506f6ba60Sopenharmony_ci 1606f6ba60Sopenharmony_ci#include <cstdio> 1706f6ba60Sopenharmony_ci#include <string> 1806f6ba60Sopenharmony_ci 1906f6ba60Sopenharmony_ci#include <gtest/gtest.h> 2006f6ba60Sopenharmony_ci 2106f6ba60Sopenharmony_ci#include "bpf_log_reader.h" 2206f6ba60Sopenharmony_ci 2306f6ba60Sopenharmony_ciusing namespace testing::ext; 2406f6ba60Sopenharmony_ciusing namespace std; 2506f6ba60Sopenharmony_cinamespace { 2606f6ba60Sopenharmony_ciconst std::string FILE_NAME = "/data/local/tmp/libebpf.log"; 2706f6ba60Sopenharmony_ci} // namespace 2806f6ba60Sopenharmony_ci 2906f6ba60Sopenharmony_cinamespace OHOS { 3006f6ba60Sopenharmony_cinamespace Developtools { 3106f6ba60Sopenharmony_cinamespace Hiebpf { 3206f6ba60Sopenharmony_ciclass BPFLogReaderTest : public ::testing::Test { 3306f6ba60Sopenharmony_cipublic: 3406f6ba60Sopenharmony_ci static void SetUpTestCase() {}; 3506f6ba60Sopenharmony_ci static void TearDownTestCase() 3606f6ba60Sopenharmony_ci { 3706f6ba60Sopenharmony_ci if (access(FILE_NAME.c_str(), F_OK) == 0) { 3806f6ba60Sopenharmony_ci std::string cmd = "rm " + FILE_NAME; 3906f6ba60Sopenharmony_ci system(cmd.c_str()); 4006f6ba60Sopenharmony_ci } 4106f6ba60Sopenharmony_ci } 4206f6ba60Sopenharmony_ci 4306f6ba60Sopenharmony_ci void SetUp() {} 4406f6ba60Sopenharmony_ci void TearDown() {} 4506f6ba60Sopenharmony_ci}; 4606f6ba60Sopenharmony_ci 4706f6ba60Sopenharmony_ci/** 4806f6ba60Sopenharmony_ci * @tc.name: MakeUnique 4906f6ba60Sopenharmony_ci * @tc.desc: Test BPFLogReader MakeUnique 5006f6ba60Sopenharmony_ci * @tc.type: FUNC 5106f6ba60Sopenharmony_ci */ 5206f6ba60Sopenharmony_ciHWTEST_F(BPFLogReaderTest, MakeUnique, TestSize.Level1) 5306f6ba60Sopenharmony_ci{ 5406f6ba60Sopenharmony_ci auto logger = BPFLogReader::MakeUnique(""); 5506f6ba60Sopenharmony_ci EXPECT_TRUE(logger == nullptr); 5606f6ba60Sopenharmony_ci 5706f6ba60Sopenharmony_ci logger = BPFLogReader::MakeUnique("stdout"); 5806f6ba60Sopenharmony_ci EXPECT_TRUE(logger != nullptr); 5906f6ba60Sopenharmony_ci 6006f6ba60Sopenharmony_ci logger = BPFLogReader::MakeUnique(FILE_NAME); 6106f6ba60Sopenharmony_ci EXPECT_TRUE(logger != nullptr); 6206f6ba60Sopenharmony_ci} 6306f6ba60Sopenharmony_ci 6406f6ba60Sopenharmony_ci/** 6506f6ba60Sopenharmony_ci * @tc.name: OpenLogFile 6606f6ba60Sopenharmony_ci * @tc.desc: Test BPFLogReader OpenLogFile 6706f6ba60Sopenharmony_ci * @tc.type: FUNC 6806f6ba60Sopenharmony_ci */ 6906f6ba60Sopenharmony_ciHWTEST_F(BPFLogReaderTest, OpenLogFile, TestSize.Level1) 7006f6ba60Sopenharmony_ci{ 7106f6ba60Sopenharmony_ci BPFLogReader logger; 7206f6ba60Sopenharmony_ci auto ret = logger.OpenLogFile(""); 7306f6ba60Sopenharmony_ci EXPECT_EQ(ret, -1); 7406f6ba60Sopenharmony_ci 7506f6ba60Sopenharmony_ci ret = logger.OpenLogFile("stdout"); 7606f6ba60Sopenharmony_ci EXPECT_EQ(ret, 0); 7706f6ba60Sopenharmony_ci 7806f6ba60Sopenharmony_ci ret = logger.OpenLogFile(FILE_NAME); 7906f6ba60Sopenharmony_ci EXPECT_EQ(ret, 0); 8006f6ba60Sopenharmony_ci} 8106f6ba60Sopenharmony_ci 8206f6ba60Sopenharmony_ci/** 8306f6ba60Sopenharmony_ci * @tc.name: GetLogFileName 8406f6ba60Sopenharmony_ci * @tc.desc: Test BPFLogReader GetLogFileName 8506f6ba60Sopenharmony_ci * @tc.type: FUNC 8606f6ba60Sopenharmony_ci */ 8706f6ba60Sopenharmony_ciHWTEST_F(BPFLogReaderTest, GetLogFileName, TestSize.Level1) 8806f6ba60Sopenharmony_ci{ 8906f6ba60Sopenharmony_ci BPFLogReader logger; 9006f6ba60Sopenharmony_ci std::string fileName = logger.GetLogFileName(); 9106f6ba60Sopenharmony_ci EXPECT_STRNE(fileName.c_str(), ""); 9206f6ba60Sopenharmony_ci} 9306f6ba60Sopenharmony_ci 9406f6ba60Sopenharmony_ci/** 9506f6ba60Sopenharmony_ci * @tc.name: Start 9606f6ba60Sopenharmony_ci * @tc.desc: Test BPFLogReader Start 9706f6ba60Sopenharmony_ci * @tc.type: FUNC 9806f6ba60Sopenharmony_ci */ 9906f6ba60Sopenharmony_ciHWTEST_F(BPFLogReaderTest, Start, TestSize.Level1) 10006f6ba60Sopenharmony_ci{ 10106f6ba60Sopenharmony_ci BPFLogReader logger; 10206f6ba60Sopenharmony_ci auto ret = logger.Start(); 10306f6ba60Sopenharmony_ci EXPECT_EQ(ret, 0); 10406f6ba60Sopenharmony_ci 10506f6ba60Sopenharmony_ci sleep(1); 10606f6ba60Sopenharmony_ci 10706f6ba60Sopenharmony_ci ret = logger.Stop(); 10806f6ba60Sopenharmony_ci EXPECT_EQ(ret, 0); 10906f6ba60Sopenharmony_ci} 11006f6ba60Sopenharmony_ci} // namespace Hiebpf 11106f6ba60Sopenharmony_ci} // namespace Developtools 11206f6ba60Sopenharmony_ci} // namespace OHOS 113