/* * Copyright (C) 2023 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include "perfetto/ext/base/subprocess.h" #include "perfetto/ext/base/utils.h" #include "protos/perfetto/trace_processor/trace_processor.gen.h" #include "test/gtest_and_gmock.h" #include "test/test_helper.h" namespace perfetto::trace_processor { namespace { using TraceProcessorRpc = protos::gen::TraceProcessorRpc; using TraceProcessorRpcStream = protos::gen::TraceProcessorRpcStream; using CellsBatch = protos::gen::QueryResult::CellsBatch; using testing::AllOf; using testing::ElementsAre; using testing::IsEmpty; using testing::Property; using testing::SizeIs; const std::string_view kSimpleSystrace = R"(# tracer surfaceflinger-598 ( 598) [004] .... 10852.771242: tracing_mark_write: B|598|some event surfaceflinger-598 ( 598) [004] .... 10852.771245: tracing_mark_write: E|598 )"; TEST(TraceProcessorShellIntegrationTest, StdioSimpleRequestResponse) { TraceProcessorRpcStream req; auto* rpc = req.add_msg(); rpc->set_append_trace_data(kSimpleSystrace.data(), kSimpleSystrace.size()); rpc->set_request(TraceProcessorRpc::TPM_APPEND_TRACE_DATA); rpc = req.add_msg(); rpc->set_request(TraceProcessorRpc::TPM_FINALIZE_TRACE_DATA); rpc = req.add_msg(); rpc->set_request(TraceProcessorRpc::TPM_QUERY_STREAMING); rpc->mutable_query_args()->set_sql_query("SELECT ts, dur FROM slice"); base::Subprocess process( {base::GetCurExecutableDir() + "/trace_processor_shell", "--stdiod"}); process.args.stdin_mode = base::Subprocess::InputMode::kBuffer; process.args.stdout_mode = base::Subprocess::OutputMode::kBuffer; process.args.stderr_mode = base::Subprocess::OutputMode::kInherit; process.args.input = req.SerializeAsString(); process.Start(); ASSERT_TRUE(process.Wait(kDefaultTestTimeoutMs)); TraceProcessorRpcStream stream; stream.ParseFromString(process.output()); ASSERT_THAT(stream.msg(), ElementsAre(Property(&TraceProcessorRpc::response, TraceProcessorRpc::TPM_APPEND_TRACE_DATA), Property(&TraceProcessorRpc::response, TraceProcessorRpc::TPM_FINALIZE_TRACE_DATA), Property(&TraceProcessorRpc::response, TraceProcessorRpc::TPM_QUERY_STREAMING))); ASSERT_THAT(stream.msg()[0].append_result().error(), IsEmpty()); ASSERT_THAT(stream.msg()[2].query_result().batch(), SizeIs(1)); ASSERT_THAT(stream.msg()[2].query_result().batch()[0].varint_cells(), ElementsAre(10852771242000, 3000)); } } // namespace } // namespace perfetto::trace_processor