/*
* 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