Index: webrtc/common_video/h264/profile_level_id_unittest.cc |
diff --git a/webrtc/common_video/h264/profile_level_id_unittest.cc b/webrtc/common_video/h264/profile_level_id_unittest.cc |
index 491fda14aaf89fb80be630dcfef5d357832948df..db4c8a9870466d0152d6343866f9b67907f1982c 100644 |
--- a/webrtc/common_video/h264/profile_level_id_unittest.cc |
+++ b/webrtc/common_video/h264/profile_level_id_unittest.cc |
@@ -109,5 +109,89 @@ TEST(H264ProfileLevelId, TestToStringInvalid) { |
ProfileLevelId(static_cast<Profile>(255), kLevel3_1))); |
} |
+TEST(H264ProfileLevelId, TestParseSdpProfileLevelIdEmpty) { |
+ const rtc::Optional<ProfileLevelId> profile_level_id = |
+ ParseSdpProfileLevelId(CodecParameterMap()); |
+ EXPECT_TRUE(profile_level_id); |
+ EXPECT_EQ(kProfileConstrainedBaseline, profile_level_id->profile); |
+ EXPECT_EQ(kLevel3_1, profile_level_id->level); |
+} |
+ |
+TEST(H264ProfileLevelId, TestParseSdpProfileLevelIdConstrainedHigh) { |
+ CodecParameterMap params; |
+ params["profile-level-id"] = "640c2a"; |
+ const rtc::Optional<ProfileLevelId> profile_level_id = |
+ ParseSdpProfileLevelId(params); |
+ EXPECT_TRUE(profile_level_id); |
+ EXPECT_EQ(kProfileConstrainedHigh, profile_level_id->profile); |
+ EXPECT_EQ(kLevel4_2, profile_level_id->level); |
+} |
+ |
+TEST(H264ProfileLevelId, TestParseSdpProfileLevelIdInvalid) { |
+ CodecParameterMap params; |
+ params["profile-level-id"] = "foobar"; |
+ EXPECT_FALSE(ParseSdpProfileLevelId(params)); |
+} |
+ |
+TEST(H264ProfileLevelId, TestNegotiateProfileLevelIdEmpty) { |
+ const rtc::Optional<ProfileLevelId> profile_level_id = |
+ NegotiateProfileLevelId(CodecParameterMap(), CodecParameterMap()); |
+ EXPECT_TRUE(profile_level_id); |
+ EXPECT_EQ(kProfileConstrainedBaseline, profile_level_id->profile); |
+ EXPECT_EQ(kLevel3_1, profile_level_id->level); |
+} |
+ |
+TEST(H264ProfileLevelId, TestNegotiateProfileLevelIdInvalid) { |
+ CodecParameterMap local_params; |
+ local_params["profile-level-id"] = "foobar"; |
+ EXPECT_FALSE(NegotiateProfileLevelId(local_params, CodecParameterMap())); |
+} |
+ |
+TEST(H264ProfileLevelId, TestNegotiateProfileLevelIdDifferentProfiles) { |
+ CodecParameterMap local_params; |
+ local_params["profile-level-id"] = "42e01f"; |
+ CodecParameterMap remote_params; |
+ remote_params["profile-level-id"] = "640c2a"; |
+ EXPECT_FALSE(NegotiateProfileLevelId(local_params, remote_params)); |
hta-webrtc
2016/11/08 09:39:06
Given that profiles form subsets too, I'm not sure
magjed_webrtc
2016/11/08 15:48:40
This test does not make sense anymore since the pr
|
+} |
+ |
+TEST(H264ProfileLevelId, TestNegotiateProfileLevelIdLevelSymmetryRejected) { |
+ CodecParameterMap local_params; |
+ local_params["profile-level-id"] = "42e015"; |
+ CodecParameterMap remote_params; |
+ remote_params["profile-level-id"] = "42e01f"; |
+ // The codec should be rejected since local can't handle the remote level. |
+ EXPECT_FALSE(NegotiateProfileLevelId(local_params, remote_params)); |
hta-webrtc
2016/11/08 09:39:06
This test is wrong.
magjed_webrtc
2016/11/08 15:48:40
Yes, it's removed now.
|
+} |
+ |
+TEST(H264ProfileLevelId, TestNegotiateProfileLevelIdLevelSymmetryCapped) { |
+ CodecParameterMap local_params; |
+ local_params["profile-level-id"] = "42e01f"; |
+ CodecParameterMap remote_params; |
+ remote_params["profile-level-id"] = "42e015"; |
+ const rtc::Optional<ProfileLevelId> profile_level_id = |
+ NegotiateProfileLevelId(local_params, remote_params); |
+ EXPECT_TRUE(profile_level_id); |
+ EXPECT_EQ(kProfileConstrainedBaseline, profile_level_id->profile); |
+ // The level should be capped by the remote capabilities. |
+ EXPECT_EQ(kLevel2_1, profile_level_id->level); |
hta-webrtc
2016/11/08 09:39:06
It's not very readable to set the parameters in te
magjed_webrtc
2016/11/08 15:48:40
Done, strings are used everywhere now.
|
+} |
+ |
+TEST(H264ProfileLevelId, |
+ TestNegotiateProfileLevelIdConstrainedBaselineLevelAsymmetry) { |
+ CodecParameterMap local_params; |
+ local_params["profile-level-id"] = "42e01f"; |
+ local_params["level-asymmetry-allowed"] = "1"; |
+ CodecParameterMap remote_params; |
+ remote_params["profile-level-id"] = "42e015"; |
+ remote_params["level-asymmetry-allowed"] = "1"; |
+ const rtc::Optional<ProfileLevelId> profile_level_id = |
+ NegotiateProfileLevelId(local_params, remote_params); |
+ EXPECT_TRUE(profile_level_id); |
+ EXPECT_EQ(kProfileConstrainedBaseline, profile_level_id->profile); |
+ // We should be able to send a level different from the remote capabilities. |
+ EXPECT_EQ(kLevel3_1, profile_level_id->level); |
hta-webrtc
2016/11/08 09:39:06
Actually, we should send with the remote capabilit
magjed_webrtc
2016/11/08 15:48:40
Yeah, the 'send level' in the comment is actually
|
+} |
+ |
} // namespace H264 |
} // namespace webrtc |