• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2021-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 <iostream>
17 #include <string>
18 
19 #include "perf_file_reader.h"
20 #include "perf_file_reader_test.h"
21 
22 using namespace testing::ext;
23 using namespace std;
24 using namespace OHOS::HiviewDFX;
25 namespace OHOS {
26 namespace Developtools {
27 namespace HiPerf {
28 using ProcessRecordCB = const std::function<bool(std::unique_ptr<PerfEventRecord> record)>;
29 class PerfFileReaderTest : public testing::Test {
30 public:
31     static void SetUpTestCase(void);
32     static void TearDownTestCase(void);
33     void SetUp();
34     void TearDown();
35     std::unique_ptr<PerfFileReader> hiperfFileReader_ {nullptr};
36 };
37 
SetUpTestCase()38 void PerfFileReaderTest::SetUpTestCase() {}
39 
TearDownTestCase()40 void PerfFileReaderTest::TearDownTestCase() {}
41 
SetUp()42 void PerfFileReaderTest::SetUp() {}
TearDown()43 void PerfFileReaderTest::TearDown() {}
44 
45 HWTEST_F(PerfFileReaderTest, Test_Instance_success, TestSize.Level1)
46 {
47     const std::string filename = "perf.data";
48     FILE *fp = stdout;
49     PerfFileReader *hiperfFileReader = new PerfFileReader(filename, fp);
50     std::unique_ptr<PerfFileReader> ret = hiperfFileReader->Instance(filename);
51     bool result = true;
52     if (ret != 0) {
53         result = true;
54     }
55     EXPECT_EQ(result, true);
56 }
57 
58 HWTEST_F(PerfFileReaderTest, Test_Instance_fail, TestSize.Level1)
59 {
60     const std::string filename = "xxx";
61     FILE *fp = nullptr;
62     PerfFileReader *hiperfFileReader = new PerfFileReader(filename, fp);
63     std::unique_ptr<PerfFileReader> ret = hiperfFileReader->Instance(filename);
64     bool result = true;
65     if (ret == 0) {
66         result = false;
67     }
68     EXPECT_EQ(result, false);
69 }
70 
71 HWTEST_F(PerfFileReaderTest, Test_ReadFetureSection_success, TestSize.Level1)
72 {
73     const std::string filename = "perf.data";
74     FILE *fp = stdout;
75     PerfFileReader *hiperfFileReader = new PerfFileReader(filename, fp);
76     bool ret = hiperfFileReader->ReadFeatureSection();
77     EXPECT_EQ(ret, true);
78 }
79 
80 HWTEST_F(PerfFileReaderTest, Test_ReadFetureSection, TestSize.Level1)
81 {
82     const std::string filename = "xxx";
83     FILE *fp = nullptr;
84     PerfFileReader *hiperfFileReader = new PerfFileReader(filename, fp);
85     bool ret = hiperfFileReader->ReadFeatureSection();
86     EXPECT_EQ(ret, true);
87 }
88 
89 HWTEST_F(PerfFileReaderTest, Test_GetFetures, TestSize.Level1)
90 {
91     const std::string filename = "perf.data";
92     FILE *fp = stdout;
93     PerfFileReader *hiperfFileReader = new PerfFileReader(filename, fp);
94     std::vector<FEATURE> features_;
95     FEATURE feture1 = FEATURE::RESERVED;
96     FEATURE feture2 = FEATURE::ARCH;
97     FEATURE feture3 = FEATURE::BUILD_ID;
98     FEATURE feture4 = FEATURE::LAST_FEATURE;
99     features_.push_back(feture1);
100     features_.push_back(feture2);
101     features_.push_back(feture3);
102     features_.push_back(feture4);
103     EXPECT_NE(features_.size(), hiperfFileReader->GetFeatures().size());
104 }
105 
106 HWTEST_F(PerfFileReaderTest, Test_GetFetureString, TestSize.Level1)
107 {
108     const std::string filename = "perf.data";
109     FILE *fp = stdout;
110     PerfFileReader *hiperfFileReader = new PerfFileReader(filename, fp);
111     const FEATURE feture = FEATURE::ARCH;
112     const std::string result = "ARCH";
113     EXPECT_NE(hiperfFileReader->GetFeatureString(feture), result);
114 }
115 } // namespace HiPerf
116 } // namespace Developtools
117 } // namespace OHOS
118