Chromium Code Reviews| Index: webrtc/ortc/rtpparametersconversion_unittest.cc |
| diff --git a/webrtc/ortc/rtpparametersconversion_unittest.cc b/webrtc/ortc/rtpparametersconversion_unittest.cc |
| index 6bb335c78dd8758c43c51181ee8114de93c227a1..665bbb672f0468439c002ba45153a0f38f761913 100644 |
| --- a/webrtc/ortc/rtpparametersconversion_unittest.cc |
| +++ b/webrtc/ortc/rtpparametersconversion_unittest.cc |
| @@ -456,6 +456,80 @@ TEST(RtpParametersConversionTest, ToVideoRtpCodecCapability) { |
| codec.rtcp_feedback[1]); |
| } |
| +// Tests that the StreamParamsVec can be successfully converted to |
| +// RtpEncodingParameters and vice versa. |
|
Taylor Brandstetter
2017/03/08 22:35:49
Since there are already independent tests for ToCr
Zhi Huang
2017/03/08 23:56:49
Done.
|
| +TEST(RtpParametersConversionTest, StreamParamsVecAndRtpEncodingConversion) { |
| + // Translate RtpEncodingParameters to StreamParamVec. |
| + std::vector<RtpEncodingParameters> encodings; |
| + RtpEncodingParameters encoding; |
| + encoding.ssrc.emplace(1234u); |
| + encoding.rtx.emplace(0xdeadbeef); |
| + encodings.push_back(encoding); |
| + auto result = ToCricketStreamParamsVec(encodings); |
| + ASSERT_TRUE(result.ok()); |
| + ASSERT_EQ(1u, result.value().size()); |
| + EXPECT_EQ(2u, result.value()[0].ssrcs.size()); |
| + EXPECT_EQ(1234u, result.value()[0].first_ssrc()); |
| + uint32_t rtx_ssrc = 0; |
| + EXPECT_TRUE(result.value()[0].GetFidSsrc(1234u, &rtx_ssrc)); |
| + EXPECT_EQ(0xdeadbeef, rtx_ssrc); |
| + // Translate StreamParamVec back to RtpEncodingParameters. |
| + auto rtp_encodings = ToRtpEncodings(result.MoveValue()); |
| + ASSERT_EQ(1u, rtp_encodings.size()); |
| + EXPECT_EQ(1234, rtp_encodings[0].ssrc); |
| + EXPECT_EQ(0xdeadbeef, rtp_encodings[0].rtx->ssrc); |
| +} |
| + |
| +TEST(RtpParametersConversionTest, ToAudioRtpCodecParameters) { |
| + cricket::VideoCodec cricket_codec; |
|
Taylor Brandstetter
2017/03/08 22:35:49
Should be AudioCodec; it looks like this is a copy
Zhi Huang
2017/03/08 23:56:49
Oh, I must forgot to update this for some reason.
|
| + cricket_codec.name = "VID"; |
| + cricket_codec.id = 101; |
| + cricket_codec.clockrate = 80000; |
| + cricket_codec.params["foo"] = "bar"; |
| + cricket_codec.params["ANOTHER"] = "param"; |
| + cricket_codec.feedback_params.Add(cricket::FeedbackParam("transport-cc")); |
| + cricket_codec.feedback_params.Add({"nack", "pli"}); |
| + RtpCodecParameters codec = ToRtpCodecParameters(cricket_codec); |
| + |
| + EXPECT_EQ("VID", codec.name); |
| + EXPECT_EQ(cricket::MEDIA_TYPE_VIDEO, codec.kind); |
| + EXPECT_EQ(101, codec.payload_type); |
| + EXPECT_EQ(rtc::Optional<int>(80000), codec.clock_rate); |
| + ASSERT_EQ(2u, codec.parameters.size()); |
| + EXPECT_EQ("bar", codec.parameters["foo"]); |
| + EXPECT_EQ("param", codec.parameters["ANOTHER"]); |
| + EXPECT_EQ(2u, codec.rtcp_feedback.size()); |
| + EXPECT_EQ(RtcpFeedback(RtcpFeedbackType::TRANSPORT_CC), |
| + codec.rtcp_feedback[0]); |
| + EXPECT_EQ(RtcpFeedback(RtcpFeedbackType::NACK, RtcpFeedbackMessageType::PLI), |
| + codec.rtcp_feedback[1]); |
| +} |
| + |
| +TEST(RtpParametersConversionTest, ToVideoRtpCodecParameters) { |
| + cricket::VideoCodec cricket_codec; |
| + cricket_codec.name = "VID"; |
| + cricket_codec.id = 101; |
| + cricket_codec.clockrate = 80000; |
| + cricket_codec.params["foo"] = "bar"; |
| + cricket_codec.params["ANOTHER"] = "param"; |
| + cricket_codec.feedback_params.Add(cricket::FeedbackParam("transport-cc")); |
| + cricket_codec.feedback_params.Add({"nack", "pli"}); |
| + RtpCodecParameters codec = ToRtpCodecParameters(cricket_codec); |
| + |
| + EXPECT_EQ("VID", codec.name); |
| + EXPECT_EQ(cricket::MEDIA_TYPE_VIDEO, codec.kind); |
| + EXPECT_EQ(101, codec.payload_type); |
| + EXPECT_EQ(rtc::Optional<int>(80000), codec.clock_rate); |
| + ASSERT_EQ(2u, codec.parameters.size()); |
| + EXPECT_EQ("bar", codec.parameters["foo"]); |
| + EXPECT_EQ("param", codec.parameters["ANOTHER"]); |
| + EXPECT_EQ(2u, codec.rtcp_feedback.size()); |
| + EXPECT_EQ(RtcpFeedback(RtcpFeedbackType::TRANSPORT_CC), |
| + codec.rtcp_feedback[0]); |
| + EXPECT_EQ(RtcpFeedback(RtcpFeedbackType::NACK, RtcpFeedbackMessageType::PLI), |
| + codec.rtcp_feedback[1]); |
| +} |
| + |
| // An unknown feedback param should just be ignored. |
| TEST(RtpParametersConversionTest, ToRtpCodecCapabilityUnknownFeedbackParam) { |
| cricket::AudioCodec cricket_codec; |
| @@ -532,4 +606,40 @@ TEST(RtpParametersConversionTest, ToRtpCapabilities) { |
| FecMechanism::FLEXFEC)); |
| } |
| +TEST(RtpParametersConversionTest, ToRtpParameters) { |
| + cricket::VideoCodec vp8; |
| + vp8.name = "VP8"; |
| + vp8.id = 101; |
| + vp8.clockrate = 90000; |
| + |
| + cricket::VideoCodec red; |
| + red.name = "red"; |
| + red.id = 102; |
| + red.clockrate = 90000; |
| + |
| + cricket::VideoCodec ulpfec; |
| + ulpfec.name = "ulpfec"; |
| + ulpfec.id = 103; |
| + ulpfec.clockrate = 90000; |
| + |
| + cricket::StreamParamsVec streams; |
| + cricket::StreamParams stream; |
| + stream.ssrcs.push_back(1234u); |
| + streams.push_back(stream); |
| + |
| + RtpParameters rtp_parameters = ToRtpParameters<cricket::VideoCodec>( |
| + {vp8, red, ulpfec}, {{"uri", 1}, {"uri2", 3}}, streams); |
| + ASSERT_EQ(3u, rtp_parameters.codecs.size()); |
| + EXPECT_EQ("VP8", rtp_parameters.codecs[0].name); |
| + EXPECT_EQ("red", rtp_parameters.codecs[1].name); |
| + EXPECT_EQ("ulpfec", rtp_parameters.codecs[2].name); |
| + ASSERT_EQ(2u, rtp_parameters.header_extensions.size()); |
| + EXPECT_EQ("uri", rtp_parameters.header_extensions[0].uri); |
| + EXPECT_EQ(1, rtp_parameters.header_extensions[0].id); |
| + EXPECT_EQ("uri2", rtp_parameters.header_extensions[1].uri); |
| + EXPECT_EQ(3, rtp_parameters.header_extensions[1].id); |
| + ASSERT_EQ(1u, rtp_parameters.encodings.size()); |
| + EXPECT_EQ(1234u, rtp_parameters.encodings[0].ssrc); |
| +} |
| + |
| } // namespace webrtc |