Actually input packets into the PacketBuffer.

Also prepared it for comming changes to RTPVideoHeader.

Bug: none
Change-Id: I60e57f779aee4ee98b6eec3d6631e43ac682c37f
Reviewed-on: https://webrtc-review.googlesource.com/87825
Reviewed-by: Alex Loiko <aleloi@webrtc.org>
Commit-Queue: Philip Eliasson <philipel@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#23911}
This commit is contained in:
philipel
2018-07-10 11:31:29 +02:00
committed by Commit Bot
parent 9cb5d5f9de
commit 32134470ca

View File

@ -27,8 +27,26 @@ void FuzzOneInput(const uint8_t* data, size_t size) {
video_coding::PacketBuffer::Create(&clock, 8, 1024, &callback)); video_coding::PacketBuffer::Create(&clock, 8, 1024, &callback));
test::FuzzDataHelper helper(rtc::ArrayView<const uint8_t>(data, size)); test::FuzzDataHelper helper(rtc::ArrayView<const uint8_t>(data, size));
while (helper.BytesLeft()) while (helper.BytesLeft()) {
// The RTPVideoHeader is a complex type, so overwriting it with random data
// will put it in an invalid state. Therefore we save/restore it.
uint8_t video_header_backup[sizeof(packet.video_header)];
memcpy(&video_header_backup, &packet.video_header,
sizeof(packet.video_header));
helper.CopyTo(&packet); helper.CopyTo(&packet);
memcpy(&packet.video_header, &video_header_backup,
sizeof(packet.video_header));
// The packet buffer owns the payload of the packet.
uint8_t payload_size;
helper.CopyTo(&payload_size);
packet.sizeBytes = payload_size;
packet.dataPtr = new uint8_t[payload_size];
packet_buffer->InsertPacket(&packet);
}
} }
} // namespace webrtc } // namespace webrtc