Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(726)

Unified Diff: webrtc/modules/rtp_rtcp/source/rtcp_packet/fir_unittest.cc

Issue 1544403002: [rtp_rtcp] rtcp::Fir cleaned and got Parse function. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webrtc/modules/rtp_rtcp/source/rtcp_packet/fir_unittest.cc
diff --git a/webrtc/modules/rtp_rtcp/source/rtcp_packet/fir_unittest.cc b/webrtc/modules/rtp_rtcp/source/rtcp_packet/fir_unittest.cc
index b65a0c3f5a0e256673b492ab7e3c5f1236a23256..7f56b756b903cd36d1a2211b66473072fd50fc1a 100644
--- a/webrtc/modules/rtp_rtcp/source/rtcp_packet/fir_unittest.cc
+++ b/webrtc/modules/rtp_rtcp/source/rtcp_packet/fir_unittest.cc
@@ -12,31 +12,116 @@
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
-#include "webrtc/test/rtcp_packet_parser.h"
+using testing::AllOf;
+using testing::ElementsAre;
+using testing::ElementsAreArray;
+using testing::Eq;
+using testing::Field;
+using testing::make_tuple;
using webrtc::rtcp::Fir;
using webrtc::rtcp::RawPacket;
-using webrtc::test::RtcpPacketParser;
+using webrtc::RTCPUtility::RtcpCommonHeader;
+using webrtc::RTCPUtility::RtcpParseCommonHeader;
namespace webrtc {
+namespace {
const uint32_t kSenderSsrc = 0x12345678;
const uint32_t kRemoteSsrc = 0x23456789;
+const uint8_t kSeqNr = 13;
+// Manually created Fir packet matching constants above.
+const uint8_t kPacket[] = {0x84, 206, 0x00, 0x04,
+ 0x12, 0x34, 0x56, 0x78,
+ 0x00, 0x00, 0x00, 0x00,
+ 0x23, 0x45, 0x67, 0x89,
+ 0x0d, 0x00, 0x00, 0x00};
-TEST(RtcpPacketFirTest, Fir) {
+bool ParseFir(const uint8_t* buffer, size_t length, Fir* parsed) {
åsapersson 2016/01/21 16:04:35 perhaps parsed->fir
danilchap 2016/01/21 16:48:12 Done, fir is nicer.
+ RtcpCommonHeader header;
+ EXPECT_TRUE(RtcpParseCommonHeader(buffer, length, &header));
+ EXPECT_THAT(header.BlockSize(), Eq(length));
+ return parsed->Parse(header, buffer + RtcpCommonHeader::kHeaderSizeBytes);
+}
+
+TEST(RtcpPacketFirTest, Parse) {
+ Fir mutable_parsed;
+ EXPECT_TRUE(ParseFir(kPacket, sizeof(kPacket), &mutable_parsed));
+ const Fir& parsed = mutable_parsed; // Read values from constant object.
+
+ EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc());
+ EXPECT_THAT(parsed.requests(),
+ ElementsAre(AllOf(Field(&Fir::Request::ssrc, Eq(kRemoteSsrc)),
+ Field(&Fir::Request::seq_nr, Eq(kSeqNr)))));
+}
+
+TEST(RtcpPacketFirTest, Create) {
+ Fir fir;
+ fir.From(kSenderSsrc);
+ fir.WithRequestTo(kRemoteSsrc, kSeqNr);
+
+ rtc::scoped_ptr<RawPacket> packet = fir.Build();
+
+ EXPECT_THAT(make_tuple(packet->Buffer(), packet->Length()),
+ ElementsAreArray(kPacket));
+}
+
+TEST(RtcpPacketFirTest, TwoFciEntries) {
+ Fir fir;
+ fir.From(kSenderSsrc);
+ fir.WithRequestTo(kRemoteSsrc, kSeqNr);
+ fir.WithRequestTo(kRemoteSsrc + 1, kSeqNr + 1);
+
+ rtc::scoped_ptr<RawPacket> packet = fir.Build();
+ Fir parsed;
+ EXPECT_TRUE(ParseFir(packet->Buffer(), packet->Length(), &parsed));
+
+ EXPECT_EQ(kSenderSsrc, parsed.sender_ssrc());
+ EXPECT_THAT(parsed.requests(),
+ ElementsAre(AllOf(Field(&Fir::Request::ssrc, Eq(kRemoteSsrc)),
+ Field(&Fir::Request::seq_nr, Eq(kSeqNr))),
+ AllOf(Field(&Fir::Request::ssrc, Eq(kRemoteSsrc + 1)),
+ Field(&Fir::Request::seq_nr, Eq(kSeqNr + 1)))));
+}
+
+TEST(RtcpPacketFirTest, ParseFailsOnZeroFciEntries) {
Fir fir;
fir.From(kSenderSsrc);
- fir.To(kRemoteSsrc);
- fir.WithCommandSeqNum(123);
-
- rtc::scoped_ptr<RawPacket> packet(fir.Build());
- RtcpPacketParser parser;
- parser.Parse(packet->Buffer(), packet->Length());
- EXPECT_EQ(1, parser.fir()->num_packets());
- EXPECT_EQ(kSenderSsrc, parser.fir()->Ssrc());
- EXPECT_EQ(1, parser.fir_item()->num_packets());
- EXPECT_EQ(kRemoteSsrc, parser.fir_item()->Ssrc());
- EXPECT_EQ(123U, parser.fir_item()->SeqNum());
+ fir.WithRequestTo(kRemoteSsrc, kSeqNr);
+
+ rtc::scoped_ptr<RawPacket> packet = fir.Build();
+
+ RtcpCommonHeader header;
+ RtcpParseCommonHeader(packet->Buffer(), packet->Length(), &header);
+ ASSERT_EQ(16u, header.payload_size_bytes); // Common: 8, 1xfci: 8.
+ header.payload_size_bytes = 8; // Common: 8, 0xfcis.
+
+ Fir parsed;
+ EXPECT_FALSE(parsed.Parse(
+ header, packet->Buffer() + RtcpCommonHeader::kHeaderSizeBytes));
}
+TEST(RtcpPacketFirTest, ParseFailsOnFractionalFciEntries) {
+ Fir fir;
+ fir.From(kSenderSsrc);
+ fir.WithRequestTo(kRemoteSsrc, kSeqNr);
+ fir.WithRequestTo(kRemoteSsrc + 1, kSeqNr + 1);
+
+ rtc::scoped_ptr<RawPacket> packet = fir.Build();
+
+ RtcpCommonHeader header;
+ RtcpParseCommonHeader(packet->Buffer(), packet->Length(), &header);
+ ASSERT_EQ(24u, header.payload_size_bytes); // Common: 8, 2xfcis: 16.
+
+ const uint8_t* payload =
+ packet->Buffer() + RtcpCommonHeader::kHeaderSizeBytes;
+ Fir good;
+ EXPECT_TRUE(good.Parse(header, payload));
+ for (size_t i = 1; i < 8; ++i) {
+ header.payload_size_bytes = 16 + i;
+ Fir bad;
+ EXPECT_FALSE(bad.Parse(header, payload));
+ }
+}
+} // namespace
} // namespace webrtc

Powered by Google App Engine
This is Rietveld 408576698