普通文本  |  122行  |  3.89 KB

/*
 * Copyright 2018 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 <gtest/gtest.h>

#include "packet.h"
#include "packet_test_common.h"
#include "test_packets.h"

namespace bluetooth {

// Test making a packet from another packet. The new packet should have the
// same payload bounds as the old packet.
TEST(PacketTest, newPacketFromPacketTest) {
  // Create a packet with payload bounds
  auto packet = TestPacket::Make(
      test_avctp_data, test_avctp_data_payload_offset, test_avctp_data.size());

  // Create packet from bounded packet
  auto new_packet = TestPacket::Make(packet);

  // Check to see if the new packet is bounded by the payload of the old packet
  auto it = new_packet->begin();
  for (size_t i = 0; i < test_avrcp_data.size(); i++) {
    ASSERT_EQ(test_avrcp_data[i], *it++);
  }
}

// Test that the correct payload length is returned
TEST(PacketTest, sizeTest) {
  auto packet = TestPacket::Make(test_avctp_data);
  ASSERT_EQ(packet->size(), test_avctp_data.size());

  packet = TestPacket::Make(test_avctp_data, test_avctp_data_payload_offset,
                            test_avctp_data.size());
  ASSERT_EQ(packet->size(), test_avrcp_data.size());
}

// Test the array access operator
TEST(PacketTest, arrayAccessTest) {
  auto packet = TestPacket::Make(test_l2cap_data);
  for (size_t i = 0; i < test_l2cap_data.size(); i++) {
    ASSERT_EQ(test_l2cap_data[i], (*packet)[i]);
  }

  packet = TestPacket::Make(test_avctp_data, test_avctp_data_payload_offset,
                            test_avctp_data.size());
  for (size_t i = 0; i < test_avrcp_data.size(); i++) {
    ASSERT_EQ(test_avrcp_data[i], (*packet)[i]);
  }
}

// Test that accessing past the end of the defined payload dies
TEST(PacketTest, arrayAccessDeathTest) {
  auto packet =
      TestPacket::Make(test_l2cap_data, 3, test_l2cap_data.size() - 2);
  ASSERT_DEATH((*packet)[test_l2cap_data.size()], "");
}

// Test that the iterator and array access operator return the same data
TEST(PacketTest, iteratorTest) {
  auto packet = TestPacket::Make(
      test_avctp_data, test_avctp_data_payload_offset, test_avctp_data.size());

  // Check to see if the data matches
  auto it = packet->begin();
  for (size_t i = 0; i < packet->size(); i++) {
    ASSERT_EQ((*packet)[i], *it++);
  }

  // Check to see if the iterator points to the end of the data
  ASSERT_EQ(it, packet->end());
}

class ChildTestPacket : public TestPacket {
 public:
  using TestPacket::TestPacket;

  std::string ToString() const override { return "ChildTestPacket"; };
};

// Test specializing a packet to another packet type
TEST(PacketTest, specializeTest) {
  auto packet = TestPacket::Make(test_l2cap_data);

  std::shared_ptr<ChildTestPacket> specialized_packet =
      Packet::Specialize<ChildTestPacket>(packet);

  // Test that the new packet is an instance of ChildTestPacket
  ASSERT_EQ(specialized_packet->ToString(), "ChildTestPacket");

  // Test that the underlying data is the same and no copy took place
  ASSERT_EQ(&specialized_packet->GetData(), &packet->GetData());
}

// Test that when the packet goes out of scope, that the underlying memory is
// freed
TEST(PacketTest, memoryFreeTest) {
  auto packet = TestPacket::Make(test_l2cap_data);
  std::weak_ptr<std::vector<uint8_t>> data_ptr(packet->GetDataPointer());

  ASSERT_FALSE(data_ptr.expired());

  packet.reset();

  ASSERT_TRUE(data_ptr.expired());
}

}  // namespace bluetooth