| Index: components/tracing/test/proto_zero_generation_unittest.cc
|
| diff --git a/components/tracing/test/proto_zero_generation_unittest.cc b/components/tracing/test/proto_zero_generation_unittest.cc
|
| index eb6e8f759ff918ec143a4340cc002f94062fd9a4..c3f8713744cc08b2f7c90c2078967c053521c443 100644
|
| --- a/components/tracing/test/proto_zero_generation_unittest.cc
|
| +++ b/components/tracing/test/proto_zero_generation_unittest.cc
|
| @@ -2,21 +2,162 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| +#include <limits>
|
| +#include <memory>
|
| +#include <vector>
|
| +
|
| +#include "components/tracing/core/proto_zero_message_handle.h"
|
| #include "components/tracing/test/example_proto/library.pbzero.h"
|
| +#include "components/tracing/test/example_proto/test_messages.pb.h"
|
| #include "components/tracing/test/example_proto/test_messages.pbzero.h"
|
| +#include "components/tracing/test/fake_scattered_buffer.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
|
|
| namespace tracing {
|
| namespace proto {
|
|
|
| -using foo::bar::CamelCaseFields;
|
| +using namespace pbzero::foo::bar;
|
| +namespace pbgold = foo::bar; // Official C++ protobuf compiler.
|
|
|
| -TEST(ProtoZeroTest, Simple) {
|
| - // TODO(kraynov) Put tests in the next CL (crbug.com/608721).
|
| +using tracing::v2::FakeScatteredBuffer;
|
| +using tracing::v2::ProtoZeroMessage;
|
| +using tracing::v2::ScatteredStreamWriter;
|
| +using tracing::v2::ProtoZeroMessageHandle;
|
| +using tracing::v2::ProtoZeroMessageHandleBase;
|
| +
|
| +constexpr size_t kChunkSize = 42;
|
| +
|
| +class ProtoZeroConformanceTest : public ::testing::Test {
|
| + public:
|
| + void SetUp() override {
|
| + buffer_.reset(new FakeScatteredBuffer(kChunkSize));
|
| + stream_writer_.reset(new ScatteredStreamWriter(buffer_.get()));
|
| + }
|
| +
|
| + void TearDown() override {
|
| + handles_.clear();
|
| + root_messages_.clear();
|
| + stream_writer_.reset();
|
| + buffer_.reset();
|
| + google::protobuf::ShutdownProtobufLibrary();
|
| + }
|
| +
|
| + protected:
|
| + template <class T>
|
| + void CreateMessage(T** message_ptr) {
|
| + *message_ptr = new T();
|
| + root_messages_.push_back(std::unique_ptr<T>(*message_ptr));
|
| + (*message_ptr)->Reset(stream_writer_.get());
|
| + handles_.push_back(std::unique_ptr<ProtoZeroMessageHandleBase>(
|
| + new ProtoZeroMessageHandle<T>(*message_ptr)));
|
| + }
|
| +
|
| + size_t GetNumSerializedBytes() {
|
| + return buffer_->chunks().size() * kChunkSize -
|
| + stream_writer_->bytes_available();
|
| + }
|
| +
|
| + void GetSerializedBytes(size_t start, size_t length, uint8_t* buffer) {
|
| + return buffer_->GetBytes(start, length, buffer);
|
| + }
|
| +
|
| + private:
|
| + std::unique_ptr<FakeScatteredBuffer> buffer_;
|
| + std::unique_ptr<ScatteredStreamWriter> stream_writer_;
|
| + std::vector<std::unique_ptr<ProtoZeroMessage>> root_messages_;
|
| + std::vector<std::unique_ptr<ProtoZeroMessageHandleBase>> handles_;
|
| +};
|
| +
|
| +TEST_F(ProtoZeroConformanceTest, SimpleFieldsNoNesting) {
|
| + EveryField* msg;
|
| + CreateMessage(&msg);
|
| +
|
| + msg->set_field_int32(-1);
|
| + msg->set_field_int64(-333123456789ll);
|
| + msg->set_field_uint32(600);
|
| + msg->set_field_uint64(333123456789ll);
|
| + msg->set_field_sint32(-5);
|
| + msg->set_field_sint64(-9000);
|
| + msg->set_field_fixed32(12345);
|
| + msg->set_field_fixed64(444123450000ll);
|
| + msg->set_field_sfixed32(-69999);
|
| + msg->set_field_sfixed64(-200);
|
| + msg->set_field_float(3.14f);
|
| + msg->set_field_double(0.5555);
|
| + msg->set_field_bool(true);
|
| + msg->set_small_enum(SmallEnum::TO_BE);
|
| + msg->set_signed_enum(SignedEnum::NEGATIVE);
|
| + msg->set_big_enum(BigEnum::BEGIN);
|
| + msg->set_field_string("FizzBuzz");
|
| + msg->set_field_bytes(reinterpret_cast<const uint8_t*>("\x11\x00\xBE\xEF"), 4);
|
| + msg->add_repeated_int32(1);
|
| + msg->add_repeated_int32(-1);
|
| + msg->add_repeated_int32(100);
|
| + msg->add_repeated_int32(2000000);
|
|
|
| + size_t msg_size = GetNumSerializedBytes();
|
| + EXPECT_EQ(126u, msg_size);
|
| +
|
| + std::unique_ptr<uint8_t[]> msg_binary(new uint8_t[msg_size]);
|
| + GetSerializedBytes(0, msg_size, msg_binary.get());
|
| +
|
| + pbgold::EveryField gold;
|
| + gold.ParseFromArray(msg_binary.get(), msg_size);
|
| + EXPECT_EQ(-1, gold.field_int32());
|
| + EXPECT_EQ(-333123456789ll, gold.field_int64());
|
| + EXPECT_EQ(600u, gold.field_uint32());
|
| + EXPECT_EQ(333123456789ull, gold.field_uint64());
|
| + EXPECT_EQ(-5, gold.field_sint32());
|
| + EXPECT_EQ(-9000, gold.field_sint64());
|
| + EXPECT_EQ(12345u, gold.field_fixed32());
|
| + EXPECT_EQ(444123450000ull, gold.field_fixed64());
|
| + EXPECT_EQ(-69999, gold.field_sfixed32());
|
| + EXPECT_EQ(-200, gold.field_sfixed64());
|
| + EXPECT_EQ(3.14f, gold.field_float());
|
| + EXPECT_EQ(0.5555, gold.field_double());
|
| + EXPECT_EQ(true, gold.field_bool());
|
| + EXPECT_EQ(pbgold::SmallEnum::TO_BE, gold.small_enum());
|
| + EXPECT_EQ(pbgold::SignedEnum::NEGATIVE, gold.signed_enum());
|
| + EXPECT_EQ(pbgold::BigEnum::BEGIN, gold.big_enum());
|
| + EXPECT_EQ("FizzBuzz", gold.field_string());
|
| + EXPECT_EQ(std::string("\x11\x00\xBE\xEF", 4), gold.field_bytes());
|
| + EXPECT_EQ(4, gold.repeated_int32_size());
|
| + EXPECT_EQ(1, gold.repeated_int32(0));
|
| + EXPECT_EQ(-1, gold.repeated_int32(1));
|
| + EXPECT_EQ(100, gold.repeated_int32(2));
|
| + EXPECT_EQ(2000000, gold.repeated_int32(3));
|
| +}
|
| +
|
| +TEST_F(ProtoZeroConformanceTest, NestedMessages) {
|
| + NestedA* msg_a;
|
| + CreateMessage(&msg_a);
|
| +
|
| + NestedA::NestedB* msg_b = msg_a->add_repeated_a();
|
| + NestedA::NestedB::NestedC* msg_c = msg_b->set_value_b();
|
| + msg_c->set_value_c(321);
|
| + msg_b = msg_a->add_repeated_a();
|
| + msg_c = msg_a->set_super_nested();
|
| + msg_c->set_value_c(1000);
|
| + msg_a->Finalize();
|
| +
|
| + size_t msg_size = GetNumSerializedBytes();
|
| + EXPECT_EQ(26u, msg_size);
|
| +
|
| + std::unique_ptr<uint8_t[]> msg_binary(new uint8_t[msg_size]);
|
| + GetSerializedBytes(0, msg_size, msg_binary.get());
|
| +
|
| + pbgold::NestedA gold_a;
|
| + gold_a.ParseFromArray(msg_binary.get(), msg_size);
|
| + EXPECT_EQ(2, gold_a.repeated_a_size());
|
| + EXPECT_EQ(321, gold_a.repeated_a(0).value_b().value_c());
|
| + EXPECT_FALSE(gold_a.repeated_a(1).has_value_b());
|
| + EXPECT_EQ(1000, gold_a.super_nested().value_c());
|
| +}
|
| +
|
| +TEST(ProtoZeroTest, Simple) {
|
| // Test the includes for indirect public import: library.pbzero.h ->
|
| // library_internals/galaxies.pbzero.h -> upper_import.pbzero.h .
|
| - EXPECT_LE(0u, sizeof(foo::bar::TrickyPublicImport));
|
| + EXPECT_LE(0u, sizeof(TrickyPublicImport));
|
| }
|
|
|
| TEST(ProtoZeroTest, FieldNumbers) {
|
|
|