This is a reland of commit 97ba853295578975a04fc504315cccd465f9f0bd This cl did not cause the regression in Chrome rolls https://chromium-review.googlesource.com/c/chromium/src/+/4132644?tab=checks. Real culprit reverted in https://webrtc-review.googlesource.com/c/src/+/290502. Original change's description: > Remove use of ReceiveStreamRtpConfig:transport_cc > > With this change, webrtc will send RTCP transport feedback for all received packets that have a transport sequence number, if the header extension > http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions is negotiated. > I.e the SDP attribute a=rtcp-fb:96 transport-cc is ignored. > > > Change-Id: I95d8d4405dc86a2f872f7883b7bafd623d5f7841 > > Bug: webrtc:14802 > Change-Id: I95d8d4405dc86a2f872f7883b7bafd623d5f7841 > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/290403 > Reviewed-by: Harald Alvestrand <hta@webrtc.org> > Reviewed-by: Danil Chapovalov <danilchap@webrtc.org> > Commit-Queue: Per Kjellander <perkj@webrtc.org> > Cr-Commit-Position: refs/heads/main@{#38980} Bug: webrtc:14802 Change-Id: Ib98e61413161d462da60144942cdb0140e12bc42 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/290503 Reviewed-by: Danil Chapovalov <danilchap@webrtc.org> Commit-Queue: Per Kjellander <perkj@webrtc.org> Reviewed-by: Harald Alvestrand <hta@webrtc.org> Cr-Commit-Position: refs/heads/main@{#38997}
65 lines
2.7 KiB
C++
65 lines
2.7 KiB
C++
/*
|
|
* Copyright (c) 2019 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#include "test/call_config_utils.h"
|
|
|
|
#include "call/video_receive_stream.h"
|
|
#include "test/gtest.h"
|
|
|
|
namespace webrtc {
|
|
namespace test {
|
|
|
|
TEST(CallConfigUtils, MarshalUnmarshalProcessSameObject) {
|
|
VideoReceiveStreamInterface::Config recv_config(nullptr);
|
|
|
|
VideoReceiveStreamInterface::Decoder decoder;
|
|
decoder.payload_type = 10;
|
|
decoder.video_format.name = "test";
|
|
decoder.video_format.parameters["99"] = "b";
|
|
recv_config.decoders.push_back(decoder);
|
|
recv_config.render_delay_ms = 10;
|
|
recv_config.rtp.remote_ssrc = 100;
|
|
recv_config.rtp.local_ssrc = 101;
|
|
recv_config.rtp.rtcp_mode = RtcpMode::kCompound;
|
|
recv_config.rtp.lntf.enabled = false;
|
|
recv_config.rtp.nack.rtp_history_ms = 150;
|
|
recv_config.rtp.red_payload_type = 50;
|
|
recv_config.rtp.rtx_ssrc = 1000;
|
|
recv_config.rtp.rtx_associated_payload_types[10] = 10;
|
|
recv_config.rtp.extensions.emplace_back("uri", 128, true);
|
|
|
|
VideoReceiveStreamInterface::Config unmarshaled_config =
|
|
ParseVideoReceiveStreamJsonConfig(
|
|
nullptr, GenerateVideoReceiveStreamJsonConfig(recv_config));
|
|
|
|
EXPECT_EQ(recv_config.decoders[0].payload_type,
|
|
unmarshaled_config.decoders[0].payload_type);
|
|
EXPECT_EQ(recv_config.decoders[0].video_format.name,
|
|
unmarshaled_config.decoders[0].video_format.name);
|
|
EXPECT_EQ(recv_config.decoders[0].video_format.parameters,
|
|
unmarshaled_config.decoders[0].video_format.parameters);
|
|
EXPECT_EQ(recv_config.render_delay_ms, unmarshaled_config.render_delay_ms);
|
|
EXPECT_EQ(recv_config.rtp.remote_ssrc, unmarshaled_config.rtp.remote_ssrc);
|
|
EXPECT_EQ(recv_config.rtp.local_ssrc, unmarshaled_config.rtp.local_ssrc);
|
|
EXPECT_EQ(recv_config.rtp.rtcp_mode, unmarshaled_config.rtp.rtcp_mode);
|
|
EXPECT_EQ(recv_config.rtp.lntf.enabled, unmarshaled_config.rtp.lntf.enabled);
|
|
EXPECT_EQ(recv_config.rtp.nack.rtp_history_ms,
|
|
unmarshaled_config.rtp.nack.rtp_history_ms);
|
|
EXPECT_EQ(recv_config.rtp.red_payload_type,
|
|
unmarshaled_config.rtp.red_payload_type);
|
|
EXPECT_EQ(recv_config.rtp.rtx_ssrc, unmarshaled_config.rtp.rtx_ssrc);
|
|
EXPECT_EQ(recv_config.rtp.rtx_associated_payload_types,
|
|
unmarshaled_config.rtp.rtx_associated_payload_types);
|
|
EXPECT_EQ(recv_config.rtp.extensions, recv_config.rtp.extensions);
|
|
}
|
|
|
|
} // namespace test
|
|
} // namespace webrtc
|