xref: /aosp_15_r20/external/perfetto/src/perfetto_cmd/config_unittest.cc (revision 6dbdd20afdafa5e3ca9b8809fa73465d530080dc)
1*6dbdd20aSAndroid Build Coastguard Worker /*
2*6dbdd20aSAndroid Build Coastguard Worker  * Copyright (C) 2018 The Android Open Source Project
3*6dbdd20aSAndroid Build Coastguard Worker  *
4*6dbdd20aSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*6dbdd20aSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*6dbdd20aSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*6dbdd20aSAndroid Build Coastguard Worker  *
8*6dbdd20aSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*6dbdd20aSAndroid Build Coastguard Worker  *
10*6dbdd20aSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*6dbdd20aSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*6dbdd20aSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*6dbdd20aSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*6dbdd20aSAndroid Build Coastguard Worker  * limitations under the License.
15*6dbdd20aSAndroid Build Coastguard Worker  */
16*6dbdd20aSAndroid Build Coastguard Worker 
17*6dbdd20aSAndroid Build Coastguard Worker #include "src/perfetto_cmd/config.h"
18*6dbdd20aSAndroid Build Coastguard Worker 
19*6dbdd20aSAndroid Build Coastguard Worker #include "test/gtest_and_gmock.h"
20*6dbdd20aSAndroid Build Coastguard Worker 
21*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/tracing/core/data_source_config.h"
22*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/tracing/core/trace_config.h"
23*6dbdd20aSAndroid Build Coastguard Worker 
24*6dbdd20aSAndroid Build Coastguard Worker #include "protos/perfetto/config/ftrace/ftrace_config.gen.h"
25*6dbdd20aSAndroid Build Coastguard Worker 
26*6dbdd20aSAndroid Build Coastguard Worker namespace perfetto {
27*6dbdd20aSAndroid Build Coastguard Worker namespace {
28*6dbdd20aSAndroid Build Coastguard Worker 
29*6dbdd20aSAndroid Build Coastguard Worker using testing::Contains;
30*6dbdd20aSAndroid Build Coastguard Worker 
31*6dbdd20aSAndroid Build Coastguard Worker class CreateConfigFromOptionsTest : public ::testing::Test {
32*6dbdd20aSAndroid Build Coastguard Worker  public:
33*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig config;
34*6dbdd20aSAndroid Build Coastguard Worker   ConfigOptions options;
35*6dbdd20aSAndroid Build Coastguard Worker };
36*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,Default)37*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, Default) {
38*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
39*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_FALSE(config.write_into_file());
40*6dbdd20aSAndroid Build Coastguard Worker }
41*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,MilliSeconds)42*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, MilliSeconds) {
43*6dbdd20aSAndroid Build Coastguard Worker   options.time = "2ms";
44*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
45*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.duration_ms(), 2u);
46*6dbdd20aSAndroid Build Coastguard Worker }
47*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,ZeroTime)48*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, ZeroTime) {
49*6dbdd20aSAndroid Build Coastguard Worker   options.time = "0";
50*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
51*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.duration_ms(), 0u);
52*6dbdd20aSAndroid Build Coastguard Worker }
53*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,Seconds)54*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, Seconds) {
55*6dbdd20aSAndroid Build Coastguard Worker   options.time = "100s";
56*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
57*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.duration_ms(), 100 * 1000u);
58*6dbdd20aSAndroid Build Coastguard Worker }
59*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,Minutes)60*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, Minutes) {
61*6dbdd20aSAndroid Build Coastguard Worker   options.time = "2m";
62*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
63*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.duration_ms(), 2 * 60 * 1000u);
64*6dbdd20aSAndroid Build Coastguard Worker }
65*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,Hours)66*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, Hours) {
67*6dbdd20aSAndroid Build Coastguard Worker   options.time = "2h";
68*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
69*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.duration_ms(), 2 * 60 * 60 * 1000u);
70*6dbdd20aSAndroid Build Coastguard Worker }
71*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,ZeroBufferSize)72*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, ZeroBufferSize) {
73*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "0";
74*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
75*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.buffers()[0].size_kb(), 0u);
76*6dbdd20aSAndroid Build Coastguard Worker }
77*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,Kilobyte)78*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, Kilobyte) {
79*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "2kb";
80*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
81*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.buffers()[0].size_kb(), 2u);
82*6dbdd20aSAndroid Build Coastguard Worker }
83*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,Megabyte)84*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, Megabyte) {
85*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "2mb";
86*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
87*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.buffers()[0].size_kb(), 2 * 1024u);
88*6dbdd20aSAndroid Build Coastguard Worker }
89*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,Gigabyte)90*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, Gigabyte) {
91*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "2gb";
92*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
93*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.buffers()[0].size_kb(), 2 * 1024 * 1024u);
94*6dbdd20aSAndroid Build Coastguard Worker }
95*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,BadTrailingSpace)96*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, BadTrailingSpace) {
97*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "2gb ";
98*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_FALSE(CreateConfigFromOptions(options, &config));
99*6dbdd20aSAndroid Build Coastguard Worker }
100*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,UnmatchedUnit)101*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, UnmatchedUnit) {
102*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "2ly";
103*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_FALSE(CreateConfigFromOptions(options, &config));
104*6dbdd20aSAndroid Build Coastguard Worker }
105*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,OnlyNumber)106*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, OnlyNumber) {
107*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "2";
108*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_FALSE(CreateConfigFromOptions(options, &config));
109*6dbdd20aSAndroid Build Coastguard Worker }
110*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,OnlyUnit)111*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, OnlyUnit) {
112*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "kb";
113*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_FALSE(CreateConfigFromOptions(options, &config));
114*6dbdd20aSAndroid Build Coastguard Worker }
115*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,Empty)116*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, Empty) {
117*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "";
118*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
119*6dbdd20aSAndroid Build Coastguard Worker }
120*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,InvalidTime)121*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, InvalidTime) {
122*6dbdd20aSAndroid Build Coastguard Worker   options.time = "2mb";
123*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_FALSE(CreateConfigFromOptions(options, &config));
124*6dbdd20aSAndroid Build Coastguard Worker }
125*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,InvalidSize)126*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, InvalidSize) {
127*6dbdd20aSAndroid Build Coastguard Worker   options.max_file_size = "2s";
128*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_FALSE(CreateConfigFromOptions(options, &config));
129*6dbdd20aSAndroid Build Coastguard Worker }
130*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,FullConfig)131*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, FullConfig) {
132*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "100mb";
133*6dbdd20aSAndroid Build Coastguard Worker   options.max_file_size = "1gb";
134*6dbdd20aSAndroid Build Coastguard Worker   options.time = "1h";
135*6dbdd20aSAndroid Build Coastguard Worker   options.categories.push_back("sw");
136*6dbdd20aSAndroid Build Coastguard Worker   options.categories.push_back("sched/sched_switch");
137*6dbdd20aSAndroid Build Coastguard Worker   options.atrace_apps.push_back("com.android.chrome");
138*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
139*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.duration_ms(), 60 * 60 * 1000u);
140*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.flush_period_ms(), 30 * 1000u);
141*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.max_file_size_bytes(), 1 * 1024 * 1024 * 1024u);
142*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.buffers()[0].size_kb(), 100 * 1024u);
143*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.data_sources()[0].config().name(), "linux.ftrace");
144*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.data_sources()[0].config().target_buffer(), 0u);
145*6dbdd20aSAndroid Build Coastguard Worker 
146*6dbdd20aSAndroid Build Coastguard Worker   protos::gen::FtraceConfig ftrace;
147*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(ftrace.ParseFromString(
148*6dbdd20aSAndroid Build Coastguard Worker       config.data_sources()[0].config().ftrace_config_raw()));
149*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_THAT(ftrace.ftrace_events(), Contains("sched/sched_switch"));
150*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_TRUE(ftrace.symbolize_ksyms());
151*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_THAT(ftrace.atrace_categories(), Contains("sw"));
152*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_THAT(ftrace.atrace_apps(), Contains("com.android.chrome"));
153*6dbdd20aSAndroid Build Coastguard Worker }
154*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,OnlyHypervisorTraces)155*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, OnlyHypervisorTraces) {
156*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "100mb";
157*6dbdd20aSAndroid Build Coastguard Worker   options.time = "10s";
158*6dbdd20aSAndroid Build Coastguard Worker   options.categories.push_back("hyp");
159*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
160*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.duration_ms(), 10 * 1000u);
161*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.buffers()[0].size_kb(), 100 * 1024u);
162*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.data_sources()[0].config().name(), "linux.ftrace");
163*6dbdd20aSAndroid Build Coastguard Worker   protos::gen::FtraceConfig ftrace;
164*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(ftrace.ParseFromString(
165*6dbdd20aSAndroid Build Coastguard Worker       config.data_sources()[0].config().ftrace_config_raw()));
166*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_THAT(ftrace.ftrace_events(), Contains("hyp/*"));
167*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(ftrace.instance_name(), "hyp");
168*6dbdd20aSAndroid Build Coastguard Worker }
169*6dbdd20aSAndroid Build Coastguard Worker 
TEST_F(CreateConfigFromOptionsTest,BothHypervisorAndHostFtraceTraces)170*6dbdd20aSAndroid Build Coastguard Worker TEST_F(CreateConfigFromOptionsTest, BothHypervisorAndHostFtraceTraces) {
171*6dbdd20aSAndroid Build Coastguard Worker   options.buffer_size = "100mb";
172*6dbdd20aSAndroid Build Coastguard Worker   options.time = "10s";
173*6dbdd20aSAndroid Build Coastguard Worker   options.categories.push_back("hyp");
174*6dbdd20aSAndroid Build Coastguard Worker   options.categories.push_back("sw");
175*6dbdd20aSAndroid Build Coastguard Worker   options.categories.push_back("sched/sched_switch");
176*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(CreateConfigFromOptions(options, &config));
177*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.duration_ms(), 10 * 1000u);
178*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.buffers()[0].size_kb(), 100 * 1024u);
179*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.buffers()[0].size_kb(), 100 * 1024u);
180*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.data_sources()[0].config().name(), "linux.ftrace");
181*6dbdd20aSAndroid Build Coastguard Worker   {
182*6dbdd20aSAndroid Build Coastguard Worker     protos::gen::FtraceConfig ftrace;
183*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_TRUE(ftrace.ParseFromString(
184*6dbdd20aSAndroid Build Coastguard Worker         config.data_sources()[0].config().ftrace_config_raw()));
185*6dbdd20aSAndroid Build Coastguard Worker     EXPECT_THAT(ftrace.ftrace_events(), Contains("sched/sched_switch"));
186*6dbdd20aSAndroid Build Coastguard Worker     EXPECT_THAT(ftrace.atrace_categories(), Contains("sw"));
187*6dbdd20aSAndroid Build Coastguard Worker     EXPECT_TRUE(ftrace.symbolize_ksyms());
188*6dbdd20aSAndroid Build Coastguard Worker   }
189*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(config.data_sources()[1].config().name(), "linux.ftrace");
190*6dbdd20aSAndroid Build Coastguard Worker   {
191*6dbdd20aSAndroid Build Coastguard Worker     protos::gen::FtraceConfig ftrace;
192*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_TRUE(ftrace.ParseFromString(
193*6dbdd20aSAndroid Build Coastguard Worker         config.data_sources()[1].config().ftrace_config_raw()));
194*6dbdd20aSAndroid Build Coastguard Worker     EXPECT_THAT(ftrace.ftrace_events(), Contains("hyp/*"));
195*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_EQ(ftrace.instance_name(), "hyp");
196*6dbdd20aSAndroid Build Coastguard Worker   }
197*6dbdd20aSAndroid Build Coastguard Worker }
198*6dbdd20aSAndroid Build Coastguard Worker 
199*6dbdd20aSAndroid Build Coastguard Worker }  // namespace
200*6dbdd20aSAndroid Build Coastguard Worker }  // namespace perfetto
201