Index: webrtc/call/call_unittest.cc |
diff --git a/webrtc/call/call_unittest.cc b/webrtc/call/call_unittest.cc |
index d4529275cf3ade49962c10e8ed68e4edfeab0abb..98419a8892a58f21116376ea13be6efc66e86f97 100644 |
--- a/webrtc/call/call_unittest.cc |
+++ b/webrtc/call/call_unittest.cc |
@@ -117,4 +117,73 @@ TEST(CallTest, CreateDestroy_AudioReceiveStreams) { |
streams.clear(); |
} |
} |
+ |
+TEST(CallTest, CreateDestroy_FlexfecReceiveStream) { |
+ CallHelper call; |
+ FlexfecReceiveStream::Config config; |
+ config.flexfec_payload_type = 118; |
+ config.flexfec_ssrc = 38837212; |
+ config.protected_media_ssrcs = {27273}; |
+ FlexfecReceiveStream* stream = call->CreateFlexfecReceiveStream(config); |
+ EXPECT_NE(stream, nullptr); |
+ call->DestroyFlexfecReceiveStream(stream); |
+} |
+ |
+TEST(CallTest, CreateDestroy_FlexfecReceiveStreams) { |
+ CallHelper call; |
+ FlexfecReceiveStream::Config config; |
+ config.flexfec_payload_type = 118; |
+ std::list<FlexfecReceiveStream*> streams; |
+ for (int i = 0; i < 2; ++i) { |
+ for (uint32_t ssrc = 0; ssrc < 1234567; ssrc += 34567) { |
+ config.flexfec_ssrc = ssrc; |
+ config.protected_media_ssrcs = {ssrc + 1}; |
+ FlexfecReceiveStream* stream = call->CreateFlexfecReceiveStream(config); |
+ EXPECT_NE(stream, nullptr); |
+ if (ssrc & 1) { |
+ streams.push_back(stream); |
+ } else { |
+ streams.push_front(stream); |
+ } |
+ } |
+ for (auto s : streams) { |
+ call->DestroyFlexfecReceiveStream(s); |
+ } |
+ streams.clear(); |
+ } |
+} |
+ |
+TEST(CallTest, MultipleFlexfecReceiveStreamsProtectingSingleVideoStream) { |
+ CallHelper call; |
+ FlexfecReceiveStream::Config config; |
+ config.flexfec_payload_type = 118; |
+ config.protected_media_ssrcs = {1324234}; |
+ FlexfecReceiveStream* stream; |
+ std::list<FlexfecReceiveStream*> streams; |
+ |
+ config.flexfec_ssrc = 838383; |
+ stream = call->CreateFlexfecReceiveStream(config); |
+ EXPECT_NE(stream, nullptr); |
+ streams.push_back(stream); |
+ |
+ config.flexfec_ssrc = 424993; |
+ stream = call->CreateFlexfecReceiveStream(config); |
+ EXPECT_NE(stream, nullptr); |
+ streams.push_back(stream); |
+ |
+ config.flexfec_ssrc = 99383; |
+ stream = call->CreateFlexfecReceiveStream(config); |
+ EXPECT_NE(stream, nullptr); |
+ streams.push_back(stream); |
+ |
+ config.flexfec_ssrc = 5548; |
+ stream = call->CreateFlexfecReceiveStream(config); |
+ EXPECT_NE(stream, nullptr); |
+ streams.push_back(stream); |
+ |
+ for (auto s : streams) { |
+ call->DestroyFlexfecReceiveStream(s); |
+ } |
+} |
+ |
} // namespace webrtc |