blob: b16bb5beaa524bd27edb0f5ddebb313fbd1a4f2a [file] [log] [blame]
/*
* Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include "modules/rtp_rtcp/source/rtcp_packet/target_bitrate.h"
#include "modules/rtp_rtcp/source/byte_io.h"
#include "modules/rtp_rtcp/source/rtcp_packet/extended_reports.h"
#include "rtc_base/buffer.h"
#include "test/gtest.h"
#include "test/rtcp_packet_parser.h"
namespace webrtc {
namespace {
using BitrateItem = rtcp::TargetBitrate::BitrateItem;
using rtcp::TargetBitrate;
using test::ParseSinglePacket;
constexpr uint32_t kSsrc = 0x12345678;
// clang-format off
const uint8_t kPacket[] = { TargetBitrate::kBlockType, // Block ID.
0x00, // Reserved.
0x00, 0x04, // Length = 4 words.
0x00, 0x01, 0x02, 0x03, // S0T0 0x010203 kbps.
0x01, 0x02, 0x03, 0x04, // S0T1 0x020304 kbps.
0x10, 0x03, 0x04, 0x05, // S1T0 0x030405 kbps.
0x11, 0x04, 0x05, 0x06 }; // S1T1 0x040506 kbps.
constexpr size_t kPacketLengthBlocks = ((sizeof(kPacket) + 3) / 4) - 1;
// clang-format on
void ExpectBirateItemEquals(const BitrateItem& expected,
const BitrateItem& actual) {
EXPECT_EQ(expected.spatial_layer, actual.spatial_layer);
EXPECT_EQ(expected.temporal_layer, actual.temporal_layer);
EXPECT_EQ(expected.target_bitrate_kbps, actual.target_bitrate_kbps);
}
void CheckBitrateItems(const std::vector<BitrateItem>& bitrates) {
EXPECT_EQ(4U, bitrates.size());
ExpectBirateItemEquals(BitrateItem(0, 0, 0x010203), bitrates[0]);
ExpectBirateItemEquals(BitrateItem(0, 1, 0x020304), bitrates[1]);
ExpectBirateItemEquals(BitrateItem(1, 0, 0x030405), bitrates[2]);
ExpectBirateItemEquals(BitrateItem(1, 1, 0x040506), bitrates[3]);
}
} // namespace
TEST(TargetBitrateTest, Parse) {
TargetBitrate target_bitrate;
target_bitrate.Parse(kPacket, kPacketLengthBlocks);
CheckBitrateItems(target_bitrate.GetTargetBitrates());
}
TEST(TargetBitrateTest, FullPacket) {
const size_t kXRHeaderSize = 8; // RTCP header (4) + SSRC (4).
const size_t kTotalSize = kXRHeaderSize + sizeof(kPacket);
uint8_t kRtcpPacket[kTotalSize] = {2 << 6, 207, 0x00, (kTotalSize / 4) - 1,
0x12, 0x34, 0x56, 0x78}; // SSRC.
memcpy(&kRtcpPacket[kXRHeaderSize], kPacket, sizeof(kPacket));
rtcp::ExtendedReports xr;
EXPECT_TRUE(ParseSinglePacket(kRtcpPacket, &xr));
EXPECT_EQ(kSsrc, xr.sender_ssrc());
const absl::optional<TargetBitrate>& target_bitrate = xr.target_bitrate();
ASSERT_TRUE(static_cast<bool>(target_bitrate));
CheckBitrateItems(target_bitrate->GetTargetBitrates());
}
TEST(TargetBitrateTest, Create) {
TargetBitrate target_bitrate;
target_bitrate.AddTargetBitrate(0, 0, 0x010203);
target_bitrate.AddTargetBitrate(0, 1, 0x020304);
target_bitrate.AddTargetBitrate(1, 0, 0x030405);
target_bitrate.AddTargetBitrate(1, 1, 0x040506);
uint8_t buffer[sizeof(kPacket)] = {};
ASSERT_EQ(sizeof(kPacket), target_bitrate.BlockLength());
target_bitrate.Create(buffer);
EXPECT_EQ(0, memcmp(kPacket, buffer, sizeof(kPacket)));
}
TEST(TargetBitrateTest, ParseNullBitratePacket) {
const uint8_t kNullPacket[] = {TargetBitrate::kBlockType, 0x00, 0x00, 0x00};
TargetBitrate target_bitrate;
target_bitrate.Parse(kNullPacket, 0);
EXPECT_TRUE(target_bitrate.GetTargetBitrates().empty());
}
} // namespace webrtc