Index: webrtc/video/loopback.cc |
diff --git a/webrtc/video/loopback.cc b/webrtc/video/loopback.cc |
index 9083500c1e6a3a80583812f32a97c99e320595b2..2a80b101126f62b031933c9656f9d03f3acb233e 100644 |
--- a/webrtc/video/loopback.cc |
+++ b/webrtc/video/loopback.cc |
@@ -27,8 +27,8 @@ |
#include "webrtc/test/encoder_settings.h" |
#include "webrtc/test/fake_encoder.h" |
#include "webrtc/test/layer_filtering_transport.h" |
+#include "webrtc/test/frame_generator.h" |
#include "webrtc/test/run_loop.h" |
-#include "webrtc/test/testsupport/trace_to_stderr.h" |
#include "webrtc/test/video_capturer.h" |
#include "webrtc/test/video_renderer.h" |
#include "webrtc/typedefs.h" |
@@ -36,12 +36,6 @@ |
namespace webrtc { |
namespace test { |
-static const int kAbsSendTimeExtensionId = 7; |
- |
-static const uint32_t kSendSsrc = 0x654321; |
-static const uint32_t kSendRtxSsrc = 0x654322; |
-static const uint32_t kReceiverLocalSsrc = 0x123456; |
- |
static const uint8_t kRtxVideoPayloadType = 96; |
static const uint8_t kVideoPayloadTypeVP8 = 124; |
static const uint8_t kVideoPayloadTypeVP9 = 125; |
@@ -50,28 +44,27 @@ Loopback::Loopback(const Config& config) |
: config_(config), clock_(Clock::GetRealTimeClock()) { |
} |
-Loopback::~Loopback() { |
+void Loopback::TestBody() { |
+ // Empty. Use Run() instead. |
sprang_webrtc
2015/09/11 08:01:34
Should this ever be reached?
ivica
2015/09/14 17:12:55
Whoops, rebase error. This file should've been rem
|
} |
void Loopback::Run() { |
- rtc::scoped_ptr<test::TraceToStderr> trace_to_stderr_; |
- if (config_.logs) |
- trace_to_stderr_.reset(new test::TraceToStderr); |
- |
rtc::scoped_ptr<test::VideoRenderer> local_preview( |
- test::VideoRenderer::Create("Local Preview", config_.width, |
- config_.height)); |
+ test::VideoRenderer::Create("Local Preview", config_.shared.width, |
+ config_.shared.height)); |
rtc::scoped_ptr<test::VideoRenderer> loopback_video( |
- test::VideoRenderer::Create("Loopback Video", config_.width, |
- config_.height)); |
+ test::VideoRenderer::Create("Loopback Video", config_.shared.width, |
+ config_.shared.height)); |
+ |
+ test::DirectTransport transport(config_.shared.pipe); |
+ Call::Config call_config(&transport); |
- Call::Config call_config; |
call_config.bitrate_config.min_bitrate_bps = |
- static_cast<int>(config_.min_bitrate_kbps) * 1000; |
+ static_cast<int>(config_.shared.min_bitrate_bps); |
call_config.bitrate_config.start_bitrate_bps = |
- static_cast<int>(config_.start_bitrate_kbps) * 1000; |
+ static_cast<int>(config_.start_bitrate_bps); |
call_config.bitrate_config.max_bitrate_bps = |
- static_cast<int>(config_.max_bitrate_kbps) * 1000; |
+ static_cast<int>(config_.shared.max_bitrate_bps); |
rtc::scoped_ptr<Call> call(Call::Create(call_config)); |
FakeNetworkPipe::Config pipe_config; |
@@ -88,54 +81,36 @@ void Loopback::Run() { |
// Loopback, call sends to itself. |
send_transport.SetReceiver(call->Receiver()); |
- VideoSendStream::Config send_config(&send_transport); |
- send_config.rtp.ssrcs.push_back(kSendSsrc); |
- send_config.rtp.rtx.ssrcs.push_back(kSendRtxSsrc); |
- send_config.rtp.rtx.payload_type = kRtxVideoPayloadType; |
- send_config.rtp.nack.rtp_history_ms = 1000; |
- send_config.rtp.extensions.push_back( |
- RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeExtensionId)); |
- |
- send_config.local_renderer = local_preview.get(); |
rtc::scoped_ptr<VideoEncoder> encoder; |
- if (config_.codec == "VP8") { |
- encoder.reset(VideoEncoder::Create(VideoEncoder::kVp8)); |
- } else if (config_.codec == "VP9") { |
- encoder.reset(VideoEncoder::Create(VideoEncoder::kVp9)); |
- } else { |
- // Codec not supported. |
- RTC_NOTREACHED() << "Codec not supported!"; |
- return; |
- } |
- const int payload_type = |
- config_.codec == "VP8" ? kVideoPayloadTypeVP8 : kVideoPayloadTypeVP9; |
- send_config.encoder_settings.encoder = encoder.get(); |
- send_config.encoder_settings.payload_name = config_.codec; |
- send_config.encoder_settings.payload_type = payload_type; |
- |
- VideoEncoderConfig encoder_config(CreateEncoderConfig()); |
+ SendConfigDefaultValues(&config_.shared); |
+ SetupFromSharedConfig(config_.shared, &encoder); |
+ send_config_.local_renderer = local_preview.get(); |
+ send_config_.encoder_settings.payload_type = kVideoPayloadType; |
+ // VideoSendStream::Config send_config; |
+ // send_config.rtp.ssrcs.push_back(kSendSsrc); // (!) |
+ // send_config.rtp.rtx.ssrcs.push_back(kSendRtxSsrc); // (!) |
+ send_config_.rtp.rtx.payload_type = kRtxVideoPayloadType; // (!) |
sprang_webrtc
2015/09/11 08:01:34
What's with the comments here?
ivica
2015/09/14 17:12:55
Same as above, file deleted.
|
+ |
+ rtc::scoped_ptr<test::FrameGenerator> frame_generator; |
+ SetupScreenshare(config_.shared, &codec_settings_, &frame_generator); |
sprang_webrtc
2015/09/11 08:01:34
Is this only used with screenshare?
ivica
2015/09/14 17:12:55
Same as above, file deleted.
|
VideoSendStream* send_stream = |
- call->CreateVideoSendStream(send_config, encoder_config); |
- |
- rtc::scoped_ptr<test::VideoCapturer> capturer(CreateCapturer(send_stream)); |
- |
- VideoReceiveStream::Config receive_config(&send_transport); |
- receive_config.rtp.remote_ssrc = send_config.rtp.ssrcs[0]; |
- receive_config.rtp.local_ssrc = kReceiverLocalSsrc; |
- receive_config.rtp.nack.rtp_history_ms = 1000; |
- receive_config.rtp.remb = true; |
- receive_config.rtp.rtx[payload_type].ssrc = kSendRtxSsrc; |
- receive_config.rtp.rtx[payload_type].payload_type = kRtxVideoPayloadType; |
- receive_config.rtp.extensions.push_back( |
+ call->CreateVideoSendStream(send_config_, encoder_config_); |
+ |
+ test::FrameGeneratorCapturer* capturer = new test::FrameGeneratorCapturer( |
+ clock_, send_stream->Input(), frame_generator.release(), |
+ config_.shared.fps); |
+ EXPECT_TRUE(capturer->Init()); |
+ |
+ receive_configs_[0].rtp.rtx[kVideoPayloadType].ssrc = kSendRtxSsrcs[0]; |
+ receive_configs_[0].rtp.rtx[kVideoPayloadType].payload_type = |
+ kRtxVideoPayloadType; |
+ receive_configs_[0].rtp.extensions.push_back( |
RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeExtensionId)); |
- receive_config.renderer = loopback_video.get(); |
- VideoReceiveStream::Decoder decoder = |
- test::CreateMatchingDecoder(send_config.encoder_settings); |
- receive_config.decoders.push_back(decoder); |
+ receive_configs_[0].renderer = loopback_video.get(); |
VideoReceiveStream* receive_stream = |
- call->CreateVideoReceiveStream(receive_config); |
+ call->CreateVideoReceiveStream(receive_configs_[0]); |
receive_stream->Start(); |
send_stream->Start(); |
@@ -150,34 +125,10 @@ void Loopback::Run() { |
call->DestroyVideoReceiveStream(receive_stream); |
call->DestroyVideoSendStream(send_stream); |
- delete decoder.decoder; |
+ // delete decoder.decoder; |
sprang_webrtc
2015/09/11 08:01:34
Remove
ivica
2015/09/14 17:12:55
Same as above, file deleted.
|
send_transport.StopSending(); |
} |
-VideoEncoderConfig Loopback::CreateEncoderConfig() { |
- VideoEncoderConfig encoder_config; |
- encoder_config.streams = test::CreateVideoStreams(1); |
- VideoStream* stream = &encoder_config.streams[0]; |
- stream->width = config_.width; |
- stream->height = config_.height; |
- stream->min_bitrate_bps = static_cast<int>(config_.min_bitrate_kbps) * 1000; |
- stream->max_bitrate_bps = static_cast<int>(config_.max_bitrate_kbps) * 1000; |
- stream->target_bitrate_bps = |
- static_cast<int>(config_.max_bitrate_kbps) * 1000; |
- stream->max_framerate = config_.fps; |
- stream->max_qp = 56; |
- if (config_.num_temporal_layers != 0) { |
- stream->temporal_layer_thresholds_bps.resize(config_.num_temporal_layers - |
- 1); |
- } |
- return encoder_config; |
-} |
- |
-test::VideoCapturer* Loopback::CreateCapturer(VideoSendStream* send_stream) { |
- return test::VideoCapturer::Create(send_stream->Input(), config_.width, |
- config_.height, config_.fps, clock_); |
-} |
- |
} // namespace test |
} // namespace webrtc |