blob: 3a37bb1c0e24500b100ae2adeb334f0fd517f49e [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/tmmbn.h"
#include "test/gmock.h"
#include "test/gtest.h"
#include "test/rtcp_packet_parser.h"
using ::testing::ElementsAreArray;
using ::testing::IsEmpty;
using ::testing::make_tuple;
using webrtc::rtcp::TmmbItem;
using webrtc::rtcp::Tmmbn;
namespace webrtc {
namespace {
const uint32_t kSenderSsrc = 0x12345678;
const uint32_t kRemoteSsrc = 0x23456789;
const uint32_t kBitrateBps = 312000;
const uint16_t kOverhead = 0x1fe;
const uint8_t kPacket[] = {0x84, 205, 0x00, 0x04, 0x12, 0x34, 0x56,
0x78, 0x00, 0x00, 0x00, 0x00, 0x23, 0x45,
0x67, 0x89, 0x0a, 0x61, 0x61, 0xfe};
} // namespace
TEST(RtcpPacketTmmbnTest, Create) {
Tmmbn tmmbn;
tmmbn.SetSenderSsrc(kSenderSsrc);
tmmbn.AddTmmbr(TmmbItem(kRemoteSsrc, kBitrateBps, kOverhead));
rtc::Buffer packet = tmmbn.Build();
EXPECT_THAT(make_tuple(packet.data(), packet.size()),
ElementsAreArray(kPacket));
}
TEST(RtcpPacketTmmbnTest, Parse) {
Tmmbn tmmbn;
EXPECT_TRUE(test::ParseSinglePacket(kPacket, &tmmbn));
const Tmmbn& parsed = tmmbn;
EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc());
ASSERT_EQ(1u, parsed.items().size());
EXPECT_EQ(kRemoteSsrc, parsed.items().front().ssrc());
EXPECT_EQ(kBitrateBps, parsed.items().front().bitrate_bps());
EXPECT_EQ(kOverhead, parsed.items().front().packet_overhead());
}
TEST(RtcpPacketTmmbnTest, CreateAndParseWithoutItems) {
Tmmbn tmmbn;
tmmbn.SetSenderSsrc(kSenderSsrc);
rtc::Buffer packet = tmmbn.Build();
Tmmbn parsed;
EXPECT_TRUE(test::ParseSinglePacket(packet, &parsed));
EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc());
EXPECT_THAT(parsed.items(), IsEmpty());
}
TEST(RtcpPacketTmmbnTest, CreateAndParseWithTwoItems) {
Tmmbn tmmbn;
tmmbn.SetSenderSsrc(kSenderSsrc);
tmmbn.AddTmmbr(TmmbItem(kRemoteSsrc, kBitrateBps, kOverhead));
tmmbn.AddTmmbr(TmmbItem(kRemoteSsrc + 1, 4 * kBitrateBps, 40));
rtc::Buffer packet = tmmbn.Build();
Tmmbn parsed;
EXPECT_TRUE(test::ParseSinglePacket(packet, &parsed));
EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc());
EXPECT_EQ(2u, parsed.items().size());
EXPECT_EQ(kRemoteSsrc, parsed.items()[0].ssrc());
EXPECT_EQ(kBitrateBps, parsed.items()[0].bitrate_bps());
EXPECT_EQ(kOverhead, parsed.items()[0].packet_overhead());
EXPECT_EQ(kRemoteSsrc + 1, parsed.items()[1].ssrc());
EXPECT_EQ(4 * kBitrateBps, parsed.items()[1].bitrate_bps());
EXPECT_EQ(40U, parsed.items()[1].packet_overhead());
}
TEST(RtcpPacketTmmbnTest, ParseFailsOnTooSmallPacket) {
const uint8_t kSmallPacket[] = {0x84, 205, 0x00, 0x01,
0x12, 0x34, 0x56, 0x78};
Tmmbn tmmbn;
EXPECT_FALSE(test::ParseSinglePacket(kSmallPacket, &tmmbn));
}
TEST(RtcpPacketTmmbnTest, ParseFailsOnUnAlignedPacket) {
const uint8_t kUnalignedPacket[] = {0x84, 205, 0x00, 0x03, 0x12, 0x34,
0x56, 0x78, 0x00, 0x00, 0x00, 0x00,
0x23, 0x45, 0x67, 0x89};
Tmmbn tmmbn;
EXPECT_FALSE(test::ParseSinglePacket(kUnalignedPacket, &tmmbn));
}
} // namespace webrtc