| Index: webrtc/video/full_stack.cc
|
| diff --git a/webrtc/video/full_stack.cc b/webrtc/video/full_stack.cc
|
| index 1d9eaf867da9d51334f26b6a0441230008ee19b9..c7d1bec1c07156540b5ad6b74cbe5e7163a51dc7 100644
|
| --- a/webrtc/video/full_stack.cc
|
| +++ b/webrtc/video/full_stack.cc
|
| @@ -24,20 +24,22 @@
|
|
|
| void ForemanCifWithoutPacketLoss(const std::string& video_codec) {
|
| // TODO(pbos): Decide on psnr/ssim thresholds for foreman_cif.
|
| - 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};
|
| + 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}};
|
| RunTest(foreman_cif);
|
| }
|
|
|
| void ForemanCifPlr5(const std::string& video_codec) {
|
| - 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};
|
| + 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}};
|
| foreman_cif.pipe.loss_percent = 5;
|
| foreman_cif.pipe.queue_delay_ms = 50;
|
| RunTest(foreman_cif);
|
| @@ -65,41 +67,42 @@
|
| #endif // !defined(RTC_DISABLE_VP9)
|
|
|
| TEST_F(FullStackTest, ParisQcifWithoutPacketLoss) {
|
| - 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};
|
| + 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}};
|
| RunTest(paris_qcif);
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCifWithoutPacketLoss) {
|
| // TODO(pbos): Decide on psnr/ssim thresholds for foreman_cif.
|
| - 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};
|
| + 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}};
|
| RunTest(foreman_cif);
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCifPlr5) {
|
| - 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};
|
| + 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}};
|
| foreman_cif.pipe.loss_percent = 5;
|
| foreman_cif.pipe.queue_delay_ms = 50;
|
| RunTest(foreman_cif);
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbps) {
|
| - 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};
|
| + 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}};
|
| foreman_cif.pipe.queue_length_packets = 0;
|
| foreman_cif.pipe.queue_delay_ms = 0;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -107,11 +110,12 @@
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbpsLimitedQueue) {
|
| - 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};
|
| + 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}};
|
| foreman_cif.pipe.queue_length_packets = 32;
|
| foreman_cif.pipe.queue_delay_ms = 0;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -119,11 +123,11 @@
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbps100ms) {
|
| - 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};
|
| + 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}};
|
| foreman_cif.pipe.queue_length_packets = 0;
|
| foreman_cif.pipe.queue_delay_ms = 100;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -131,11 +135,12 @@
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbps100msLimitedQueue) {
|
| - 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};
|
| + 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}};
|
| foreman_cif.pipe.queue_length_packets = 32;
|
| foreman_cif.pipe.queue_delay_ms = 100;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -143,11 +148,12 @@
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif500kbps100msLimitedQueueRecvBwe) {
|
| - 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};
|
| + 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}};
|
| foreman_cif.pipe.queue_length_packets = 32;
|
| foreman_cif.pipe.queue_delay_ms = 100;
|
| foreman_cif.pipe.link_capacity_kbps = 500;
|
| @@ -155,11 +161,12 @@
|
| }
|
|
|
| TEST_F(FullStackTest, ForemanCif1000kbps100msLimitedQueue) {
|
| - 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};
|
| + 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}};
|
| foreman_cif.pipe.queue_length_packets = 32;
|
| foreman_cif.pipe.queue_delay_ms = 100;
|
| foreman_cif.pipe.link_capacity_kbps = 1000;
|
| @@ -167,12 +174,12 @@
|
| }
|
|
|
| TEST_F(FullStackTest, ConferenceMotionHd2000kbps100msLimitedQueue) {
|
| - 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};
|
| + 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}};
|
| conf_motion_hd.pipe.queue_length_packets = 32;
|
| conf_motion_hd.pipe.queue_delay_ms = 100;
|
| conf_motion_hd.pipe.link_capacity_kbps = 2000;
|
| @@ -180,32 +187,30 @@
|
| }
|
|
|
| TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL) {
|
| - 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};
|
| + VideoQualityTest::Params screenshare = {
|
| + {1850, 1110, 5, 50000, 200000, 2000000, false, "VP8", 2, 1, 400000, true},
|
| + {},
|
| + {true, 10},
|
| + {"screenshare_slides", 0.0, 0.0, kFullStackTestDurationSecs}};
|
| RunTest(screenshare);
|
| }
|
|
|
| TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL_Scroll) {
|
| - 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};
|
| + 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}};
|
| RunTest(config);
|
| }
|
|
|
| TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL_LossyNet) {
|
| - 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};
|
| + 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}};
|
| screenshare.pipe.loss_percent = 5;
|
| screenshare.pipe.queue_delay_ms = 200;
|
| screenshare.pipe.link_capacity_kbps = 500;
|
| @@ -213,12 +218,11 @@
|
| }
|
|
|
| TEST_F(FullStackTest, ScreenshareSlidesVP8_2TL_VeryLossyNet) {
|
| - 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};
|
| + 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}};
|
| screenshare.pipe.loss_percent = 10;
|
| screenshare.pipe.queue_delay_ms = 200;
|
| screenshare.pipe.link_capacity_kbps = 500;
|
| @@ -227,14 +231,14 @@
|
|
|
| #if !defined(RTC_DISABLE_VP9)
|
| TEST_F(FullStackTest, ScreenshareSlidesVP9_2SL) {
|
| - 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};
|
| + 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}};
|
| RunTest(screenshare);
|
| }
|
| #endif // !defined(RTC_DISABLE_VP9)
|
|
|