| Index: webrtc/video/full_stack.cc
|
| diff --git a/webrtc/video/full_stack.cc b/webrtc/video/full_stack.cc
|
| index 26aae3c1ff0d86a188f7f3503addca974dd4a871..42c110a98e69cf9cd891384dac65d31f078cb4d0 100644
|
| --- a/webrtc/video/full_stack.cc
|
| +++ b/webrtc/video/full_stack.cc
|
| @@ -24,22 +24,20 @@ class FullStackTest : public VideoQualityTest {
|
|
|
| void ForemanCifWithoutPacketLoss(const std::string& video_codec) {
|
| // TODO(pbos): Decide on psnr/ssim thresholds for foreman_cif.
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 700000, 700000, 700000, false, video_codec, 1},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_net_delay_0_0_plr_0_" + video_codec, 0.0, 0.0,
|
| - kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 700000, 700000, 700000, false,
|
| + video_codec, 1, 0, 0, false, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_net_delay_0_0_plr_0_" + video_codec,
|
| + 0.0, 0.0, kFullStackTestDurationSecs};
|
| RunTest(foreman_cif);
|
| }
|
|
|
| void ForemanCifPlr5(const std::string& video_codec) {
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 30000, 500000, 2000000, false, video_codec, 1},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_delay_50_0_plr_5_" + video_codec, 0.0, 0.0,
|
| - kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false,
|
| + video_codec, 1, 0, 0, false, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_delay_50_0_plr_5_" + video_codec, 0.0,
|
| + 0.0, kFullStackTestDurationSecs};
|
| foreman_cif.pipe.loss_percent = 5;
|
| foreman_cif.pipe.queue_delay_ms = 50;
|
| RunTest(foreman_cif);
|
| @@ -67,42 +65,41 @@ TEST_F(FullStackTest, ForemanCifPlr5Vp9) {
|
| #endif // !defined(RTC_DISABLE_VP9)
|
|
|
| TEST_F(FullStackTest, ParisQcifWithoutPacketLoss) {
|
| - VideoQualityTest::Params paris_qcif = {
|
| - {176, 144, 30, 300000, 300000, 300000, false, "VP8", 1, 0, 0, true},
|
| - {"paris_qcif"},
|
| - {},
|
| - {"net_delay_0_0_plr_0", 36.0, 0.96, kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params paris_qcif;
|
| + paris_qcif.video = {true, 176, 144, 30, 300000, 300000, 300000, false,
|
| + "VP8", 1, 0, 0, true, "paris_qcif"};
|
| + paris_qcif.analyzer = {"net_delay_0_0_plr_0", 36.0, 0.96,
|
| + kFullStackTestDurationSecs};
|
| RunTest(paris_qcif);
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCifWithoutPacketLoss) {
|
| // TODO(pbos): Decide on psnr/ssim thresholds for foreman_cif.
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 700000, 700000, 700000, false, "VP8", 1, 0, 0, true},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_net_delay_0_0_plr_0", 0.0, 0.0,
|
| - kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 700000, 700000, 700000, false, "VP8",
|
| + 1, 0, 0, true, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_net_delay_0_0_plr_0", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| RunTest(foreman_cif);
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCifPlr5) {
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 30000, 500000, 2000000, false, "VP8", 1, 0, 0, true},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_delay_50_0_plr_5", 0.0, 0.0, kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
|
| + 1, 0, 0, true, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_delay_50_0_plr_5", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| foreman_cif.pipe.loss_percent = 5;
|
| foreman_cif.pipe.queue_delay_ms = 50;
|
| RunTest(foreman_cif);
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbps) {
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 30000, 500000, 2000000, false, "VP8", 1, 0, 0, true},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_500kbps", 0.0, 0.0, kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
|
| + 1, 0, 0, true, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_500kbps", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| foreman_cif.pipe.queue_length_packets = 0;
|
| foreman_cif.pipe.queue_delay_ms = 0;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -110,12 +107,11 @@ TEST_F(FullStackTest, ForemanCif500kbps) {
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbpsLimitedQueue) {
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 30000, 500000, 2000000, false, "VP8", 1, 0, 0, true},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_500kbps_32pkts_queue", 0.0, 0.0,
|
| - kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
|
| + 1, 0, 0, true, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_500kbps_32pkts_queue", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| foreman_cif.pipe.queue_length_packets = 32;
|
| foreman_cif.pipe.queue_delay_ms = 0;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -123,11 +119,11 @@ TEST_F(FullStackTest, ForemanCif500kbpsLimitedQueue) {
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbps100ms) {
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 30000, 500000, 2000000, false, "VP8", 1, 0, 0, true},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_500kbps_100ms", 0.0, 0.0, kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
|
| + 1, 0, 0, true, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_500kbps_100ms", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| foreman_cif.pipe.queue_length_packets = 0;
|
| foreman_cif.pipe.queue_delay_ms = 100;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -135,12 +131,11 @@ TEST_F(FullStackTest, ForemanCif500kbps100ms) {
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbps100msLimitedQueue) {
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 30000, 500000, 2000000, false, "VP8", 1, 0, 0, true},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_500kbps_100ms_32pkts_queue", 0.0, 0.0,
|
| - kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
|
| + 1, 0, 0, true, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_500kbps_100ms_32pkts_queue", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| foreman_cif.pipe.queue_length_packets = 32;
|
| foreman_cif.pipe.queue_delay_ms = 100;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -148,12 +143,11 @@ TEST_F(FullStackTest, ForemanCif500kbps100msLimitedQueue) {
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbps100msLimitedQueueRecvBwe) {
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 30000, 500000, 2000000, false, "VP8", 1, 0, 0, false},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_500kbps_100ms_32pkts_queue", 0.0, 0.0,
|
| - kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
|
| + 1, 0, 0, false, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_500kbps_100ms_32pkts_queue", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| foreman_cif.pipe.queue_length_packets = 32;
|
| foreman_cif.pipe.queue_delay_ms = 100;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -161,12 +155,11 @@ TEST_F(FullStackTest, ForemanCif500kbps100msLimitedQueueRecvBwe) {
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif1000kbps100msLimitedQueue) {
|
| - VideoQualityTest::Params foreman_cif = {
|
| - {352, 288, 30, 30000, 2000000, 2000000, false, "VP8", 1, 0, 0, true},
|
| - {"foreman_cif"},
|
| - {},
|
| - {"foreman_cif_1000kbps_100ms_32pkts_queue", 0.0, 0.0,
|
| - kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params foreman_cif;
|
| + foreman_cif.video = {true, 352, 288, 30, 30000, 2000000, 2000000, false,
|
| + "VP8", 1, 0, 0, true, "foreman_cif"};
|
| + foreman_cif.analyzer = {"foreman_cif_1000kbps_100ms_32pkts_queue", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| foreman_cif.pipe.queue_length_packets = 32;
|
| foreman_cif.pipe.queue_delay_ms = 100;
|
| foreman_cif.pipe.link_capacity_kbps = 1000;
|
| @@ -174,12 +167,11 @@ TEST_F(FullStackTest, ForemanCif1000kbps100msLimitedQueue) {
|
| }
|
|
|
| TEST_F(FullStackTest, ConferenceMotionHd2000kbps100msLimitedQueue) {
|
| - VideoQualityTest::Params conf_motion_hd = {
|
| - {1280, 720, 50, 30000, 3000000, 3000000, false, "VP8", 1, 0, 0, true},
|
| - {"ConferenceMotion_1280_720_50"},
|
| - {},
|
| - {"conference_motion_hd_2000kbps_100ms_32pkts_queue", 0.0, 0.0,
|
| - kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params conf_motion_hd;
|
| + conf_motion_hd.video = {true, 1280, 720, 50, 30000, 3000000, 3000000, false,
|
| + "VP8", 1, 0, 0, true, "ConferenceMotion_1280_720_50"};
|
| + conf_motion_hd.analyzer = {"conference_motion_hd_2000kbps_100ms_32pkts_queue",
|
| + 0.0, 0.0, kFullStackTestDurationSecs};
|
| conf_motion_hd.pipe.queue_length_packets = 32;
|
| conf_motion_hd.pipe.queue_delay_ms = 100;
|
| conf_motion_hd.pipe.link_capacity_kbps = 2000;
|
| @@ -187,30 +179,32 @@ TEST_F(FullStackTest, ConferenceMotionHd2000kbps100msLimitedQueue) {
|
| }
|
|
|
| TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL) {
|
| - VideoQualityTest::Params screenshare = {
|
| - {1850, 1110, 5, 50000, 200000, 2000000, false, "VP8", 2, 1, 400000, true},
|
| - {},
|
| - {true, 10},
|
| - {"screenshare_slides", 0.0, 0.0, kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params screenshare;
|
| + screenshare.video = {true, 1850, 1110, 5, 50000, 200000, 2000000, false,
|
| + "VP8", 2, 1, 400000, true, ""};
|
| + screenshare.screenshare = {true, 10};
|
| + screenshare.analyzer = {"screenshare_slides", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| RunTest(screenshare);
|
| }
|
|
|
| TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL_Scroll) {
|
| - VideoQualityTest::Params config = {
|
| - {1850, 1110 / 2, 5, 50000, 200000, 2000000, false, "VP8", 2, 1, 400000,
|
| - true},
|
| - {},
|
| - {true, 10, 2},
|
| - {"screenshare_slides_scrolling", 0.0, 0.0, kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params config;
|
| + config.video = {true, 1850, 1110 / 2, 5, 50000, 200000, 2000000, false,
|
| + "VP8", 2, 1, 400000, true, ""};
|
| + config.screenshare = {true, 10, 2};
|
| + config.analyzer = {"screenshare_slides_scrolling", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| RunTest(config);
|
| }
|
|
|
| TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL_LossyNet) {
|
| - VideoQualityTest::Params screenshare = {
|
| - {1850, 1110, 5, 50000, 200000, 2000000, false, "VP8", 2, 1, 400000, true},
|
| - {}, // Video-specific.
|
| - {true, 10}, // Screenshare-specific.
|
| - {"screenshare_slides_lossy_net", 0.0, 0.0, kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params screenshare;
|
| + screenshare.video = {true, 1850, 1110, 5, 50000, 200000, 2000000, false,
|
| + "VP8", 2, 1, 400000, true, ""};
|
| + screenshare.screenshare = {true, 10};
|
| + screenshare.analyzer = {"screenshare_slides_lossy_net", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| screenshare.pipe.loss_percent = 5;
|
| screenshare.pipe.queue_delay_ms = 200;
|
| screenshare.pipe.link_capacity_kbps = 500;
|
| @@ -218,11 +212,12 @@ TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL_LossyNet) {
|
| }
|
|
|
| TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL_VeryLossyNet) {
|
| - VideoQualityTest::Params screenshare = {
|
| - {1850, 1110, 5, 50000, 200000, 2000000, false, "VP8", 2, 1, 400000, true},
|
| - {}, // Video-specific.
|
| - {true, 10}, // Screenshare-specific.
|
| - {"screenshare_slides_very_lossy", 0.0, 0.0, kFullStackTestDurationSecs}};
|
| + VideoQualityTest::Params screenshare;
|
| + screenshare.video = {true, 1850, 1110, 5, 50000, 200000, 2000000, false,
|
| + "VP8", 2, 1, 400000, true, ""};
|
| + screenshare.screenshare = {true, 10};
|
| + screenshare.analyzer = {"screenshare_slides_very_lossy", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| screenshare.pipe.loss_percent = 10;
|
| screenshare.pipe.queue_delay_ms = 200;
|
| screenshare.pipe.link_capacity_kbps = 500;
|
| @@ -231,14 +226,14 @@ TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL_VeryLossyNet) {
|
|
|
| #if !defined(RTC_DISABLE_VP9)
|
| TEST_F(FullStackTest, ScreenshareSlidesVP9_2SL) {
|
| - VideoQualityTest::Params screenshare = {
|
| - {1850, 1110, 5, 50000, 200000, 2000000, false, "VP9", 1, 0, 400000, true},
|
| - {},
|
| - {true, 10},
|
| - {"screenshare_slides_vp9_2sl", 0.0, 0.0, kFullStackTestDurationSecs},
|
| - {},
|
| - false,
|
| - {std::vector<VideoStream>(), 0, 2, 1}};
|
| + VideoQualityTest::Params screenshare;
|
| + screenshare.video = {true, 1850, 1110, 5, 50000, 200000, 2000000, false,
|
| + "VP9", 1, 0, 400000, true, ""};
|
| + screenshare.screenshare = {true, 10};
|
| + screenshare.analyzer = {"screenshare_slides_vp9_2sl", 0.0, 0.0,
|
| + kFullStackTestDurationSecs};
|
| + screenshare.logs = false;
|
| + screenshare.ss = {std::vector<VideoStream>(), 0, 2, 1};
|
| RunTest(screenshare);
|
| }
|
| #endif // !defined(RTC_DISABLE_VP9)
|
|
|