From bc301e7da4f266e9441ee0c485e6d3c24667de62 Mon Sep 17 00:00:00 2001 From: Joshua Haberman Date: Sat, 10 Oct 2020 21:26:58 -0700 Subject: [PATCH] Use merge/partial variants to give proto2 benchmark the fairest hearing. --- tests/benchmark.cc | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/tests/benchmark.cc b/tests/benchmark.cc index eb7fdbba0d..15544afe1b 100644 --- a/tests/benchmark.cc +++ b/tests/benchmark.cc @@ -69,8 +69,8 @@ static void BM_ParseDescriptor_Proto2_NoArena(benchmark::State& state) { size_t bytes = 0; for (auto _ : state) { protobuf::FileDescriptorProto proto; - bool ok = proto.ParseFromArray(descriptor.data, descriptor.size); - + protobuf::StringPiece input(descriptor.data,descriptor.size); + bool ok = proto.ParseFrom(input); if (!ok) { printf("Failed to parse.\n"); exit(1); @@ -85,9 +85,10 @@ static void BM_ParseDescriptor_Proto2_Arena(benchmark::State& state) { size_t bytes = 0; for (auto _ : state) { protobuf::Arena arena; + protobuf::StringPiece input(descriptor.data,descriptor.size); auto proto = protobuf::Arena::CreateMessage( &arena); - bool ok = proto->ParseFromArray(descriptor.data, descriptor.size); + bool ok = proto->ParseFrom(input); if (!ok) { printf("Failed to parse.\n"); @@ -106,9 +107,10 @@ static void BM_ParseDescriptor_Proto2_Arena_LargeInitialBlock(benchmark::State& opts.initial_block_size = sizeof(buf); for (auto _ : state) { protobuf::Arena arena(opts); + protobuf::StringPiece input(descriptor.data,descriptor.size); auto proto = protobuf::Arena::CreateMessage( &arena); - bool ok = proto->ParsePartialFromArray(descriptor.data, descriptor.size); + bool ok = proto->ParseFrom(input); if (!ok) { printf("Failed to parse.\n"); @@ -125,7 +127,7 @@ static void BM_SerializeDescriptor_Proto2(benchmark::State& state) { protobuf::FileDescriptorProto proto; proto.ParseFromArray(descriptor.data, descriptor.size); for (auto _ : state) { - proto.SerializeToArray(buf, sizeof(buf)); + proto.SerializePartialToArray(buf, sizeof(buf)); bytes += descriptor.size; } state.SetBytesProcessed(state.iterations() * descriptor.size);