blob: c81709f0ef44c4b4fe5b5149c4f9670d27c7dd2b [file] [log] [blame]
Sebastian Jansson98b07e92018-09-27 13:47:01 +02001/*
2 * Copyright 2018 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
Jonas Olssona4d87372019-07-05 19:08:33 +020010#include "test/scenario/scenario.h"
11
Sebastian Jansson105a10a2019-04-01 09:18:14 +020012#include <atomic>
Sebastian Jansson98b07e92018-09-27 13:47:01 +020013
Sebastian Jansson98b07e92018-09-27 13:47:01 +020014#include "test/gtest.h"
Sebastian Jansson58c71db2019-05-22 16:20:56 +020015#include "test/logging/memory_log_writer.h"
Sebastian Jansson7150d8c2019-04-09 14:18:09 +020016#include "test/scenario/stats_collection.h"
17
Sebastian Jansson98b07e92018-09-27 13:47:01 +020018namespace webrtc {
19namespace test {
20TEST(ScenarioTest, StartsAndStopsWithoutErrors) {
Sebastian Jansson105a10a2019-04-01 09:18:14 +020021 std::atomic<bool> packet_received(false);
22 std::atomic<bool> bitrate_changed(false);
Sebastian Jansson98b07e92018-09-27 13:47:01 +020023 Scenario s;
24 CallClientConfig call_client_config;
25 call_client_config.transport.rates.start_rate = DataRate::kbps(300);
26 auto* alice = s.CreateClient("alice", call_client_config);
27 auto* bob = s.CreateClient("bob", call_client_config);
Sebastian Janssonef86d142019-04-15 14:42:42 +020028 NetworkSimulationConfig network_config;
Sebastian Jansson98b07e92018-09-27 13:47:01 +020029 auto alice_net = s.CreateSimulationNode(network_config);
30 auto bob_net = s.CreateSimulationNode(network_config);
Sebastian Jansson800e1212018-10-22 11:49:03 +020031 auto route = s.CreateRoutes(alice, {alice_net}, bob, {bob_net});
Sebastian Jansson98b07e92018-09-27 13:47:01 +020032
33 VideoStreamConfig video_stream_config;
Sebastian Jansson800e1212018-10-22 11:49:03 +020034 s.CreateVideoStream(route->forward(), video_stream_config);
35 s.CreateVideoStream(route->reverse(), video_stream_config);
Sebastian Jansson98b07e92018-09-27 13:47:01 +020036
37 AudioStreamConfig audio_stream_config;
Sebastian Jansson82858412018-10-11 19:48:05 +020038 audio_stream_config.encoder.min_rate = DataRate::kbps(6);
39 audio_stream_config.encoder.max_rate = DataRate::kbps(64);
40 audio_stream_config.encoder.allocate_bitrate = true;
41 audio_stream_config.stream.in_bandwidth_estimation = false;
Sebastian Jansson800e1212018-10-22 11:49:03 +020042 s.CreateAudioStream(route->forward(), audio_stream_config);
43 s.CreateAudioStream(route->reverse(), audio_stream_config);
Sebastian Jansson98b07e92018-09-27 13:47:01 +020044
Sebastian Janssona4c22b92019-04-15 21:10:00 +020045 RandomWalkConfig cross_traffic_config;
46 s.net()->CreateRandomWalkCrossTraffic(
47 s.net()->CreateTrafficRoute({alice_net}), cross_traffic_config);
Sebastian Jansson98b07e92018-09-27 13:47:01 +020048
Sebastian Jansson98b07e92018-09-27 13:47:01 +020049 s.NetworkDelayedAction({alice_net, bob_net}, 100,
50 [&packet_received] { packet_received = true; });
Sebastian Jansson98b07e92018-09-27 13:47:01 +020051 s.Every(TimeDelta::ms(10), [alice, bob, &bitrate_changed] {
52 if (alice->GetStats().send_bandwidth_bps != 300000 &&
53 bob->GetStats().send_bandwidth_bps != 300000)
54 bitrate_changed = true;
55 });
56 s.RunUntil(TimeDelta::seconds(2), TimeDelta::ms(5),
57 [&bitrate_changed, &packet_received] {
58 return packet_received && bitrate_changed;
59 });
60 EXPECT_TRUE(packet_received);
61 EXPECT_TRUE(bitrate_changed);
62}
Sebastian Janssoncf2df2f2019-04-02 11:51:28 +020063namespace {
64void SetupVideoCall(Scenario& s, VideoQualityAnalyzer* analyzer) {
65 CallClientConfig call_config;
66 auto* alice = s.CreateClient("alice", call_config);
67 auto* bob = s.CreateClient("bob", call_config);
Sebastian Janssonef86d142019-04-15 14:42:42 +020068 NetworkSimulationConfig network_config;
69 network_config.bandwidth = DataRate::kbps(1000);
70 network_config.delay = TimeDelta::ms(50);
Sebastian Janssoncf2df2f2019-04-02 11:51:28 +020071 auto alice_net = s.CreateSimulationNode(network_config);
72 auto bob_net = s.CreateSimulationNode(network_config);
73 auto route = s.CreateRoutes(alice, {alice_net}, bob, {bob_net});
74 VideoStreamConfig video;
75 if (analyzer) {
76 video.source.capture = VideoStreamConfig::Source::Capture::kVideoFile;
77 video.source.video_file.name = "foreman_cif";
78 video.source.video_file.width = 352;
79 video.source.video_file.height = 288;
80 video.source.framerate = 30;
81 video.encoder.codec = VideoStreamConfig::Encoder::Codec::kVideoCodecVP8;
82 video.encoder.implementation =
83 VideoStreamConfig::Encoder::Implementation::kSoftware;
84 video.hooks.frame_pair_handlers = {analyzer->Handler()};
85 }
86 s.CreateVideoStream(route->forward(), video);
87 s.CreateAudioStream(route->forward(), AudioStreamConfig());
88}
89} // namespace
90
Sebastian Jansson86941182019-04-09 15:15:24 +020091// TODO(bugs.webrtc.org/10515): Remove this when performance has been improved.
92#if defined(WEBRTC_IOS) && defined(WEBRTC_ARCH_ARM64) && !defined(NDEBUG)
93#define MAYBE_SimTimeEncoding DISABLED_SimTimeEncoding
94#else
95#define MAYBE_SimTimeEncoding SimTimeEncoding
96#endif
Sebastian Jansson7237c152019-04-08 16:47:49 +020097TEST(ScenarioTest, MAYBE_SimTimeEncoding) {
Sebastian Janssoncf2df2f2019-04-02 11:51:28 +020098 VideoQualityAnalyzerConfig analyzer_config;
99 analyzer_config.psnr_coverage = 0.1;
100 VideoQualityAnalyzer analyzer(analyzer_config);
101 {
102 Scenario s("scenario/encode_sim", false);
103 SetupVideoCall(s, &analyzer);
104 s.RunFor(TimeDelta::seconds(60));
105 }
106 // Regression tests based on previous runs.
Sebastian Janssoncf2df2f2019-04-02 11:51:28 +0200107 EXPECT_EQ(analyzer.stats().lost_count, 0);
Sebastian Janssone9cac4f2019-06-24 17:10:55 +0200108 EXPECT_NEAR(analyzer.stats().psnr_with_freeze.Mean(), 38, 2);
Sebastian Janssoncf2df2f2019-04-02 11:51:28 +0200109}
110
Sebastian Jansson86941182019-04-09 15:15:24 +0200111// TODO(bugs.webrtc.org/10515): Remove this when performance has been improved.
Sebastian Jansson7237c152019-04-08 16:47:49 +0200112#if defined(WEBRTC_IOS) && defined(WEBRTC_ARCH_ARM64) && !defined(NDEBUG)
113#define MAYBE_RealTimeEncoding DISABLED_RealTimeEncoding
114#else
115#define MAYBE_RealTimeEncoding RealTimeEncoding
116#endif
117TEST(ScenarioTest, MAYBE_RealTimeEncoding) {
Sebastian Janssoncf2df2f2019-04-02 11:51:28 +0200118 VideoQualityAnalyzerConfig analyzer_config;
119 analyzer_config.psnr_coverage = 0.1;
120 VideoQualityAnalyzer analyzer(analyzer_config);
121 {
122 Scenario s("scenario/encode_real", true);
123 SetupVideoCall(s, &analyzer);
124 s.RunFor(TimeDelta::seconds(10));
125 }
126 // Regression tests based on previous runs.
Sebastian Janssoncf2df2f2019-04-02 11:51:28 +0200127 EXPECT_LT(analyzer.stats().lost_count, 2);
Sebastian Janssone9cac4f2019-06-24 17:10:55 +0200128 EXPECT_NEAR(analyzer.stats().psnr_with_freeze.Mean(), 38, 10);
Sebastian Janssoncf2df2f2019-04-02 11:51:28 +0200129}
130
131TEST(ScenarioTest, SimTimeFakeing) {
132 Scenario s("scenario/encode_sim", false);
133 SetupVideoCall(s, nullptr);
134 s.RunFor(TimeDelta::seconds(10));
135}
136
Sebastian Jansson58c71db2019-05-22 16:20:56 +0200137TEST(ScenarioTest, WritesToRtcEventLog) {
138 MemoryLogStorage storage;
139 {
140 Scenario s(storage.CreateFactory(), false);
141 SetupVideoCall(s, nullptr);
142 s.RunFor(TimeDelta::seconds(1));
143 }
144 auto logs = storage.logs();
145 // We expect that a rtc event log has been created and that it has some data.
146 EXPECT_GE(storage.logs().at("alice.rtc.dat").size(), 1u);
147}
148
Sebastian Jansson98b07e92018-09-27 13:47:01 +0200149} // namespace test
150} // namespace webrtc