Reland of "Separating video settings in VideoQualityTest".

This was landed in https://codereview.webrtc.org/2314403007/

and reverted in https://codereview.webrtc.org/2463733002/ because an error was found.

BUG=660473, webrtc:6609

Review-Url: https://codereview.webrtc.org/2466473002
Cr-Commit-Position: refs/heads/master@{#14848}
diff --git a/webrtc/video/full_stack.cc b/webrtc/video/full_stack.cc
index c7d1bec..6433f6f 100644
--- a/webrtc/video/full_stack.cc
+++ b/webrtc/video/full_stack.cc
@@ -24,22 +24,20 @@
 
   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,45 @@
 #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.call.send_side_bwe = true;
+  paris_qcif.video = {true, 176, 144, 30, 300000, 300000, 300000, false,
+                      "VP8", 1, 0, 0, false, "", "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.call.send_side_bwe = true;
+  foreman_cif.video = {true, 352, 288, 30, 700000, 700000, 700000, false, "VP8",
+                       1, 0, 0, false, "", "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.call.send_side_bwe = true;
+  foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
+                       1, 0, 0, false, "", "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.call.send_side_bwe = true;
+  foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
+                       1, 0, 0, false, "", "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 +111,12 @@
 }
 
 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.call.send_side_bwe = true;
+  foreman_cif.video = {true, 352, 288, 30, 30000, 500000, 2000000, false, "VP8",
+                       1, 0, 0, false, "", "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 +124,12 @@
 }
 
 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.call.send_side_bwe = true;
+  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", 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 +137,12 @@
 }
 
 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.call.send_side_bwe = true;
+  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;
@@ -148,12 +150,11 @@
 }
 
 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 +162,12 @@
 }
 
 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.call.send_side_bwe = true;
+  foreman_cif.video = {true, 352, 288, 30, 30000, 2000000, 2000000, false,
+                       "VP8", 1, 0, 0, false, "", "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 +175,13 @@
 }
 
 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.call.send_side_bwe = true;
+  conf_motion_hd.video = {true, 1280, 720, 50, 30000, 3000000, 3000000, false,
+                          "VP8", 1, 0, 0, false, "",
+                          "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 +189,35 @@
 }
 
 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.call.send_side_bwe = true;
+  screenshare.video = {true, 1850, 1110, 5, 50000, 200000, 2000000, false,
+                       "VP8", 2, 1, 400000, false, "", ""};
+  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.call.send_side_bwe = true;
+  config.video = {true, 1850, 1110 / 2, 5, 50000,  200000, 2000000, false,
+                  "VP8", 2, 1, 400000, false, "", ""};
+  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.call.send_side_bwe = true;
+  screenshare.video = {true, 1850,  1110, 5, 50000, 200000, 2000000, false,
+                       "VP8", 2, 1, 400000, false, "", ""};
+  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 +225,13 @@
 }
 
 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.call.send_side_bwe = true;
+  screenshare.video = {true, 1850, 1110, 5, 50000, 200000, 2000000, false,
+                       "VP8", 2, 1, 400000, false, "", ""};
+  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 +240,15 @@
 
 #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.call.send_side_bwe = true;
+  screenshare.video = {true, 1850, 1110, 5, 50000, 200000, 2000000, false,
+                       "VP9", 1, 0, 400000, false, "", ""};
+  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)