Chromium Code Reviews

Side by Side Diff: webrtc/audio/audio_receive_stream_unittest.cc

Issue 1403363003: Move VoiceEngineObserver into AudioSendStream so that we detect typing noises and return properly i… (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: better comments Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff |
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #include "testing/gtest/include/gtest/gtest.h" 11 #include "testing/gtest/include/gtest/gtest.h"
12 12
13 #include "webrtc/audio/audio_receive_stream.h" 13 #include "webrtc/audio/audio_receive_stream.h"
14 #include "webrtc/audio/audio_state.h"
14 #include "webrtc/audio/conversion.h" 15 #include "webrtc/audio/conversion.h"
16 #include "webrtc/base/scoped_ptr.h"
15 #include "webrtc/modules/remote_bitrate_estimator/include/mock/mock_remote_bitra te_estimator.h" 17 #include "webrtc/modules/remote_bitrate_estimator/include/mock/mock_remote_bitra te_estimator.h"
16 #include "webrtc/modules/rtp_rtcp/source/byte_io.h" 18 #include "webrtc/modules/rtp_rtcp/source/byte_io.h"
17 #include "webrtc/test/fake_voice_engine.h" 19 #include "webrtc/test/fake_voice_engine.h"
18 20
19 namespace { 21 namespace {
20 22
21 using webrtc::ByteWriter; 23 using webrtc::ByteWriter;
22 24
23 const size_t kAbsoluteSendTimeLength = 4; 25 const size_t kAbsoluteSendTimeLength = 4;
24 26
(...skipping 24 matching lines...)
49 ByteWriter<uint16_t>::WriteBigEndian(header + 2, 0x1234); // Sequence number. 51 ByteWriter<uint16_t>::WriteBigEndian(header + 2, 0x1234); // Sequence number.
50 ByteWriter<uint32_t>::WriteBigEndian(header + 4, 0x5678); // Timestamp. 52 ByteWriter<uint32_t>::WriteBigEndian(header + 4, 0x5678); // Timestamp.
51 ByteWriter<uint32_t>::WriteBigEndian(header + 8, 0x4321); // SSRC. 53 ByteWriter<uint32_t>::WriteBigEndian(header + 8, 0x4321); // SSRC.
52 int32_t rtp_header_length = webrtc::kRtpHeaderSize; 54 int32_t rtp_header_length = webrtc::kRtpHeaderSize;
53 55
54 BuildAbsoluteSendTimeExtension(header + rtp_header_length, extension_id, 56 BuildAbsoluteSendTimeExtension(header + rtp_header_length, extension_id,
55 abs_send_time); 57 abs_send_time);
56 rtp_header_length += kAbsoluteSendTimeLength; 58 rtp_header_length += kAbsoluteSendTimeLength;
57 return rtp_header_length; 59 return rtp_header_length;
58 } 60 }
61
62 struct ConfigHelper {
63 ConfigHelper() {
64 webrtc::AudioState::Config config;
65 config.voice_engine = &voice_engine_;
66 audio_state_.reset(new webrtc::internal::AudioState(config));
67 }
68
69 webrtc::MockRemoteBitrateEstimator* remote_bitrate_estimator() {
70 return &remote_bitrate_estimator_;
71 }
72 webrtc::AudioReceiveStream::Config& config() {
73 return stream_config_;
74 }
75 webrtc::internal::AudioState* audio_state() {
76 return audio_state_.get();
77 }
78
79 private:
80 webrtc::MockRemoteBitrateEstimator remote_bitrate_estimator_;
81 webrtc::test::FakeVoiceEngine voice_engine_;
82 rtc::scoped_ptr<webrtc::internal::AudioState> audio_state_;
83 webrtc::AudioReceiveStream::Config stream_config_;
84 };
59 } // namespace 85 } // namespace
60 86
61 namespace webrtc { 87 namespace webrtc {
62 namespace test { 88 namespace test {
63 89
64 TEST(AudioReceiveStreamTest, ConfigToString) { 90 TEST(AudioReceiveStreamTest, ConfigToString) {
65 const int kAbsSendTimeId = 3; 91 const int kAbsSendTimeId = 3;
66 AudioReceiveStream::Config config; 92 AudioReceiveStream::Config config;
67 config.rtp.remote_ssrc = 1234; 93 config.rtp.remote_ssrc = 1234;
68 config.rtp.local_ssrc = 5678; 94 config.rtp.local_ssrc = 5678;
69 config.rtp.extensions.push_back( 95 config.rtp.extensions.push_back(
70 RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeId)); 96 RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeId));
71 config.voe_channel_id = 1; 97 config.voe_channel_id = 1;
72 config.combined_audio_video_bwe = true; 98 config.combined_audio_video_bwe = true;
73 EXPECT_EQ("{rtp: {remote_ssrc: 1234, local_ssrc: 5678, extensions: [{name: " 99 EXPECT_EQ("{rtp: {remote_ssrc: 1234, local_ssrc: 5678, extensions: [{name: "
74 "http://www.webrtc.org/experiments/rtp-hdrext/abs-send-time, id: 3}]}, " 100 "http://www.webrtc.org/experiments/rtp-hdrext/abs-send-time, id: 3}]}, "
75 "receive_transport: nullptr, rtcp_send_transport: nullptr, " 101 "receive_transport: nullptr, rtcp_send_transport: nullptr, "
76 "voe_channel_id: 1, combined_audio_video_bwe: true}", config.ToString()); 102 "voe_channel_id: 1, combined_audio_video_bwe: true}", config.ToString());
77 } 103 }
78 104
79 TEST(AudioReceiveStreamTest, ConstructDestruct) { 105 TEST(AudioReceiveStreamTest, ConstructDestruct) {
80 MockRemoteBitrateEstimator remote_bitrate_estimator; 106 ConfigHelper helper;
81 FakeVoiceEngine voice_engine; 107 helper.config().voe_channel_id = 1;
82 AudioReceiveStream::Config config; 108 internal::AudioReceiveStream recv_stream(
83 config.voe_channel_id = 1; 109 helper.remote_bitrate_estimator(), helper.config(), helper.audio_state());
84 internal::AudioReceiveStream recv_stream(&remote_bitrate_estimator, config,
85 &voice_engine);
86 } 110 }
87 111
88 TEST(AudioReceiveStreamTest, AudioPacketUpdatesBweWithTimestamp) { 112 TEST(AudioReceiveStreamTest, AudioPacketUpdatesBweWithTimestamp) {
89 MockRemoteBitrateEstimator remote_bitrate_estimator; 113 ConfigHelper helper;
90 FakeVoiceEngine voice_engine; 114 helper.config().combined_audio_video_bwe = true;
91 AudioReceiveStream::Config config; 115 helper.config().voe_channel_id = FakeVoiceEngine::kRecvChannelId;
92 config.combined_audio_video_bwe = true;
93 config.voe_channel_id = FakeVoiceEngine::kRecvChannelId;
94 const int kAbsSendTimeId = 3; 116 const int kAbsSendTimeId = 3;
95 config.rtp.extensions.push_back( 117 helper.config().rtp.extensions.push_back(
96 RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeId)); 118 RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeId));
97 internal::AudioReceiveStream recv_stream(&remote_bitrate_estimator, config, 119 internal::AudioReceiveStream recv_stream(
98 &voice_engine); 120 helper.remote_bitrate_estimator(), helper.config(), helper.audio_state());
99 uint8_t rtp_packet[30]; 121 uint8_t rtp_packet[30];
100 const int kAbsSendTimeValue = 1234; 122 const int kAbsSendTimeValue = 1234;
101 CreateRtpHeaderWithAbsSendTime(rtp_packet, kAbsSendTimeId, kAbsSendTimeValue); 123 CreateRtpHeaderWithAbsSendTime(rtp_packet, kAbsSendTimeId, kAbsSendTimeValue);
102 PacketTime packet_time(5678000, 0); 124 PacketTime packet_time(5678000, 0);
103 const size_t kExpectedHeaderLength = 20; 125 const size_t kExpectedHeaderLength = 20;
104 EXPECT_CALL(remote_bitrate_estimator, 126 EXPECT_CALL(*helper.remote_bitrate_estimator(),
105 IncomingPacket(packet_time.timestamp / 1000, 127 IncomingPacket(packet_time.timestamp / 1000,
106 sizeof(rtp_packet) - kExpectedHeaderLength, testing::_, false)) 128 sizeof(rtp_packet) - kExpectedHeaderLength, testing::_, false))
107 .Times(1); 129 .Times(1);
108 EXPECT_TRUE( 130 EXPECT_TRUE(
109 recv_stream.DeliverRtp(rtp_packet, sizeof(rtp_packet), packet_time)); 131 recv_stream.DeliverRtp(rtp_packet, sizeof(rtp_packet), packet_time));
110 } 132 }
111 133
112 TEST(AudioReceiveStreamTest, GetStats) { 134 TEST(AudioReceiveStreamTest, GetStats) {
113 MockRemoteBitrateEstimator remote_bitrate_estimator; 135 ConfigHelper helper;
114 FakeVoiceEngine voice_engine; 136 helper.config().rtp.remote_ssrc = FakeVoiceEngine::kRecvSsrc;
115 AudioReceiveStream::Config config; 137 helper.config().voe_channel_id = FakeVoiceEngine::kRecvChannelId;
116 config.rtp.remote_ssrc = FakeVoiceEngine::kRecvSsrc; 138 internal::AudioReceiveStream recv_stream(
117 config.voe_channel_id = FakeVoiceEngine::kRecvChannelId; 139 helper.remote_bitrate_estimator(), helper.config(), helper.audio_state());
118 internal::AudioReceiveStream recv_stream(&remote_bitrate_estimator, config,
119 &voice_engine);
120 140
121 AudioReceiveStream::Stats stats = recv_stream.GetStats(); 141 AudioReceiveStream::Stats stats = recv_stream.GetStats();
122 const CallStatistics& call_stats = FakeVoiceEngine::kRecvCallStats; 142 const CallStatistics& call_stats = FakeVoiceEngine::kRecvCallStats;
123 const CodecInst& codec_inst = FakeVoiceEngine::kRecvCodecInst; 143 const CodecInst& codec_inst = FakeVoiceEngine::kRecvCodecInst;
124 const NetworkStatistics& net_stats = FakeVoiceEngine::kRecvNetworkStats; 144 const NetworkStatistics& net_stats = FakeVoiceEngine::kRecvNetworkStats;
125 const AudioDecodingCallStats& decode_stats = 145 const AudioDecodingCallStats& decode_stats =
126 FakeVoiceEngine::kRecvAudioDecodingCallStats; 146 FakeVoiceEngine::kRecvAudioDecodingCallStats;
127 EXPECT_EQ(FakeVoiceEngine::kRecvSsrc, stats.remote_ssrc); 147 EXPECT_EQ(FakeVoiceEngine::kRecvSsrc, stats.remote_ssrc);
128 EXPECT_EQ(static_cast<int64_t>(call_stats.bytesReceived), stats.bytes_rcvd); 148 EXPECT_EQ(static_cast<int64_t>(call_stats.bytesReceived), stats.bytes_rcvd);
129 EXPECT_EQ(static_cast<uint32_t>(call_stats.packetsReceived), 149 EXPECT_EQ(static_cast<uint32_t>(call_stats.packetsReceived),
(...skipping 23 matching lines...)
153 EXPECT_EQ(decode_stats.calls_to_neteq, stats.decoding_calls_to_neteq); 173 EXPECT_EQ(decode_stats.calls_to_neteq, stats.decoding_calls_to_neteq);
154 EXPECT_EQ(decode_stats.decoded_normal, stats.decoding_normal); 174 EXPECT_EQ(decode_stats.decoded_normal, stats.decoding_normal);
155 EXPECT_EQ(decode_stats.decoded_plc, stats.decoding_plc); 175 EXPECT_EQ(decode_stats.decoded_plc, stats.decoding_plc);
156 EXPECT_EQ(decode_stats.decoded_cng, stats.decoding_cng); 176 EXPECT_EQ(decode_stats.decoded_cng, stats.decoding_cng);
157 EXPECT_EQ(decode_stats.decoded_plc_cng, stats.decoding_plc_cng); 177 EXPECT_EQ(decode_stats.decoded_plc_cng, stats.decoding_plc_cng);
158 EXPECT_EQ(call_stats.capture_start_ntp_time_ms_, 178 EXPECT_EQ(call_stats.capture_start_ntp_time_ms_,
159 stats.capture_start_ntp_time_ms); 179 stats.capture_start_ntp_time_ms);
160 } 180 }
161 } // namespace test 181 } // namespace test
162 } // namespace webrtc 182 } // namespace webrtc
OLDNEW

Powered by Google App Engine