Chromium Code Reviews| Index: webrtc/modules/rtp_rtcp/source/fec_receiver_unittest.cc |
| diff --git a/webrtc/modules/rtp_rtcp/source/fec_receiver_unittest.cc b/webrtc/modules/rtp_rtcp/source/fec_receiver_unittest.cc |
| index 1c30f37e8a568364b936a2c6662b013b1a81fbda..56d7e6cfc017169f553cb47bf3df2e2ace61a739 100644 |
| --- a/webrtc/modules/rtp_rtcp/source/fec_receiver_unittest.cc |
| +++ b/webrtc/modules/rtp_rtcp/source/fec_receiver_unittest.cc |
| @@ -32,35 +32,35 @@ namespace webrtc { |
| class ReceiverFecTest : public ::testing::Test { |
| protected: |
| - virtual void SetUp() { |
| - fec_.reset(new ForwardErrorCorrection()); |
| - receiver_fec_.reset(FecReceiver::Create(&rtp_data_callback_)); |
| - generator_.reset(new FrameGenerator()); |
| - } |
| - |
| - void GenerateFec(ForwardErrorCorrection::PacketList* media_packets, |
| - std::list<ForwardErrorCorrection::Packet*>* fec_packets, |
| - unsigned int num_fec_packets) { |
| + ReceiverFecTest() |
| + : rtp_data_callback_(), |
|
danilchap
2016/08/22 13:00:41
it's cleaner to omit default constructions of memb
brandtr
2016/08/23 08:19:10
Done, see https://codereview.webrtc.org/2267393002
|
| + fec_(ForwardErrorCorrection::CreateUlpfec()), |
| + receiver_fec_(FecReceiver::Create(&rtp_data_callback_)), |
| + generator_() {} |
| + |
| + void EncodeFec(ForwardErrorCorrection::PacketList* media_packets, |
| + std::list<ForwardErrorCorrection::Packet*>* fec_packets, |
| + unsigned int num_fec_packets) { |
| uint8_t protection_factor = num_fec_packets * 255 / media_packets->size(); |
| - EXPECT_EQ(0, fec_->GenerateFec(*media_packets, protection_factor, |
| - 0, false, kFecMaskBursty, fec_packets)); |
| + EXPECT_EQ(0, fec_.EncodeFec(*media_packets, protection_factor, 0, false, |
| + kFecMaskBursty, fec_packets)); |
| ASSERT_EQ(num_fec_packets, fec_packets->size()); |
| } |
| void GenerateFrame(int num_media_packets, |
| int frame_offset, |
| - std::list<test::RawRtpPacket*>* media_rtp_packets, |
| + std::list<test::fec::RawRtpPacket*>* media_rtp_packets, |
| ForwardErrorCorrection::PacketList* media_packets) { |
| - generator_->NewFrame(num_media_packets); |
| + generator_.NewFrame(num_media_packets); |
| for (int i = 0; i < num_media_packets; ++i) { |
| - std::unique_ptr<test::RawRtpPacket> next_packet( |
| - generator_->NextPacket(frame_offset + i, kRtpHeaderSize + 10)); |
| + std::unique_ptr<test::fec::RawRtpPacket> next_packet( |
| + generator_.NextPacket(frame_offset + i, kRtpHeaderSize + 10)); |
| media_rtp_packets->push_back(next_packet.get()); |
| media_packets->push_back(std::move(next_packet)); |
| } |
| } |
| - void VerifyReconstructedMediaPacket(const test::RawRtpPacket* packet, |
| + void VerifyReconstructedMediaPacket(const test::fec::RawRtpPacket* packet, |
| int times) { |
| // Verify that the content of the reconstructed packet is equal to the |
| // content of |packet|, and that the same content is received |times| number |
| @@ -71,20 +71,20 @@ class ReceiverFecTest : public ::testing::Test { |
| .Times(times).WillRepeatedly(Return(true)); |
| } |
| - void BuildAndAddRedMediaPacket(test::RawRtpPacket* packet) { |
| - std::unique_ptr<test::RawRtpPacket> red_packet( |
| - generator_->BuildMediaRedPacket(packet)); |
| + void BuildAndAddRedMediaPacket(test::fec::RawRtpPacket* packet) { |
| + std::unique_ptr<test::fec::RawRtpPacket> red_packet( |
| + generator_.BuildMediaRedPacket(packet)); |
| EXPECT_EQ(0, receiver_fec_->AddReceivedRedPacket( |
| red_packet->header.header, red_packet->data, |
| - red_packet->length, kFecPayloadType)); |
| + red_packet->length, test::fec::kFecPayloadType)); |
| } |
| void BuildAndAddRedFecPacket(Packet* packet) { |
| - std::unique_ptr<test::RawRtpPacket> red_packet( |
| - generator_->BuildFecRedPacket(packet)); |
| + std::unique_ptr<test::fec::RawRtpPacket> red_packet( |
| + generator_.BuildFecRedPacket(packet)); |
| EXPECT_EQ(0, receiver_fec_->AddReceivedRedPacket( |
| red_packet->header.header, red_packet->data, |
| - red_packet->length, kFecPayloadType)); |
| + red_packet->length, test::fec::kFecPayloadType)); |
| } |
| void InjectGarbagePacketLength(size_t fec_garbage_offset); |
| @@ -93,18 +93,18 @@ class ReceiverFecTest : public ::testing::Test { |
| uint8_t ulpfec_payload_type); |
| MockRtpData rtp_data_callback_; |
| - std::unique_ptr<ForwardErrorCorrection> fec_; |
| + ForwardErrorCorrection fec_; |
| std::unique_ptr<FecReceiver> receiver_fec_; |
| - std::unique_ptr<FrameGenerator> generator_; |
| + test::fec::FrameGenerator generator_; |
| }; |
| TEST_F(ReceiverFecTest, TwoMediaOneFec) { |
| const unsigned int kNumFecPackets = 1u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets; |
| ForwardErrorCorrection::PacketList media_packets; |
| GenerateFrame(2, 0, &media_rtp_packets, &media_packets); |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - GenerateFec(&media_packets, &fec_packets, kNumFecPackets); |
| + EncodeFec(&media_packets, &fec_packets, kNumFecPackets); |
| // Recovery |
| auto it = media_rtp_packets.begin(); |
| @@ -129,11 +129,11 @@ void ReceiverFecTest::InjectGarbagePacketLength(size_t fec_garbage_offset) { |
| .WillRepeatedly(Return(true)); |
| const unsigned int kNumFecPackets = 1u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets; |
| ForwardErrorCorrection::PacketList media_packets; |
| GenerateFrame(2, 0, &media_rtp_packets, &media_packets); |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - GenerateFec(&media_packets, &fec_packets, kNumFecPackets); |
| + EncodeFec(&media_packets, &fec_packets, kNumFecPackets); |
| ByteWriter<uint16_t>::WriteBigEndian( |
| &fec_packets.front()->data[fec_garbage_offset], 0x4711); |
| @@ -162,11 +162,11 @@ TEST_F(ReceiverFecTest, InjectGarbageFecLevelHeaderProtectionLength) { |
| TEST_F(ReceiverFecTest, TwoMediaTwoFec) { |
| const unsigned int kNumFecPackets = 2u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets; |
| ForwardErrorCorrection::PacketList media_packets; |
| GenerateFrame(2, 0, &media_rtp_packets, &media_packets); |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - GenerateFec(&media_packets, &fec_packets, kNumFecPackets); |
| + EncodeFec(&media_packets, &fec_packets, kNumFecPackets); |
| // Recovery |
| // Drop both media packets. |
| @@ -184,12 +184,12 @@ TEST_F(ReceiverFecTest, TwoMediaTwoFec) { |
| TEST_F(ReceiverFecTest, TwoFramesOneFec) { |
| const unsigned int kNumFecPackets = 1u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets; |
| ForwardErrorCorrection::PacketList media_packets; |
| GenerateFrame(1, 0, &media_rtp_packets, &media_packets); |
| GenerateFrame(1, 1, &media_rtp_packets, &media_packets); |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - GenerateFec(&media_packets, &fec_packets, kNumFecPackets); |
| + EncodeFec(&media_packets, &fec_packets, kNumFecPackets); |
| // Recovery |
| auto it = media_rtp_packets.begin(); |
| @@ -205,13 +205,13 @@ TEST_F(ReceiverFecTest, TwoFramesOneFec) { |
| TEST_F(ReceiverFecTest, OneCompleteOneUnrecoverableFrame) { |
| const unsigned int kNumFecPackets = 1u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets; |
| ForwardErrorCorrection::PacketList media_packets; |
| GenerateFrame(1, 0, &media_rtp_packets, &media_packets); |
| GenerateFrame(2, 1, &media_rtp_packets, &media_packets); |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - GenerateFec(&media_packets, &fec_packets, kNumFecPackets); |
| + EncodeFec(&media_packets, &fec_packets, kNumFecPackets); |
| // Recovery |
| auto it = media_rtp_packets.begin(); |
| @@ -227,13 +227,13 @@ TEST_F(ReceiverFecTest, OneCompleteOneUnrecoverableFrame) { |
| TEST_F(ReceiverFecTest, MaxFramesOneFec) { |
| const unsigned int kNumFecPackets = 1u; |
| const unsigned int kNumMediaPackets = 48u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets; |
| ForwardErrorCorrection::PacketList media_packets; |
| for (unsigned int i = 0; i < kNumMediaPackets; ++i) { |
| GenerateFrame(1, i, &media_rtp_packets, &media_packets); |
| } |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - GenerateFec(&media_packets, &fec_packets, kNumFecPackets); |
| + EncodeFec(&media_packets, &fec_packets, kNumFecPackets); |
| // Recovery |
| auto it = media_rtp_packets.begin(); |
| @@ -252,15 +252,15 @@ TEST_F(ReceiverFecTest, MaxFramesOneFec) { |
| TEST_F(ReceiverFecTest, TooManyFrames) { |
| const unsigned int kNumFecPackets = 1u; |
| const unsigned int kNumMediaPackets = 49u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets; |
| ForwardErrorCorrection::PacketList media_packets; |
| for (unsigned int i = 0; i < kNumMediaPackets; ++i) { |
| GenerateFrame(1, i, &media_rtp_packets, &media_packets); |
| } |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - EXPECT_EQ(-1, fec_->GenerateFec(media_packets, |
| - kNumFecPackets * 255 / kNumMediaPackets, 0, |
| - false, kFecMaskBursty, &fec_packets)); |
| + EXPECT_EQ( |
| + -1, fec_.EncodeFec(media_packets, kNumFecPackets * 255 / kNumMediaPackets, |
| + 0, false, kFecMaskBursty, &fec_packets)); |
| } |
| TEST_F(ReceiverFecTest, PacketNotDroppedTooEarly) { |
| @@ -269,12 +269,12 @@ TEST_F(ReceiverFecTest, PacketNotDroppedTooEarly) { |
| Packet* delayed_fec = NULL; |
| const unsigned int kNumFecPacketsBatch1 = 1u; |
| const unsigned int kNumMediaPacketsBatch1 = 2u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets_batch1; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets_batch1; |
| ForwardErrorCorrection::PacketList media_packets_batch1; |
| GenerateFrame(kNumMediaPacketsBatch1, 0, &media_rtp_packets_batch1, |
| &media_packets_batch1); |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - GenerateFec(&media_packets_batch1, &fec_packets, kNumFecPacketsBatch1); |
| + EncodeFec(&media_packets_batch1, &fec_packets, kNumFecPacketsBatch1); |
| BuildAndAddRedMediaPacket(media_rtp_packets_batch1.front()); |
| EXPECT_CALL(rtp_data_callback_, OnRecoveredPacket(_, _)) |
| @@ -284,7 +284,7 @@ TEST_F(ReceiverFecTest, PacketNotDroppedTooEarly) { |
| // Fill the FEC decoder. No packets should be dropped. |
| const unsigned int kNumMediaPacketsBatch2 = 46u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets_batch2; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets_batch2; |
| ForwardErrorCorrection::PacketList media_packets_batch2; |
| for (unsigned int i = 0; i < kNumMediaPacketsBatch2; ++i) { |
| GenerateFrame(1, i, &media_rtp_packets_batch2, &media_packets_batch2); |
| @@ -310,12 +310,12 @@ TEST_F(ReceiverFecTest, PacketDroppedWhenTooOld) { |
| Packet* delayed_fec = NULL; |
| const unsigned int kNumFecPacketsBatch1 = 1u; |
| const unsigned int kNumMediaPacketsBatch1 = 2u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets_batch1; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets_batch1; |
| ForwardErrorCorrection::PacketList media_packets_batch1; |
| GenerateFrame(kNumMediaPacketsBatch1, 0, &media_rtp_packets_batch1, |
| &media_packets_batch1); |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| - GenerateFec(&media_packets_batch1, &fec_packets, kNumFecPacketsBatch1); |
| + EncodeFec(&media_packets_batch1, &fec_packets, kNumFecPacketsBatch1); |
| BuildAndAddRedMediaPacket(media_rtp_packets_batch1.front()); |
| EXPECT_CALL(rtp_data_callback_, OnRecoveredPacket(_, _)) |
| @@ -325,7 +325,7 @@ TEST_F(ReceiverFecTest, PacketDroppedWhenTooOld) { |
| // Fill the FEC decoder and force the last packet to be dropped. |
| const unsigned int kNumMediaPacketsBatch2 = 48u; |
| - std::list<test::RawRtpPacket*> media_rtp_packets_batch2; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets_batch2; |
| ForwardErrorCorrection::PacketList media_packets_batch2; |
| for (unsigned int i = 0; i < kNumMediaPacketsBatch2; ++i) { |
| GenerateFrame(1, i, &media_rtp_packets_batch2, &media_packets_batch2); |
| @@ -350,14 +350,14 @@ TEST_F(ReceiverFecTest, OldFecPacketDropped) { |
| // 49 frames with 2 media packets and one FEC packet. All media packets |
| // missing. |
| const unsigned int kNumMediaPackets = 49 * 2; |
| - std::list<test::RawRtpPacket*> media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> media_rtp_packets; |
| ForwardErrorCorrection::PacketList media_packets; |
| for (unsigned int i = 0; i < kNumMediaPackets / 2; ++i) { |
| - std::list<test::RawRtpPacket*> frame_media_rtp_packets; |
| + std::list<test::fec::RawRtpPacket*> frame_media_rtp_packets; |
| ForwardErrorCorrection::PacketList frame_media_packets; |
| std::list<ForwardErrorCorrection::Packet*> fec_packets; |
| GenerateFrame(2, 0, &frame_media_rtp_packets, &frame_media_packets); |
| - GenerateFec(&frame_media_packets, &fec_packets, 1); |
| + EncodeFec(&frame_media_packets, &fec_packets, 1); |
| for (auto it = fec_packets.begin(); it != fec_packets.end(); ++it) { |
| // Only FEC packets inserted. No packets recoverable at this time. |
| BuildAndAddRedFecPacket(*it); |