blob: fe795ed8271c8ffd1e173e5725a98f43e9153acd [file] [log] [blame]
/*
* Copyright (C) 2019 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 "src/trace_processor/protozero_to_text.h"
#include "perfetto/protozero/scattered_heap_buffer.h"
#include "protos/perfetto/trace/track_event/chrome_compositor_scheduler_state.pbzero.h"
#include "protos/perfetto/trace/track_event/track_event.pbzero.h"
#include "test/gtest_and_gmock.h"
namespace perfetto {
namespace trace_processor {
namespace {
constexpr size_t kChunkSize = 42;
using ::testing::_;
using ::testing::Eq;
TEST(ProtozeroToTextTest, TrackEventBasic) {
using perfetto::protos::pbzero::TrackEvent;
protozero::HeapBuffered<TrackEvent> msg{kChunkSize, kChunkSize};
msg->set_track_uuid(4);
msg->set_timestamp_delta_us(3);
auto binary_proto = msg.SerializeAsArray();
EXPECT_EQ("track_uuid: 4\ntimestamp_delta_us: 3",
DebugProtozeroToText(".perfetto.protos.TrackEvent",
protozero::ConstBytes{binary_proto.data(),
binary_proto.size()}));
EXPECT_EQ(
"track_uuid: 4 timestamp_delta_us: 3",
ShortDebugProtozeroToText(
".perfetto.protos.TrackEvent",
protozero::ConstBytes{binary_proto.data(), binary_proto.size()}));
}
TEST(ProtozeroToTextTest, TrackEventNestedMsg) {
using perfetto::protos::pbzero::TrackEvent;
protozero::HeapBuffered<TrackEvent> msg{kChunkSize, kChunkSize};
msg->set_track_uuid(4);
auto* state = msg->set_cc_scheduler_state();
state->set_deadline_us(7);
auto* machine = state->set_state_machine();
auto* minor_state = machine->set_minor_state();
minor_state->set_commit_count(8);
state->set_observing_begin_frame_source(true);
msg->set_timestamp_delta_us(3);
auto binary_proto = msg.SerializeAsArray();
EXPECT_EQ(R"(track_uuid: 4
cc_scheduler_state: {
deadline_us: 7
state_machine: {
minor_state: {
commit_count: 8
}
}
observing_begin_frame_source: true
}
timestamp_delta_us: 3)",
DebugProtozeroToText(".perfetto.protos.TrackEvent",
protozero::ConstBytes{binary_proto.data(),
binary_proto.size()}));
EXPECT_EQ(
"track_uuid: 4 cc_scheduler_state: { deadline_us: 7 state_machine: { "
"minor_state: { commit_count: 8 } } observing_begin_frame_source: true } "
"timestamp_delta_us: 3",
ShortDebugProtozeroToText(
".perfetto.protos.TrackEvent",
protozero::ConstBytes{binary_proto.data(), binary_proto.size()}));
}
TEST(ProtozeroToTextTest, TrackEventEnumNames) {
using perfetto::protos::pbzero::TrackEvent;
protozero::HeapBuffered<TrackEvent> msg{kChunkSize, kChunkSize};
msg->set_type(TrackEvent::TYPE_SLICE_BEGIN);
auto binary_proto = msg.SerializeAsArray();
EXPECT_EQ("type: TYPE_SLICE_BEGIN",
DebugProtozeroToText(".perfetto.protos.TrackEvent",
protozero::ConstBytes{binary_proto.data(),
binary_proto.size()}));
EXPECT_EQ("type: TYPE_SLICE_BEGIN",
DebugProtozeroToText(".perfetto.protos.TrackEvent",
protozero::ConstBytes{binary_proto.data(),
binary_proto.size()}));
}
TEST(ProtozeroToTextTest, EnumToString) {
using perfetto::protos::pbzero::TrackEvent;
EXPECT_EQ("TYPE_SLICE_END",
ProtozeroEnumToText(".perfetto.protos.TrackEvent.Type",
TrackEvent::TYPE_SLICE_END));
}
} // namespace
} // namespace trace_processor
} // namespace perfetto