xref: /aosp_15_r20/external/perfetto/test/traced_integrationtest.cc (revision 6dbdd20afdafa5e3ca9b8809fa73465d530080dc)
1*6dbdd20aSAndroid Build Coastguard Worker /*
2*6dbdd20aSAndroid Build Coastguard Worker  * Copyright (C) 2022 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 <string>
18*6dbdd20aSAndroid Build Coastguard Worker 
19*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/base/build_config.h"
20*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/base/logging.h"
21*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/base/file_utils.h"
22*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/base/pipe.h"
23*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/base/scoped_file.h"
24*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/base/string_utils.h"
25*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/base/temp_file.h"
26*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/base/unix_socket.h"
27*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/base/utils.h"
28*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/tracing/core/commit_data_request.h"
29*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/tracing/core/null_consumer_endpoint_for_testing.h"
30*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/tracing/core/trace_packet.h"
31*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/ext/tracing/core/tracing_service.h"
32*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/protozero/scattered_heap_buffer.h"
33*6dbdd20aSAndroid Build Coastguard Worker #include "perfetto/tracing/core/tracing_service_state.h"
34*6dbdd20aSAndroid Build Coastguard Worker #include "src/base/test/test_task_runner.h"
35*6dbdd20aSAndroid Build Coastguard Worker #include "src/base/test/utils.h"
36*6dbdd20aSAndroid Build Coastguard Worker #include "src/protozero/filtering/filter_bytecode_generator.h"
37*6dbdd20aSAndroid Build Coastguard Worker #include "test/gtest_and_gmock.h"
38*6dbdd20aSAndroid Build Coastguard Worker #include "test/test_helper.h"
39*6dbdd20aSAndroid Build Coastguard Worker 
40*6dbdd20aSAndroid Build Coastguard Worker #include "protos/perfetto/config/test_config.gen.h"
41*6dbdd20aSAndroid Build Coastguard Worker #include "protos/perfetto/config/trace_config.gen.h"
42*6dbdd20aSAndroid Build Coastguard Worker #include "protos/perfetto/trace/perfetto/tracing_service_event.gen.h"
43*6dbdd20aSAndroid Build Coastguard Worker #include "protos/perfetto/trace/test_event.gen.h"
44*6dbdd20aSAndroid Build Coastguard Worker #include "protos/perfetto/trace/trace.gen.h"
45*6dbdd20aSAndroid Build Coastguard Worker #include "protos/perfetto/trace/trace_packet.gen.h"
46*6dbdd20aSAndroid Build Coastguard Worker #include "protos/perfetto/trace/trace_packet.pbzero.h"
47*6dbdd20aSAndroid Build Coastguard Worker 
48*6dbdd20aSAndroid Build Coastguard Worker namespace perfetto {
49*6dbdd20aSAndroid Build Coastguard Worker 
50*6dbdd20aSAndroid Build Coastguard Worker namespace {
51*6dbdd20aSAndroid Build Coastguard Worker 
52*6dbdd20aSAndroid Build Coastguard Worker using ::testing::ContainsRegex;
53*6dbdd20aSAndroid Build Coastguard Worker using ::testing::Each;
54*6dbdd20aSAndroid Build Coastguard Worker using ::testing::ElementsAreArray;
55*6dbdd20aSAndroid Build Coastguard Worker using ::testing::HasSubstr;
56*6dbdd20aSAndroid Build Coastguard Worker using ::testing::Property;
57*6dbdd20aSAndroid Build Coastguard Worker using ::testing::SizeIs;
58*6dbdd20aSAndroid Build Coastguard Worker 
59*6dbdd20aSAndroid Build Coastguard Worker }  // namespace
60*6dbdd20aSAndroid Build Coastguard Worker 
TEST(PerfettoTracedIntegrationTest,NullConsumerEndpointBuilds)61*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, NullConsumerEndpointBuilds) {
62*6dbdd20aSAndroid Build Coastguard Worker   NullConsumerEndpointForTesting npe;
63*6dbdd20aSAndroid Build Coastguard Worker   npe.StartTracing();
64*6dbdd20aSAndroid Build Coastguard Worker }
65*6dbdd20aSAndroid Build Coastguard Worker 
TEST(PerfettoTracedIntegrationTest,TestFakeProducer)66*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, TestFakeProducer) {
67*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
68*6dbdd20aSAndroid Build Coastguard Worker 
69*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner);
70*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
71*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectFakeProducer();
72*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
73*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
74*6dbdd20aSAndroid Build Coastguard Worker 
75*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
76*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(1024);
77*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(200);
78*6dbdd20aSAndroid Build Coastguard Worker 
79*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
80*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
81*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_target_buffer(0);
82*6dbdd20aSAndroid Build Coastguard Worker 
83*6dbdd20aSAndroid Build Coastguard Worker   static constexpr size_t kNumPackets = 12;
84*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kRandomSeed = 42;
85*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kMsgSize = 1024;
86*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_seed(kRandomSeed);
87*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_count(kNumPackets);
88*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_size(kMsgSize);
89*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_send_batch_on_register(true);
90*6dbdd20aSAndroid Build Coastguard Worker 
91*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config);
92*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForTracingDisabled();
93*6dbdd20aSAndroid Build Coastguard Worker 
94*6dbdd20aSAndroid Build Coastguard Worker   helper.ReadData();
95*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForReadData();
96*6dbdd20aSAndroid Build Coastguard Worker 
97*6dbdd20aSAndroid Build Coastguard Worker   const auto& packets = helper.trace();
98*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(packets.size(), kNumPackets);
99*6dbdd20aSAndroid Build Coastguard Worker 
100*6dbdd20aSAndroid Build Coastguard Worker   std::minstd_rand0 rnd_engine(kRandomSeed);
101*6dbdd20aSAndroid Build Coastguard Worker   for (const auto& packet : packets) {
102*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_TRUE(packet.has_for_testing());
103*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_EQ(packet.for_testing().seq_value(), rnd_engine());
104*6dbdd20aSAndroid Build Coastguard Worker   }
105*6dbdd20aSAndroid Build Coastguard Worker }
106*6dbdd20aSAndroid Build Coastguard Worker 
TEST(PerfettoTracedIntegrationTest,VeryLargePackets)107*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, VeryLargePackets) {
108*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
109*6dbdd20aSAndroid Build Coastguard Worker 
110*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner);
111*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
112*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectFakeProducer();
113*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
114*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
115*6dbdd20aSAndroid Build Coastguard Worker 
116*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
117*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(4096 * 10);
118*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(500);
119*6dbdd20aSAndroid Build Coastguard Worker 
120*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
121*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
122*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_target_buffer(0);
123*6dbdd20aSAndroid Build Coastguard Worker 
124*6dbdd20aSAndroid Build Coastguard Worker   static constexpr size_t kNumPackets = 7;
125*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kRandomSeed = 42;
126*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kMsgSize = 1024 * 1024 - 42;
127*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_seed(kRandomSeed);
128*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_count(kNumPackets);
129*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_size(kMsgSize);
130*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_send_batch_on_register(true);
131*6dbdd20aSAndroid Build Coastguard Worker 
132*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config);
133*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForTracingDisabled();
134*6dbdd20aSAndroid Build Coastguard Worker 
135*6dbdd20aSAndroid Build Coastguard Worker   helper.ReadData();
136*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForReadData(/* read_count */ 0, /* timeout_ms */ 10000);
137*6dbdd20aSAndroid Build Coastguard Worker 
138*6dbdd20aSAndroid Build Coastguard Worker   const auto& packets = helper.trace();
139*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(packets.size(), kNumPackets);
140*6dbdd20aSAndroid Build Coastguard Worker 
141*6dbdd20aSAndroid Build Coastguard Worker   std::minstd_rand0 rnd_engine(kRandomSeed);
142*6dbdd20aSAndroid Build Coastguard Worker   for (const auto& packet : packets) {
143*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_TRUE(packet.has_for_testing());
144*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_EQ(packet.for_testing().seq_value(), rnd_engine());
145*6dbdd20aSAndroid Build Coastguard Worker     size_t msg_size = packet.for_testing().str().size();
146*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_EQ(kMsgSize, msg_size);
147*6dbdd20aSAndroid Build Coastguard Worker     for (size_t i = 0; i < msg_size; i++)
148*6dbdd20aSAndroid Build Coastguard Worker       ASSERT_EQ(i < msg_size - 1 ? '.' : 0, packet.for_testing().str()[i]);
149*6dbdd20aSAndroid Build Coastguard Worker   }
150*6dbdd20aSAndroid Build Coastguard Worker }
151*6dbdd20aSAndroid Build Coastguard Worker 
152*6dbdd20aSAndroid Build Coastguard Worker // This is a regression test see b/169051440 for context.
153*6dbdd20aSAndroid Build Coastguard Worker //
154*6dbdd20aSAndroid Build Coastguard Worker // In this test we ensure that traced will not crash if a Producer stops
155*6dbdd20aSAndroid Build Coastguard Worker // responding or draining the socket (i.e. after we fill up the IPC buffer
156*6dbdd20aSAndroid Build Coastguard Worker // traced doesn't block on trying to write to the IPC buffer and watchdog
157*6dbdd20aSAndroid Build Coastguard Worker // doesn't kill it).
TEST(PerfettoTracedIntegrationTest,UnresponsiveProducer)158*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, UnresponsiveProducer) {
159*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
160*6dbdd20aSAndroid Build Coastguard Worker 
161*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner);
162*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
163*6dbdd20aSAndroid Build Coastguard Worker   auto* producer = helper.ConnectFakeProducer();
164*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
165*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
166*6dbdd20aSAndroid Build Coastguard Worker 
167*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
168*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(4096 * 10);
169*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(100);
170*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_flush_timeout_ms(1);
171*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_data_source_stop_timeout_ms(1);
172*6dbdd20aSAndroid Build Coastguard Worker 
173*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
174*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
175*6dbdd20aSAndroid Build Coastguard Worker 
176*6dbdd20aSAndroid Build Coastguard Worker   static constexpr size_t kNumPackets = 1;
177*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kRandomSeed = 42;
178*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kMsgSize = 1024 * 1024 - 42;
179*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_seed(kRandomSeed);
180*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_count(kNumPackets);
181*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_size(kMsgSize);
182*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_send_batch_on_register(true);
183*6dbdd20aSAndroid Build Coastguard Worker 
184*6dbdd20aSAndroid Build Coastguard Worker   // This string is just used to make the StartDataSource IPC larger.
185*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_legacy_config(std::string(8192, '.'));
186*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_target_buffer(0);
187*6dbdd20aSAndroid Build Coastguard Worker 
188*6dbdd20aSAndroid Build Coastguard Worker   // Run one legit trace, this ensures that the producer above is
189*6dbdd20aSAndroid Build Coastguard Worker   // valid and correct and mirrors real life producers.
190*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config);
191*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForProducerEnabled();
192*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForTracingDisabled();
193*6dbdd20aSAndroid Build Coastguard Worker 
194*6dbdd20aSAndroid Build Coastguard Worker   helper.ReadData();
195*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForReadData(/* read_count */ 0, /* timeout_ms */ 10000);
196*6dbdd20aSAndroid Build Coastguard Worker 
197*6dbdd20aSAndroid Build Coastguard Worker   const auto& packets = helper.trace();
198*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(packets.size(), 1u);
199*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(packets[0].has_for_testing());
200*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_FALSE(packets[0].for_testing().str().empty());
201*6dbdd20aSAndroid Build Coastguard Worker   helper.FreeBuffers();
202*6dbdd20aSAndroid Build Coastguard Worker 
203*6dbdd20aSAndroid Build Coastguard Worker   // Switch the producer to ignoring the IPC socket. On a pixel 4 it took 13
204*6dbdd20aSAndroid Build Coastguard Worker   // traces to fill up the IPC buffer and cause traced to block (and eventually
205*6dbdd20aSAndroid Build Coastguard Worker   // watchdog to kill it).
206*6dbdd20aSAndroid Build Coastguard Worker   helper.producer_thread()->get()->RemoveFileDescriptorWatch(
207*6dbdd20aSAndroid Build Coastguard Worker       producer->unix_socket_fd());
208*6dbdd20aSAndroid Build Coastguard Worker 
209*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(1);
210*6dbdd20aSAndroid Build Coastguard Worker   for (uint32_t i = 0u; i < 15u; i++) {
211*6dbdd20aSAndroid Build Coastguard Worker     helper.StartTracing(trace_config, base::ScopedFile());
212*6dbdd20aSAndroid Build Coastguard Worker     helper.WaitForTracingDisabled(/* timeout_ms = */ 20000);
213*6dbdd20aSAndroid Build Coastguard Worker     helper.FreeBuffers();
214*6dbdd20aSAndroid Build Coastguard Worker   }
215*6dbdd20aSAndroid Build Coastguard Worker   // We need to readd the FileDescriptor (otherwise when the UnixSocket attempts
216*6dbdd20aSAndroid Build Coastguard Worker   // to remove it a the FakeProducer is destroyed will hit a CHECK failure.
217*6dbdd20aSAndroid Build Coastguard Worker   helper.producer_thread()->get()->AddFileDescriptorWatch(
218*6dbdd20aSAndroid Build Coastguard Worker       producer->unix_socket_fd(), []() {});
219*6dbdd20aSAndroid Build Coastguard Worker }
220*6dbdd20aSAndroid Build Coastguard Worker 
TEST(PerfettoTracedIntegrationTest,DetachAndReattach)221*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, DetachAndReattach) {
222*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
223*6dbdd20aSAndroid Build Coastguard Worker 
224*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
225*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(1024);
226*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(10000);  // Max timeout, session is ended before.
227*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
228*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
229*6dbdd20aSAndroid Build Coastguard Worker   static constexpr size_t kNumPackets = 11;
230*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_count(kNumPackets);
231*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_size(32);
232*6dbdd20aSAndroid Build Coastguard Worker 
233*6dbdd20aSAndroid Build Coastguard Worker   // Enable tracing and detach as soon as it gets started.
234*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner);
235*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
236*6dbdd20aSAndroid Build Coastguard Worker   auto* fake_producer = helper.ConnectFakeProducer();
237*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
238*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
239*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config);
240*6dbdd20aSAndroid Build Coastguard Worker 
241*6dbdd20aSAndroid Build Coastguard Worker   // Detach.
242*6dbdd20aSAndroid Build Coastguard Worker   helper.DetachConsumer("key");
243*6dbdd20aSAndroid Build Coastguard Worker 
244*6dbdd20aSAndroid Build Coastguard Worker   // Write data while detached.
245*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForProducerEnabled();
246*6dbdd20aSAndroid Build Coastguard Worker   auto on_data_written = task_runner.CreateCheckpoint("data_written");
247*6dbdd20aSAndroid Build Coastguard Worker   fake_producer->ProduceEventBatch(helper.WrapTask(on_data_written));
248*6dbdd20aSAndroid Build Coastguard Worker   task_runner.RunUntilCheckpoint("data_written");
249*6dbdd20aSAndroid Build Coastguard Worker 
250*6dbdd20aSAndroid Build Coastguard Worker   // Then reattach the consumer.
251*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
252*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
253*6dbdd20aSAndroid Build Coastguard Worker   helper.AttachConsumer("key");
254*6dbdd20aSAndroid Build Coastguard Worker 
255*6dbdd20aSAndroid Build Coastguard Worker   helper.DisableTracing();
256*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForTracingDisabled();
257*6dbdd20aSAndroid Build Coastguard Worker 
258*6dbdd20aSAndroid Build Coastguard Worker   helper.ReadData();
259*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForReadData();
260*6dbdd20aSAndroid Build Coastguard Worker   const auto& packets = helper.trace();
261*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(packets.size(), kNumPackets);
262*6dbdd20aSAndroid Build Coastguard Worker }
263*6dbdd20aSAndroid Build Coastguard Worker 
264*6dbdd20aSAndroid Build Coastguard Worker // Tests that a detached trace session is automatically cleaned up if the
265*6dbdd20aSAndroid Build Coastguard Worker // consumer doesn't re-attach before its expiration time.
TEST(PerfettoTracedIntegrationTest,ReattachFailsAfterTimeout)266*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, ReattachFailsAfterTimeout) {
267*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
268*6dbdd20aSAndroid Build Coastguard Worker 
269*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
270*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(1024);
271*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(250);
272*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_write_into_file(true);
273*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_file_write_period_ms(100000);
274*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
275*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
276*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_count(1);
277*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_size(32);
278*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_send_batch_on_register(true);
279*6dbdd20aSAndroid Build Coastguard Worker 
280*6dbdd20aSAndroid Build Coastguard Worker   // Enable tracing and detach as soon as it gets started.
281*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner);
282*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
283*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectFakeProducer();
284*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
285*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
286*6dbdd20aSAndroid Build Coastguard Worker 
287*6dbdd20aSAndroid Build Coastguard Worker   auto pipe_pair = base::Pipe::Create();
288*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config, std::move(pipe_pair.wr));
289*6dbdd20aSAndroid Build Coastguard Worker 
290*6dbdd20aSAndroid Build Coastguard Worker   // Detach.
291*6dbdd20aSAndroid Build Coastguard Worker   helper.DetachConsumer("key");
292*6dbdd20aSAndroid Build Coastguard Worker 
293*6dbdd20aSAndroid Build Coastguard Worker   // Use the file EOF (write end closed) as a way to detect when the trace
294*6dbdd20aSAndroid Build Coastguard Worker   // session is ended.
295*6dbdd20aSAndroid Build Coastguard Worker   char buf[1024];
296*6dbdd20aSAndroid Build Coastguard Worker   while (PERFETTO_EINTR(read(*pipe_pair.rd, buf, sizeof(buf))) > 0) {
297*6dbdd20aSAndroid Build Coastguard Worker   }
298*6dbdd20aSAndroid Build Coastguard Worker 
299*6dbdd20aSAndroid Build Coastguard Worker   // Give some margin for the tracing service to destroy the session.
300*6dbdd20aSAndroid Build Coastguard Worker   usleep(250000);
301*6dbdd20aSAndroid Build Coastguard Worker 
302*6dbdd20aSAndroid Build Coastguard Worker   // Reconnect and find out that it's too late and the session is gone.
303*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
304*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
305*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_FALSE(helper.AttachConsumer("key"));
306*6dbdd20aSAndroid Build Coastguard Worker }
307*6dbdd20aSAndroid Build Coastguard Worker 
TEST(PerfettoTracedIntegrationTest,TestProducerProvidedSMB)308*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, TestProducerProvidedSMB) {
309*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
310*6dbdd20aSAndroid Build Coastguard Worker 
311*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner);
312*6dbdd20aSAndroid Build Coastguard Worker   helper.CreateProducerProvidedSmb();
313*6dbdd20aSAndroid Build Coastguard Worker 
314*6dbdd20aSAndroid Build Coastguard Worker   protos::gen::TestConfig test_config;
315*6dbdd20aSAndroid Build Coastguard Worker   test_config.set_seed(42);
316*6dbdd20aSAndroid Build Coastguard Worker   test_config.set_message_count(1);
317*6dbdd20aSAndroid Build Coastguard Worker   test_config.set_message_size(1024);
318*6dbdd20aSAndroid Build Coastguard Worker   test_config.set_send_batch_on_register(true);
319*6dbdd20aSAndroid Build Coastguard Worker 
320*6dbdd20aSAndroid Build Coastguard Worker   // Write a first batch before connection.
321*6dbdd20aSAndroid Build Coastguard Worker   helper.ProduceStartupEventBatch(test_config);
322*6dbdd20aSAndroid Build Coastguard Worker 
323*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
324*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectFakeProducer();
325*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
326*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
327*6dbdd20aSAndroid Build Coastguard Worker 
328*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
329*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(1024);
330*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(200);
331*6dbdd20aSAndroid Build Coastguard Worker 
332*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
333*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
334*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_target_buffer(0);
335*6dbdd20aSAndroid Build Coastguard Worker   *ds_config->mutable_for_testing() = test_config;
336*6dbdd20aSAndroid Build Coastguard Worker 
337*6dbdd20aSAndroid Build Coastguard Worker   // The data source is configured to emit another batch when it is started via
338*6dbdd20aSAndroid Build Coastguard Worker   // send_batch_on_register in the TestConfig.
339*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config);
340*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForTracingDisabled();
341*6dbdd20aSAndroid Build Coastguard Worker 
342*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_TRUE(helper.IsShmemProvidedByProducer());
343*6dbdd20aSAndroid Build Coastguard Worker 
344*6dbdd20aSAndroid Build Coastguard Worker   helper.ReadData();
345*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForReadData();
346*6dbdd20aSAndroid Build Coastguard Worker 
347*6dbdd20aSAndroid Build Coastguard Worker   const auto& packets = helper.trace();
348*6dbdd20aSAndroid Build Coastguard Worker   // We should have produced two batches, one before the producer connected and
349*6dbdd20aSAndroid Build Coastguard Worker   // another one when the data source was started.
350*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(packets.size(), 2u);
351*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(packets[0].has_for_testing());
352*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_TRUE(packets[1].has_for_testing());
353*6dbdd20aSAndroid Build Coastguard Worker }
354*6dbdd20aSAndroid Build Coastguard Worker 
355*6dbdd20aSAndroid Build Coastguard Worker // Regression test for b/153142114.
TEST(PerfettoTracedIntegrationTest,QueryServiceStateLargeResponse)356*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, QueryServiceStateLargeResponse) {
357*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
358*6dbdd20aSAndroid Build Coastguard Worker 
359*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner);
360*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
361*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
362*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
363*6dbdd20aSAndroid Build Coastguard Worker 
364*6dbdd20aSAndroid Build Coastguard Worker   FakeProducer* producer = helper.ConnectFakeProducer();
365*6dbdd20aSAndroid Build Coastguard Worker 
366*6dbdd20aSAndroid Build Coastguard Worker   // Register 5 data sources with very large descriptors. Each descriptor will
367*6dbdd20aSAndroid Build Coastguard Worker   // max out the IPC message size, so that the service has no other choice
368*6dbdd20aSAndroid Build Coastguard Worker   // than chunking them.
369*6dbdd20aSAndroid Build Coastguard Worker   std::map<std::string, std::string> ds_expected;
370*6dbdd20aSAndroid Build Coastguard Worker   for (int i = 0; i < 5; i++) {
371*6dbdd20aSAndroid Build Coastguard Worker     DataSourceDescriptor dsd;
372*6dbdd20aSAndroid Build Coastguard Worker     std::string name = "big_ds_" + std::to_string(i);
373*6dbdd20aSAndroid Build Coastguard Worker     dsd.set_name(name);
374*6dbdd20aSAndroid Build Coastguard Worker     std::string descriptor(ipc::kIPCBufferSize - 64,
375*6dbdd20aSAndroid Build Coastguard Worker                            static_cast<char>((' ' + i) % 64));
376*6dbdd20aSAndroid Build Coastguard Worker     dsd.set_track_event_descriptor_raw(descriptor);
377*6dbdd20aSAndroid Build Coastguard Worker     ds_expected[name] = std::move(descriptor);
378*6dbdd20aSAndroid Build Coastguard Worker     producer->RegisterDataSource(dsd);
379*6dbdd20aSAndroid Build Coastguard Worker   }
380*6dbdd20aSAndroid Build Coastguard Worker 
381*6dbdd20aSAndroid Build Coastguard Worker   // Linearize the producer with the service. We need to make sure that all the
382*6dbdd20aSAndroid Build Coastguard Worker   // RegisterDataSource() calls above have been seen by the service before
383*6dbdd20aSAndroid Build Coastguard Worker   // continuing.
384*6dbdd20aSAndroid Build Coastguard Worker   helper.SyncAndWaitProducer();
385*6dbdd20aSAndroid Build Coastguard Worker 
386*6dbdd20aSAndroid Build Coastguard Worker   // Now invoke QueryServiceState() and wait for the reply. The service will
387*6dbdd20aSAndroid Build Coastguard Worker   // send 6 (1 + 5) IPCs which will be merged together in
388*6dbdd20aSAndroid Build Coastguard Worker   // producer_ipc_client_impl.cc.
389*6dbdd20aSAndroid Build Coastguard Worker   auto svc_state = helper.QueryServiceStateAndWait();
390*6dbdd20aSAndroid Build Coastguard Worker 
391*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_GE(svc_state.producers().size(), 1u);
392*6dbdd20aSAndroid Build Coastguard Worker 
393*6dbdd20aSAndroid Build Coastguard Worker   std::map<std::string, std::string> ds_found;
394*6dbdd20aSAndroid Build Coastguard Worker   for (const auto& ds : svc_state.data_sources()) {
395*6dbdd20aSAndroid Build Coastguard Worker     if (!base::StartsWith(ds.ds_descriptor().name(), "big_ds_"))
396*6dbdd20aSAndroid Build Coastguard Worker       continue;
397*6dbdd20aSAndroid Build Coastguard Worker     ds_found[ds.ds_descriptor().name()] =
398*6dbdd20aSAndroid Build Coastguard Worker         ds.ds_descriptor().track_event_descriptor_raw();
399*6dbdd20aSAndroid Build Coastguard Worker   }
400*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_THAT(ds_found, ElementsAreArray(ds_expected));
401*6dbdd20aSAndroid Build Coastguard Worker }
402*6dbdd20aSAndroid Build Coastguard Worker 
403*6dbdd20aSAndroid Build Coastguard Worker // Regression test for b/195065199. Check that trace filtering works when a
404*6dbdd20aSAndroid Build Coastguard Worker // packet size exceeds the IPC limit. This tests that the tracing service, when
405*6dbdd20aSAndroid Build Coastguard Worker // reassembling packets after filtering, doesn't "overglue" them. They still
406*6dbdd20aSAndroid Build Coastguard Worker // need to be slice-able to fit into the ReadBuffers ipc.
TEST(PerfettoTracedIntegrationTest,TraceFilterLargePackets)407*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, TraceFilterLargePackets) {
408*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
409*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner);
410*6dbdd20aSAndroid Build Coastguard Worker 
411*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
412*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectFakeProducer();
413*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
414*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
415*6dbdd20aSAndroid Build Coastguard Worker 
416*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
417*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(1024 * 16);
418*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(500);
419*6dbdd20aSAndroid Build Coastguard Worker   auto* prod_config = trace_config.add_producers();
420*6dbdd20aSAndroid Build Coastguard Worker   prod_config->set_producer_name("android.perfetto.FakeProducer");
421*6dbdd20aSAndroid Build Coastguard Worker   prod_config->set_shm_size_kb(1024 * 16);
422*6dbdd20aSAndroid Build Coastguard Worker   prod_config->set_page_size_kb(32);
423*6dbdd20aSAndroid Build Coastguard Worker 
424*6dbdd20aSAndroid Build Coastguard Worker   static constexpr size_t kNumPackets = 3;
425*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kRandomSeed = 42;
426*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kMsgSize = 8 * ipc::kIPCBufferSize;
427*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
428*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
429*6dbdd20aSAndroid Build Coastguard Worker   auto* test_config = ds_config->mutable_for_testing();
430*6dbdd20aSAndroid Build Coastguard Worker   test_config->set_seed(kRandomSeed);
431*6dbdd20aSAndroid Build Coastguard Worker   test_config->set_message_count(kNumPackets);
432*6dbdd20aSAndroid Build Coastguard Worker   test_config->set_message_size(kMsgSize);
433*6dbdd20aSAndroid Build Coastguard Worker   test_config->set_send_batch_on_register(true);
434*6dbdd20aSAndroid Build Coastguard Worker 
435*6dbdd20aSAndroid Build Coastguard Worker   protozero::FilterBytecodeGenerator filt;
436*6dbdd20aSAndroid Build Coastguard Worker   // Message 0: root Trace proto.
437*6dbdd20aSAndroid Build Coastguard Worker   filt.AddNestedField(1 /* root trace.packet*/, 1);
438*6dbdd20aSAndroid Build Coastguard Worker   filt.EndMessage();
439*6dbdd20aSAndroid Build Coastguard Worker 
440*6dbdd20aSAndroid Build Coastguard Worker   // Message 1: TracePacket proto. Allow all fields.
441*6dbdd20aSAndroid Build Coastguard Worker   filt.AddSimpleFieldRange(1, 1000);
442*6dbdd20aSAndroid Build Coastguard Worker   filt.EndMessage();
443*6dbdd20aSAndroid Build Coastguard Worker 
444*6dbdd20aSAndroid Build Coastguard Worker   trace_config.mutable_trace_filter()->set_bytecode(filt.Serialize());
445*6dbdd20aSAndroid Build Coastguard Worker 
446*6dbdd20aSAndroid Build Coastguard Worker   // The data source is configured to emit another batch when it is started via
447*6dbdd20aSAndroid Build Coastguard Worker   // send_batch_on_register in the TestConfig.
448*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config);
449*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForTracingDisabled();
450*6dbdd20aSAndroid Build Coastguard Worker 
451*6dbdd20aSAndroid Build Coastguard Worker   helper.ReadData();
452*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForReadData(/* read_count */ 0, /* timeout_ms */ 10000);
453*6dbdd20aSAndroid Build Coastguard Worker 
454*6dbdd20aSAndroid Build Coastguard Worker   const std::vector<protos::gen::TracePacket>& packets = helper.trace();
455*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_EQ(packets.size(), kNumPackets);
456*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_THAT(packets,
457*6dbdd20aSAndroid Build Coastguard Worker               Each(Property(&protos::gen::TracePacket::has_for_testing, true)));
458*6dbdd20aSAndroid Build Coastguard Worker   EXPECT_THAT(
459*6dbdd20aSAndroid Build Coastguard Worker       packets,
460*6dbdd20aSAndroid Build Coastguard Worker       Each(Property(&protos::gen::TracePacket::for_testing,
461*6dbdd20aSAndroid Build Coastguard Worker                     Property(&protos::gen::TestEvent::str, SizeIs(kMsgSize)))));
462*6dbdd20aSAndroid Build Coastguard Worker }
463*6dbdd20aSAndroid Build Coastguard Worker 
464*6dbdd20aSAndroid Build Coastguard Worker #if (PERFETTO_BUILDFLAG(PERFETTO_START_DAEMONS) && \
465*6dbdd20aSAndroid Build Coastguard Worker      PERFETTO_BUILDFLAG(PERFETTO_OS_ANDROID)) ||   \
466*6dbdd20aSAndroid Build Coastguard Worker     PERFETTO_BUILDFLAG(PERFETTO_OS_LINUX)
TEST(PerfettoTracedIntegrationTest,TestMultipleProducerSockets)467*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, TestMultipleProducerSockets) {
468*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
469*6dbdd20aSAndroid Build Coastguard Worker   auto temp_dir = base::TempDir::Create();
470*6dbdd20aSAndroid Build Coastguard Worker 
471*6dbdd20aSAndroid Build Coastguard Worker   std::vector<std::string> producer_socket_names{
472*6dbdd20aSAndroid Build Coastguard Worker       temp_dir.path() + "/producer1.sock",
473*6dbdd20aSAndroid Build Coastguard Worker       temp_dir.path() + "/producer2.sock",
474*6dbdd20aSAndroid Build Coastguard Worker   };
475*6dbdd20aSAndroid Build Coastguard Worker   auto producer_sock_name = base::Join(producer_socket_names, ",");
476*6dbdd20aSAndroid Build Coastguard Worker   // We need to start the service thread for multiple producer sockets.
477*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner, TestHelper::Mode::kStartDaemons,
478*6dbdd20aSAndroid Build Coastguard Worker                     producer_sock_name.c_str());
479*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(helper.num_producers(), 2u);
480*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
481*6dbdd20aSAndroid Build Coastguard Worker   // Setup the 1st producer (default).
482*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectFakeProducer();
483*6dbdd20aSAndroid Build Coastguard Worker   // Setup the 2ns producer.
484*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectFakeProducer(1);
485*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
486*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
487*6dbdd20aSAndroid Build Coastguard Worker 
488*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
489*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(1024);
490*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(200);
491*6dbdd20aSAndroid Build Coastguard Worker 
492*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kMsgSize = 1024;
493*6dbdd20aSAndroid Build Coastguard Worker   // Enable the 1st producer.
494*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
495*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
496*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_target_buffer(0);
497*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_count(12);
498*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_size(kMsgSize);
499*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_send_batch_on_register(true);
500*6dbdd20aSAndroid Build Coastguard Worker   // Enable the 2nd producer.
501*6dbdd20aSAndroid Build Coastguard Worker   ds_config = trace_config.add_data_sources()->mutable_config();
502*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer.1");
503*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_target_buffer(0);
504*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_count(24);
505*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_size(kMsgSize);
506*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_send_batch_on_register(true);
507*6dbdd20aSAndroid Build Coastguard Worker 
508*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config);
509*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForTracingDisabled();
510*6dbdd20aSAndroid Build Coastguard Worker 
511*6dbdd20aSAndroid Build Coastguard Worker   helper.ReadData();
512*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForReadData();
513*6dbdd20aSAndroid Build Coastguard Worker 
514*6dbdd20aSAndroid Build Coastguard Worker   const auto& packets = helper.trace();
515*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(packets.size(), 36u);
516*6dbdd20aSAndroid Build Coastguard Worker 
517*6dbdd20aSAndroid Build Coastguard Worker   for (const auto& packet : packets) {
518*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_TRUE(packet.has_for_testing());
519*6dbdd20aSAndroid Build Coastguard Worker   }
520*6dbdd20aSAndroid Build Coastguard Worker 
521*6dbdd20aSAndroid Build Coastguard Worker   for (const auto& sock_name : producer_socket_names)
522*6dbdd20aSAndroid Build Coastguard Worker     remove(sock_name.c_str());
523*6dbdd20aSAndroid Build Coastguard Worker }
524*6dbdd20aSAndroid Build Coastguard Worker 
TEST(PerfettoTracedIntegrationTest,TestShmemEmulation)525*6dbdd20aSAndroid Build Coastguard Worker TEST(PerfettoTracedIntegrationTest, TestShmemEmulation) {
526*6dbdd20aSAndroid Build Coastguard Worker   base::TestTaskRunner task_runner;
527*6dbdd20aSAndroid Build Coastguard Worker   auto temp_dir = base::TempDir::Create();
528*6dbdd20aSAndroid Build Coastguard Worker 
529*6dbdd20aSAndroid Build Coastguard Worker   std::string sock_name;
530*6dbdd20aSAndroid Build Coastguard Worker   {
531*6dbdd20aSAndroid Build Coastguard Worker     // Set up a server UnixSocket to find an unused TCP port.
532*6dbdd20aSAndroid Build Coastguard Worker     base::UnixSocket::EventListener event_listener;
533*6dbdd20aSAndroid Build Coastguard Worker     auto srv = base::UnixSocket::Listen("127.0.0.1:0", &event_listener,
534*6dbdd20aSAndroid Build Coastguard Worker                                         &task_runner, base::SockFamily::kInet,
535*6dbdd20aSAndroid Build Coastguard Worker                                         base::SockType::kStream);
536*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_TRUE(srv->is_listening());
537*6dbdd20aSAndroid Build Coastguard Worker     sock_name = srv->GetSockAddr();
538*6dbdd20aSAndroid Build Coastguard Worker     // Shut down |srv| here to free the port. It's unlikely that the port will
539*6dbdd20aSAndroid Build Coastguard Worker     // be taken by another process so quickly before we reach the code below.
540*6dbdd20aSAndroid Build Coastguard Worker   }
541*6dbdd20aSAndroid Build Coastguard Worker 
542*6dbdd20aSAndroid Build Coastguard Worker   TestHelper helper(&task_runner, TestHelper::Mode::kStartDaemons,
543*6dbdd20aSAndroid Build Coastguard Worker                     sock_name.c_str());
544*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(helper.num_producers(), 1u);
545*6dbdd20aSAndroid Build Coastguard Worker   helper.StartServiceIfRequired();
546*6dbdd20aSAndroid Build Coastguard Worker   // Setup the 1st producer (default).
547*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectFakeProducer();
548*6dbdd20aSAndroid Build Coastguard Worker   helper.ConnectConsumer();
549*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForConsumerConnect();
550*6dbdd20aSAndroid Build Coastguard Worker 
551*6dbdd20aSAndroid Build Coastguard Worker   TraceConfig trace_config;
552*6dbdd20aSAndroid Build Coastguard Worker   trace_config.add_buffers()->set_size_kb(1024);
553*6dbdd20aSAndroid Build Coastguard Worker   trace_config.set_duration_ms(200);
554*6dbdd20aSAndroid Build Coastguard Worker 
555*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kMsgSize = 1024;
556*6dbdd20aSAndroid Build Coastguard Worker   static constexpr uint32_t kRandomSeed = 42;
557*6dbdd20aSAndroid Build Coastguard Worker   // Enable the producer.
558*6dbdd20aSAndroid Build Coastguard Worker   auto* ds_config = trace_config.add_data_sources()->mutable_config();
559*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_name("android.perfetto.FakeProducer");
560*6dbdd20aSAndroid Build Coastguard Worker   ds_config->set_target_buffer(0);
561*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_seed(kRandomSeed);
562*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_count(12);
563*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_message_size(kMsgSize);
564*6dbdd20aSAndroid Build Coastguard Worker   ds_config->mutable_for_testing()->set_send_batch_on_register(true);
565*6dbdd20aSAndroid Build Coastguard Worker 
566*6dbdd20aSAndroid Build Coastguard Worker   helper.StartTracing(trace_config);
567*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForTracingDisabled();
568*6dbdd20aSAndroid Build Coastguard Worker 
569*6dbdd20aSAndroid Build Coastguard Worker   helper.ReadData();
570*6dbdd20aSAndroid Build Coastguard Worker   helper.WaitForReadData();
571*6dbdd20aSAndroid Build Coastguard Worker 
572*6dbdd20aSAndroid Build Coastguard Worker   const auto& packets = helper.trace();
573*6dbdd20aSAndroid Build Coastguard Worker   ASSERT_EQ(packets.size(), 12u);
574*6dbdd20aSAndroid Build Coastguard Worker 
575*6dbdd20aSAndroid Build Coastguard Worker   std::minstd_rand0 rnd_engine(kRandomSeed);
576*6dbdd20aSAndroid Build Coastguard Worker   for (const auto& packet : packets) {
577*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_TRUE(packet.has_for_testing());
578*6dbdd20aSAndroid Build Coastguard Worker     ASSERT_EQ(packet.for_testing().seq_value(), rnd_engine());
579*6dbdd20aSAndroid Build Coastguard Worker   }
580*6dbdd20aSAndroid Build Coastguard Worker }
581*6dbdd20aSAndroid Build Coastguard Worker #endif
582*6dbdd20aSAndroid Build Coastguard Worker 
583*6dbdd20aSAndroid Build Coastguard Worker }  // namespace perfetto
584