mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 05:40:42 +01:00
Keep Environment instead of test field trials in FakeCall test object
To pass field trials to EncoderStreamFactory in FakeVideoSendStream and thus reduce dependency on the global field trial. Bug: webrtc:10335 Change-Id: Iad32881c2d9158fe1d77f1b71f8d606374ea111e Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/346340 Reviewed-by: Harald Alvestrand <hta@webrtc.org> Commit-Queue: Danil Chapovalov <danilchap@webrtc.org> Cr-Commit-Position: refs/heads/main@{#42023}
This commit is contained in:
parent
72ab1aff5b
commit
8d079bea2a
7 changed files with 42 additions and 49 deletions
|
@ -720,8 +720,8 @@ if (rtc_build_dcsctp) {
|
||||||
":media_channel",
|
":media_channel",
|
||||||
":rtc_data_sctp_transport_internal",
|
":rtc_data_sctp_transport_internal",
|
||||||
"../api:array_view",
|
"../api:array_view",
|
||||||
"../api/environment",
|
|
||||||
"../api:libjingle_peerconnection_api",
|
"../api:libjingle_peerconnection_api",
|
||||||
|
"../api/environment",
|
||||||
"../api/task_queue:pending_task_safety_flag",
|
"../api/task_queue:pending_task_safety_flag",
|
||||||
"../api/task_queue:task_queue",
|
"../api/task_queue:task_queue",
|
||||||
"../net/dcsctp/public:factory",
|
"../net/dcsctp/public:factory",
|
||||||
|
@ -812,7 +812,6 @@ if (rtc_include_tests) {
|
||||||
"../api/environment",
|
"../api/environment",
|
||||||
"../api/task_queue",
|
"../api/task_queue",
|
||||||
"../api/task_queue:pending_task_safety_flag",
|
"../api/task_queue:pending_task_safety_flag",
|
||||||
"../api/transport:field_trial_based_config",
|
|
||||||
"../api/units:timestamp",
|
"../api/units:timestamp",
|
||||||
"../api/video:encoded_image",
|
"../api/video:encoded_image",
|
||||||
"../api/video:video_bitrate_allocation",
|
"../api/video:video_bitrate_allocation",
|
||||||
|
@ -844,7 +843,6 @@ if (rtc_include_tests) {
|
||||||
"../rtc_base:timeutils",
|
"../rtc_base:timeutils",
|
||||||
"../rtc_base/synchronization:mutex",
|
"../rtc_base/synchronization:mutex",
|
||||||
"../rtc_base/third_party/sigslot",
|
"../rtc_base/third_party/sigslot",
|
||||||
"../test:scoped_key_value_config",
|
|
||||||
"../test:test_support",
|
"../test:test_support",
|
||||||
"../video/config:streams_config",
|
"../video/config:streams_config",
|
||||||
"//testing/gtest",
|
"//testing/gtest",
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
#include "absl/algorithm/container.h"
|
#include "absl/algorithm/container.h"
|
||||||
#include "absl/strings/string_view.h"
|
#include "absl/strings/string_view.h"
|
||||||
#include "api/call/audio_sink.h"
|
#include "api/call/audio_sink.h"
|
||||||
|
#include "api/environment/environment.h"
|
||||||
#include "api/units/timestamp.h"
|
#include "api/units/timestamp.h"
|
||||||
#include "call/packet_receiver.h"
|
#include "call/packet_receiver.h"
|
||||||
#include "media/base/media_channel.h"
|
#include "media/base/media_channel.h"
|
||||||
|
@ -27,6 +28,7 @@
|
||||||
|
|
||||||
namespace cricket {
|
namespace cricket {
|
||||||
|
|
||||||
|
using ::webrtc::Environment;
|
||||||
using ::webrtc::ParseRtpSsrc;
|
using ::webrtc::ParseRtpSsrc;
|
||||||
|
|
||||||
FakeAudioSendStream::FakeAudioSendStream(
|
FakeAudioSendStream::FakeAudioSendStream(
|
||||||
|
@ -144,9 +146,11 @@ void FakeAudioReceiveStream::SetGain(float gain) {
|
||||||
}
|
}
|
||||||
|
|
||||||
FakeVideoSendStream::FakeVideoSendStream(
|
FakeVideoSendStream::FakeVideoSendStream(
|
||||||
|
const Environment& env,
|
||||||
webrtc::VideoSendStream::Config config,
|
webrtc::VideoSendStream::Config config,
|
||||||
webrtc::VideoEncoderConfig encoder_config)
|
webrtc::VideoEncoderConfig encoder_config)
|
||||||
: sending_(false),
|
: env_(env),
|
||||||
|
sending_(false),
|
||||||
config_(std::move(config)),
|
config_(std::move(config)),
|
||||||
codec_settings_set_(false),
|
codec_settings_set_(false),
|
||||||
resolution_scaling_enabled_(false),
|
resolution_scaling_enabled_(false),
|
||||||
|
@ -256,7 +260,8 @@ void FakeVideoSendStream::OnFrame(const webrtc::VideoFrame& frame) {
|
||||||
encoder_config_.video_format.name, encoder_config_.max_qp,
|
encoder_config_.video_format.name, encoder_config_.max_qp,
|
||||||
encoder_config_.content_type ==
|
encoder_config_.content_type ==
|
||||||
webrtc::VideoEncoderConfig::ContentType::kScreen,
|
webrtc::VideoEncoderConfig::ContentType::kScreen,
|
||||||
encoder_config_.legacy_conference_mode, encoder_info);
|
encoder_config_.legacy_conference_mode, encoder_info,
|
||||||
|
absl::nullopt, &env_.field_trials());
|
||||||
|
|
||||||
video_streams_ = factory->CreateEncoderStreams(
|
video_streams_ = factory->CreateEncoderStreams(
|
||||||
frame.width(), frame.height(), encoder_config_);
|
frame.width(), frame.height(), encoder_config_);
|
||||||
|
@ -444,19 +449,19 @@ void FakeFlexfecReceiveStream::OnRtpPacket(const webrtc::RtpPacketReceived&) {
|
||||||
RTC_DCHECK_NOTREACHED() << "Not implemented.";
|
RTC_DCHECK_NOTREACHED() << "Not implemented.";
|
||||||
}
|
}
|
||||||
|
|
||||||
FakeCall::FakeCall(webrtc::test::ScopedKeyValueConfig* field_trials)
|
FakeCall::FakeCall(const Environment& env)
|
||||||
: FakeCall(rtc::Thread::Current(), rtc::Thread::Current(), field_trials) {}
|
: FakeCall(env, rtc::Thread::Current(), rtc::Thread::Current()) {}
|
||||||
|
|
||||||
FakeCall::FakeCall(webrtc::TaskQueueBase* worker_thread,
|
FakeCall::FakeCall(const Environment& env,
|
||||||
webrtc::TaskQueueBase* network_thread,
|
webrtc::TaskQueueBase* worker_thread,
|
||||||
webrtc::test::ScopedKeyValueConfig* field_trials)
|
webrtc::TaskQueueBase* network_thread)
|
||||||
: network_thread_(network_thread),
|
: env_(env),
|
||||||
|
network_thread_(network_thread),
|
||||||
worker_thread_(worker_thread),
|
worker_thread_(worker_thread),
|
||||||
audio_network_state_(webrtc::kNetworkUp),
|
audio_network_state_(webrtc::kNetworkUp),
|
||||||
video_network_state_(webrtc::kNetworkUp),
|
video_network_state_(webrtc::kNetworkUp),
|
||||||
num_created_send_streams_(0),
|
num_created_send_streams_(0),
|
||||||
num_created_receive_streams_(0),
|
num_created_receive_streams_(0) {}
|
||||||
trials_(field_trials ? field_trials : &fallback_trials_) {}
|
|
||||||
|
|
||||||
FakeCall::~FakeCall() {
|
FakeCall::~FakeCall() {
|
||||||
EXPECT_EQ(0u, video_send_streams_.size());
|
EXPECT_EQ(0u, video_send_streams_.size());
|
||||||
|
@ -574,8 +579,8 @@ void FakeCall::DestroyAudioReceiveStream(
|
||||||
webrtc::VideoSendStream* FakeCall::CreateVideoSendStream(
|
webrtc::VideoSendStream* FakeCall::CreateVideoSendStream(
|
||||||
webrtc::VideoSendStream::Config config,
|
webrtc::VideoSendStream::Config config,
|
||||||
webrtc::VideoEncoderConfig encoder_config) {
|
webrtc::VideoEncoderConfig encoder_config) {
|
||||||
FakeVideoSendStream* fake_stream =
|
FakeVideoSendStream* fake_stream = new FakeVideoSendStream(
|
||||||
new FakeVideoSendStream(std::move(config), std::move(encoder_config));
|
env_, std::move(config), std::move(encoder_config));
|
||||||
video_send_streams_.push_back(fake_stream);
|
video_send_streams_.push_back(fake_stream);
|
||||||
++num_created_send_streams_;
|
++num_created_send_streams_;
|
||||||
return fake_stream;
|
return fake_stream;
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "absl/strings/string_view.h"
|
#include "absl/strings/string_view.h"
|
||||||
#include "api/transport/field_trial_based_config.h"
|
#include "api/environment/environment.h"
|
||||||
#include "api/video/video_frame.h"
|
#include "api/video/video_frame.h"
|
||||||
#include "call/audio_receive_stream.h"
|
#include "call/audio_receive_stream.h"
|
||||||
#include "call/audio_send_stream.h"
|
#include "call/audio_send_stream.h"
|
||||||
|
@ -38,7 +38,6 @@
|
||||||
#include "call/video_send_stream.h"
|
#include "call/video_send_stream.h"
|
||||||
#include "modules/rtp_rtcp/source/rtp_packet_received.h"
|
#include "modules/rtp_rtcp/source/rtp_packet_received.h"
|
||||||
#include "rtc_base/buffer.h"
|
#include "rtc_base/buffer.h"
|
||||||
#include "test/scoped_key_value_config.h"
|
|
||||||
|
|
||||||
namespace cricket {
|
namespace cricket {
|
||||||
class FakeAudioSendStream final : public webrtc::AudioSendStream {
|
class FakeAudioSendStream final : public webrtc::AudioSendStream {
|
||||||
|
@ -158,7 +157,8 @@ class FakeVideoSendStream final
|
||||||
: public webrtc::VideoSendStream,
|
: public webrtc::VideoSendStream,
|
||||||
public rtc::VideoSinkInterface<webrtc::VideoFrame> {
|
public rtc::VideoSinkInterface<webrtc::VideoFrame> {
|
||||||
public:
|
public:
|
||||||
FakeVideoSendStream(webrtc::VideoSendStream::Config config,
|
FakeVideoSendStream(const webrtc::Environment& env,
|
||||||
|
webrtc::VideoSendStream::Config config,
|
||||||
webrtc::VideoEncoderConfig encoder_config);
|
webrtc::VideoEncoderConfig encoder_config);
|
||||||
~FakeVideoSendStream() override;
|
~FakeVideoSendStream() override;
|
||||||
const webrtc::VideoSendStream::Config& GetConfig() const;
|
const webrtc::VideoSendStream::Config& GetConfig() const;
|
||||||
|
@ -215,6 +215,7 @@ class FakeVideoSendStream final
|
||||||
void ReconfigureVideoEncoder(webrtc::VideoEncoderConfig config,
|
void ReconfigureVideoEncoder(webrtc::VideoEncoderConfig config,
|
||||||
webrtc::SetParametersCallback callback) override;
|
webrtc::SetParametersCallback callback) override;
|
||||||
|
|
||||||
|
const webrtc::Environment env_;
|
||||||
bool sending_;
|
bool sending_;
|
||||||
webrtc::VideoSendStream::Config config_;
|
webrtc::VideoSendStream::Config config_;
|
||||||
webrtc::VideoEncoderConfig encoder_config_;
|
webrtc::VideoEncoderConfig encoder_config_;
|
||||||
|
@ -363,10 +364,10 @@ class FakeFlexfecReceiveStream final : public webrtc::FlexfecReceiveStream {
|
||||||
|
|
||||||
class FakeCall final : public webrtc::Call, public webrtc::PacketReceiver {
|
class FakeCall final : public webrtc::Call, public webrtc::PacketReceiver {
|
||||||
public:
|
public:
|
||||||
explicit FakeCall(webrtc::test::ScopedKeyValueConfig* field_trials = nullptr);
|
explicit FakeCall(const webrtc::Environment& env);
|
||||||
FakeCall(webrtc::TaskQueueBase* worker_thread,
|
FakeCall(const webrtc::Environment& env,
|
||||||
webrtc::TaskQueueBase* network_thread,
|
webrtc::TaskQueueBase* worker_thread,
|
||||||
webrtc::test::ScopedKeyValueConfig* field_trials = nullptr);
|
webrtc::TaskQueueBase* network_thread);
|
||||||
~FakeCall() override;
|
~FakeCall() override;
|
||||||
|
|
||||||
webrtc::MockRtpTransportControllerSend* GetMockTransportControllerSend() {
|
webrtc::MockRtpTransportControllerSend* GetMockTransportControllerSend() {
|
||||||
|
@ -406,14 +407,10 @@ class FakeCall final : public webrtc::Call, public webrtc::PacketReceiver {
|
||||||
|
|
||||||
void SetClientBitratePreferences(
|
void SetClientBitratePreferences(
|
||||||
const webrtc::BitrateSettings& preferences) override {}
|
const webrtc::BitrateSettings& preferences) override {}
|
||||||
|
const webrtc::FieldTrialsView& trials() const override {
|
||||||
void SetFieldTrial(const std::string& field_trial_string) {
|
return env_.field_trials();
|
||||||
trials_overrides_ = std::make_unique<webrtc::test::ScopedKeyValueConfig>(
|
|
||||||
*trials_, field_trial_string);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const webrtc::FieldTrialsView& trials() const override { return *trials_; }
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
webrtc::AudioSendStream* CreateAudioSendStream(
|
webrtc::AudioSendStream* CreateAudioSendStream(
|
||||||
const webrtc::AudioSendStream::Config& config) override;
|
const webrtc::AudioSendStream::Config& config) override;
|
||||||
|
@ -480,6 +477,7 @@ class FakeCall final : public webrtc::Call, public webrtc::PacketReceiver {
|
||||||
absl::string_view sync_group) override;
|
absl::string_view sync_group) override;
|
||||||
void OnSentPacket(const rtc::SentPacket& sent_packet) override;
|
void OnSentPacket(const rtc::SentPacket& sent_packet) override;
|
||||||
|
|
||||||
|
const webrtc::Environment env_;
|
||||||
webrtc::TaskQueueBase* const network_thread_;
|
webrtc::TaskQueueBase* const network_thread_;
|
||||||
webrtc::TaskQueueBase* const worker_thread_;
|
webrtc::TaskQueueBase* const worker_thread_;
|
||||||
|
|
||||||
|
@ -502,16 +500,6 @@ class FakeCall final : public webrtc::Call, public webrtc::PacketReceiver {
|
||||||
|
|
||||||
int num_created_send_streams_;
|
int num_created_send_streams_;
|
||||||
int num_created_receive_streams_;
|
int num_created_receive_streams_;
|
||||||
|
|
||||||
// The field trials that are in use, either supplied by caller
|
|
||||||
// or pointer to &fallback_trials_.
|
|
||||||
webrtc::test::ScopedKeyValueConfig* trials_;
|
|
||||||
|
|
||||||
// fallback_trials_ is used if caller does not provide any field trials.
|
|
||||||
webrtc::test::ScopedKeyValueConfig fallback_trials_;
|
|
||||||
|
|
||||||
// An extra field trial that can be set using SetFieldTrial.
|
|
||||||
std::unique_ptr<webrtc::test::ScopedKeyValueConfig> trials_overrides_;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace cricket
|
} // namespace cricket
|
||||||
|
|
|
@ -747,7 +747,7 @@ TEST_F(WebRtcVideoEngineTest, CanConstructDecoderForVp9EncoderFactory) {
|
||||||
|
|
||||||
TEST_F(WebRtcVideoEngineTest, PropagatesInputFrameTimestamp) {
|
TEST_F(WebRtcVideoEngineTest, PropagatesInputFrameTimestamp) {
|
||||||
AddSupportedVideoCodecType("VP8");
|
AddSupportedVideoCodecType("VP8");
|
||||||
FakeCall* fake_call = new FakeCall();
|
FakeCall* fake_call = new FakeCall(env_);
|
||||||
call_.reset(fake_call);
|
call_.reset(fake_call);
|
||||||
auto send_channel = SetSendParamsWithAllSupportedCodecs();
|
auto send_channel = SetSendParamsWithAllSupportedCodecs();
|
||||||
|
|
||||||
|
@ -1476,7 +1476,7 @@ TEST(WebRtcVideoEngineNewVideoCodecFactoryTest, Vp8) {
|
||||||
|
|
||||||
TEST_F(WebRtcVideoEngineTest, DISABLED_RecreatesEncoderOnContentTypeChange) {
|
TEST_F(WebRtcVideoEngineTest, DISABLED_RecreatesEncoderOnContentTypeChange) {
|
||||||
encoder_factory_->AddSupportedVideoCodecType("VP8");
|
encoder_factory_->AddSupportedVideoCodecType("VP8");
|
||||||
std::unique_ptr<FakeCall> fake_call(new FakeCall());
|
auto fake_call = std::make_unique<FakeCall>(env_);
|
||||||
auto send_channel = SetSendParamsWithAllSupportedCodecs();
|
auto send_channel = SetSendParamsWithAllSupportedCodecs();
|
||||||
|
|
||||||
ASSERT_TRUE(
|
ASSERT_TRUE(
|
||||||
|
@ -2622,7 +2622,7 @@ class WebRtcVideoChannelTest : public WebRtcVideoEngineTest {
|
||||||
AddSupportedVideoCodecType("H264");
|
AddSupportedVideoCodecType("H264");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fake_call_.reset(new FakeCall(&field_trials_));
|
fake_call_ = std::make_unique<FakeCall>(env_);
|
||||||
send_channel_ = engine_.CreateSendChannel(
|
send_channel_ = engine_.CreateSendChannel(
|
||||||
fake_call_.get(), GetMediaConfig(), VideoOptions(),
|
fake_call_.get(), GetMediaConfig(), VideoOptions(),
|
||||||
webrtc::CryptoOptions(), video_bitrate_allocator_factory_.get());
|
webrtc::CryptoOptions(), video_bitrate_allocator_factory_.get());
|
||||||
|
@ -9489,7 +9489,7 @@ TEST_F(WebRtcVideoChannelTest, GenerateKeyFrameSimulcast) {
|
||||||
class WebRtcVideoChannelSimulcastTest : public ::testing::Test {
|
class WebRtcVideoChannelSimulcastTest : public ::testing::Test {
|
||||||
public:
|
public:
|
||||||
WebRtcVideoChannelSimulcastTest()
|
WebRtcVideoChannelSimulcastTest()
|
||||||
: fake_call_(),
|
: fake_call_(CreateEnvironment(&field_trials_)),
|
||||||
encoder_factory_(new cricket::FakeWebRtcVideoEncoderFactory),
|
encoder_factory_(new cricket::FakeWebRtcVideoEncoderFactory),
|
||||||
decoder_factory_(new cricket::FakeWebRtcVideoDecoderFactory),
|
decoder_factory_(new cricket::FakeWebRtcVideoDecoderFactory),
|
||||||
mock_rate_allocator_factory_(
|
mock_rate_allocator_factory_(
|
||||||
|
|
|
@ -195,13 +195,13 @@ class WebRtcVoiceEngineTestFake : public ::testing::TestWithParam<bool> {
|
||||||
public:
|
public:
|
||||||
WebRtcVoiceEngineTestFake()
|
WebRtcVoiceEngineTestFake()
|
||||||
: use_null_apm_(GetParam()),
|
: use_null_apm_(GetParam()),
|
||||||
task_queue_factory_(webrtc::CreateDefaultTaskQueueFactory()),
|
env_(CreateEnvironment(&field_trials_)),
|
||||||
adm_(webrtc::test::MockAudioDeviceModule::CreateStrict()),
|
adm_(webrtc::test::MockAudioDeviceModule::CreateStrict()),
|
||||||
apm_(use_null_apm_
|
apm_(use_null_apm_
|
||||||
? nullptr
|
? nullptr
|
||||||
: rtc::make_ref_counted<
|
: rtc::make_ref_counted<
|
||||||
StrictMock<webrtc::test::MockAudioProcessing>>()),
|
StrictMock<webrtc::test::MockAudioProcessing>>()),
|
||||||
call_(&field_trials_) {
|
call_(env_) {
|
||||||
// AudioDeviceModule.
|
// AudioDeviceModule.
|
||||||
AdmSetupExpectations(adm_.get());
|
AdmSetupExpectations(adm_.get());
|
||||||
|
|
||||||
|
@ -220,9 +220,9 @@ class WebRtcVoiceEngineTestFake : public ::testing::TestWithParam<bool> {
|
||||||
// factories. Those tests should probably be moved elsewhere.
|
// factories. Those tests should probably be moved elsewhere.
|
||||||
auto encoder_factory = webrtc::CreateBuiltinAudioEncoderFactory();
|
auto encoder_factory = webrtc::CreateBuiltinAudioEncoderFactory();
|
||||||
auto decoder_factory = webrtc::CreateBuiltinAudioDecoderFactory();
|
auto decoder_factory = webrtc::CreateBuiltinAudioDecoderFactory();
|
||||||
engine_.reset(new cricket::WebRtcVoiceEngine(
|
engine_ = std::make_unique<cricket::WebRtcVoiceEngine>(
|
||||||
task_queue_factory_.get(), adm_.get(), encoder_factory, decoder_factory,
|
&env_.task_queue_factory(), adm_.get(), encoder_factory,
|
||||||
nullptr, apm_, nullptr, field_trials_));
|
decoder_factory, nullptr, apm_, nullptr, env_.field_trials());
|
||||||
engine_->Init();
|
engine_->Init();
|
||||||
send_parameters_.codecs.push_back(kPcmuCodec);
|
send_parameters_.codecs.push_back(kPcmuCodec);
|
||||||
recv_parameters_.codecs.push_back(kPcmuCodec);
|
recv_parameters_.codecs.push_back(kPcmuCodec);
|
||||||
|
@ -846,7 +846,7 @@ class WebRtcVoiceEngineTestFake : public ::testing::TestWithParam<bool> {
|
||||||
rtc::AutoThread main_thread_;
|
rtc::AutoThread main_thread_;
|
||||||
const bool use_null_apm_;
|
const bool use_null_apm_;
|
||||||
webrtc::test::ScopedKeyValueConfig field_trials_;
|
webrtc::test::ScopedKeyValueConfig field_trials_;
|
||||||
std::unique_ptr<webrtc::TaskQueueFactory> task_queue_factory_;
|
const Environment env_;
|
||||||
rtc::scoped_refptr<webrtc::test::MockAudioDeviceModule> adm_;
|
rtc::scoped_refptr<webrtc::test::MockAudioDeviceModule> adm_;
|
||||||
rtc::scoped_refptr<StrictMock<webrtc::test::MockAudioProcessing>> apm_;
|
rtc::scoped_refptr<StrictMock<webrtc::test::MockAudioProcessing>> apm_;
|
||||||
cricket::FakeCall call_;
|
cricket::FakeCall call_;
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "api/crypto/frame_decryptor_interface.h"
|
#include "api/crypto/frame_decryptor_interface.h"
|
||||||
#include "api/crypto/frame_encryptor_interface.h"
|
#include "api/crypto/frame_encryptor_interface.h"
|
||||||
#include "api/dtmf_sender_interface.h"
|
#include "api/dtmf_sender_interface.h"
|
||||||
|
#include "api/environment/environment_factory.h"
|
||||||
#include "api/media_stream_interface.h"
|
#include "api/media_stream_interface.h"
|
||||||
#include "api/rtc_error.h"
|
#include "api/rtc_error.h"
|
||||||
#include "api/rtc_event_log/rtc_event_log.h"
|
#include "api/rtc_event_log/rtc_event_log.h"
|
||||||
|
@ -109,7 +110,7 @@ class RtpSenderReceiverTest
|
||||||
// Create fake media engine/etc. so we can create channels to use to
|
// Create fake media engine/etc. so we can create channels to use to
|
||||||
// test RtpSenders/RtpReceivers.
|
// test RtpSenders/RtpReceivers.
|
||||||
media_engine_(std::make_unique<cricket::FakeMediaEngine>()),
|
media_engine_(std::make_unique<cricket::FakeMediaEngine>()),
|
||||||
fake_call_(worker_thread_, network_thread_),
|
fake_call_(CreateEnvironment(), worker_thread_, network_thread_),
|
||||||
local_stream_(MediaStream::Create(kStreamId1)) {
|
local_stream_(MediaStream::Create(kStreamId1)) {
|
||||||
rtp_dtls_transport_ = std::make_unique<cricket::FakeDtlsTransport>(
|
rtp_dtls_transport_ = std::make_unique<cricket::FakeDtlsTransport>(
|
||||||
"fake_dtls_transport", cricket::ICE_CANDIDATE_COMPONENT_RTP);
|
"fake_dtls_transport", cricket::ICE_CANDIDATE_COMPONENT_RTP);
|
||||||
|
|
|
@ -199,6 +199,7 @@ class VideoReceiveStream2Test : public ::testing::TestWithParam<bool> {
|
||||||
config_(&mock_transport_, &mock_h264_decoder_factory_),
|
config_(&mock_transport_, &mock_h264_decoder_factory_),
|
||||||
call_stats_(&env_.clock(), time_controller_.GetMainThread()),
|
call_stats_(&env_.clock(), time_controller_.GetMainThread()),
|
||||||
fake_renderer_(&time_controller_),
|
fake_renderer_(&time_controller_),
|
||||||
|
fake_call_(env_),
|
||||||
fake_metronome_(TimeDelta::Millis(16)),
|
fake_metronome_(TimeDelta::Millis(16)),
|
||||||
decode_sync_(&env_.clock(),
|
decode_sync_(&env_.clock(),
|
||||||
&fake_metronome_,
|
&fake_metronome_,
|
||||||
|
|
Loading…
Reference in a new issue