Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(24)

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

Issue 1414743004: Implement AudioSendStream::GetStats(). (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: TODOs Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
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
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
54 BuildAbsoluteSendTimeExtension(header + rtp_header_length, extension_id, 54 BuildAbsoluteSendTimeExtension(header + rtp_header_length, extension_id,
55 abs_send_time); 55 abs_send_time);
56 rtp_header_length += kAbsoluteSendTimeLength; 56 rtp_header_length += kAbsoluteSendTimeLength;
57 return rtp_header_length; 57 return rtp_header_length;
58 } 58 }
59 } // namespace 59 } // namespace
60 60
61 namespace webrtc { 61 namespace webrtc {
62 namespace test { 62 namespace test {
63 63
64 TEST(AudioReceiveStreamTest, ConfigToString) {
65 const int kAbsSendTimeId = 3;
66 AudioReceiveStream::Config config;
67 config.rtp.remote_ssrc = 1234;
68 config.rtp.local_ssrc = 5678;
69 config.rtp.extensions.push_back(
70 RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeId));
71 config.voe_channel_id = 1;
72 config.combined_audio_video_bwe = true;
73 EXPECT_GT(config.ToString().size(), 0u);
74 }
75
76 TEST(AudioReceiveStreamTest, ConstructDestruct) {
77 MockRemoteBitrateEstimator remote_bitrate_estimator;
78 FakeVoiceEngine voice_engine;
79 AudioReceiveStream::Config config;
80 config.voe_channel_id = 1;
81 internal::AudioReceiveStream recv_stream(&remote_bitrate_estimator, config,
82 &voice_engine);
83 }
84
64 TEST(AudioReceiveStreamTest, AudioPacketUpdatesBweWithTimestamp) { 85 TEST(AudioReceiveStreamTest, AudioPacketUpdatesBweWithTimestamp) {
65 MockRemoteBitrateEstimator remote_bitrate_estimator; 86 MockRemoteBitrateEstimator remote_bitrate_estimator;
66 FakeVoiceEngine voice_engine; 87 FakeVoiceEngine voice_engine;
67 AudioReceiveStream::Config config; 88 AudioReceiveStream::Config config;
68 config.combined_audio_video_bwe = true; 89 config.combined_audio_video_bwe = true;
69 config.voe_channel_id = voice_engine.kReceiveChannelId; 90 config.voe_channel_id = voice_engine.kRecvChannelId;
tommi 2015/10/23 12:50:37 it looks a bit strange to me to have a constant re
the sun 2015/10/23 15:14:17 Done.
70 const int kAbsSendTimeId = 3; 91 const int kAbsSendTimeId = 3;
71 config.rtp.extensions.push_back( 92 config.rtp.extensions.push_back(
72 RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeId)); 93 RtpExtension(RtpExtension::kAbsSendTime, kAbsSendTimeId));
73 internal::AudioReceiveStream recv_stream(&remote_bitrate_estimator, config, 94 internal::AudioReceiveStream recv_stream(&remote_bitrate_estimator, config,
74 &voice_engine); 95 &voice_engine);
75 uint8_t rtp_packet[30]; 96 uint8_t rtp_packet[30];
76 const int kAbsSendTimeValue = 1234; 97 const int kAbsSendTimeValue = 1234;
77 CreateRtpHeaderWithAbsSendTime(rtp_packet, kAbsSendTimeId, kAbsSendTimeValue); 98 CreateRtpHeaderWithAbsSendTime(rtp_packet, kAbsSendTimeId, kAbsSendTimeValue);
78 PacketTime packet_time(5678000, 0); 99 PacketTime packet_time(5678000, 0);
79 const size_t kExpectedHeaderLength = 20; 100 const size_t kExpectedHeaderLength = 20;
80 EXPECT_CALL(remote_bitrate_estimator, 101 EXPECT_CALL(remote_bitrate_estimator,
81 IncomingPacket(packet_time.timestamp / 1000, 102 IncomingPacket(packet_time.timestamp / 1000,
82 sizeof(rtp_packet) - kExpectedHeaderLength, testing::_, false)) 103 sizeof(rtp_packet) - kExpectedHeaderLength, testing::_, false))
83 .Times(1); 104 .Times(1);
84 EXPECT_TRUE( 105 EXPECT_TRUE(
85 recv_stream.DeliverRtp(rtp_packet, sizeof(rtp_packet), packet_time)); 106 recv_stream.DeliverRtp(rtp_packet, sizeof(rtp_packet), packet_time));
86 } 107 }
87 108
88 TEST(AudioReceiveStreamTest, GetStats) { 109 TEST(AudioReceiveStreamTest, GetStats) {
89 const uint32_t kSsrc1 = 667;
90
91 MockRemoteBitrateEstimator remote_bitrate_estimator; 110 MockRemoteBitrateEstimator remote_bitrate_estimator;
92 FakeVoiceEngine voice_engine; 111 FakeVoiceEngine voice_engine;
93 AudioReceiveStream::Config config; 112 AudioReceiveStream::Config config;
94 config.rtp.remote_ssrc = kSsrc1; 113 config.rtp.remote_ssrc = voice_engine.kRecvSsrc;
tommi 2015/10/23 12:50:37 same here
the sun 2015/10/23 15:14:17 Done.
95 config.voe_channel_id = voice_engine.kReceiveChannelId; 114 config.voe_channel_id = voice_engine.kRecvChannelId;
96 internal::AudioReceiveStream recv_stream(&remote_bitrate_estimator, config, 115 internal::AudioReceiveStream recv_stream(&remote_bitrate_estimator, config,
97 &voice_engine); 116 &voice_engine);
98 117
99 AudioReceiveStream::Stats stats = recv_stream.GetStats(); 118 AudioReceiveStream::Stats stats = recv_stream.GetStats();
100 const CallStatistics& call_stats = voice_engine.GetRecvCallStats(); 119 const CallStatistics& call_stats = voice_engine.GetRecvCallStats();
101 const CodecInst& codec_inst = voice_engine.GetRecvRecCodecInst(); 120 const CodecInst& codec_inst = voice_engine.GetRecvCodecInst();
102 const NetworkStatistics& net_stats = voice_engine.GetRecvNetworkStats(); 121 const NetworkStatistics& net_stats = voice_engine.GetRecvNetworkStats();
103 const AudioDecodingCallStats& decode_stats = 122 const AudioDecodingCallStats& decode_stats =
104 voice_engine.GetRecvAudioDecodingCallStats(); 123 voice_engine.GetRecvAudioDecodingCallStats();
105 EXPECT_EQ(kSsrc1, stats.remote_ssrc); 124 EXPECT_EQ(voice_engine.kRecvSsrc, stats.remote_ssrc);
106 EXPECT_EQ(static_cast<int64_t>(call_stats.bytesReceived), stats.bytes_rcvd); 125 EXPECT_EQ(static_cast<int64_t>(call_stats.bytesReceived), stats.bytes_rcvd);
107 EXPECT_EQ(static_cast<uint32_t>(call_stats.packetsReceived), 126 EXPECT_EQ(static_cast<uint32_t>(call_stats.packetsReceived),
108 stats.packets_rcvd); 127 stats.packets_rcvd);
109 EXPECT_EQ(call_stats.cumulativeLost, stats.packets_lost); 128 EXPECT_EQ(call_stats.cumulativeLost, stats.packets_lost);
110 EXPECT_EQ(static_cast<float>(call_stats.fractionLost) / 256, 129 EXPECT_EQ(Q8ToFloat(call_stats.fractionLost), stats.fraction_lost);
111 stats.fraction_lost);
112 EXPECT_EQ(std::string(codec_inst.plname), stats.codec_name); 130 EXPECT_EQ(std::string(codec_inst.plname), stats.codec_name);
113 EXPECT_EQ(call_stats.extendedMax, stats.ext_seqnum); 131 EXPECT_EQ(call_stats.extendedMax, stats.ext_seqnum);
114 EXPECT_EQ(call_stats.jitterSamples / (codec_inst.plfreq / 1000), 132 EXPECT_EQ(call_stats.jitterSamples / (codec_inst.plfreq / 1000),
115 stats.jitter_ms); 133 stats.jitter_ms);
116 EXPECT_EQ(net_stats.currentBufferSize, stats.jitter_buffer_ms); 134 EXPECT_EQ(net_stats.currentBufferSize, stats.jitter_buffer_ms);
117 EXPECT_EQ(net_stats.preferredBufferSize, stats.jitter_buffer_preferred_ms); 135 EXPECT_EQ(net_stats.preferredBufferSize, stats.jitter_buffer_preferred_ms);
118 EXPECT_EQ(static_cast<uint32_t>(voice_engine.kRecvJitterBufferDelay + 136 EXPECT_EQ(static_cast<uint32_t>(voice_engine.kRecvJitterBufferDelay +
119 voice_engine.kRecvPlayoutBufferDelay), stats.delay_estimate_ms); 137 voice_engine.kRecvPlayoutBufferDelay), stats.delay_estimate_ms);
120 EXPECT_EQ(static_cast<int32_t>(voice_engine.kRecvSpeechOutputLevel), 138 EXPECT_EQ(static_cast<int32_t>(voice_engine.kRecvSpeechOutputLevel),
121 stats.audio_level); 139 stats.audio_level);
(...skipping 10 matching lines...) Expand all
132 EXPECT_EQ(decode_stats.calls_to_neteq, stats.decoding_calls_to_neteq); 150 EXPECT_EQ(decode_stats.calls_to_neteq, stats.decoding_calls_to_neteq);
133 EXPECT_EQ(decode_stats.decoded_normal, stats.decoding_normal); 151 EXPECT_EQ(decode_stats.decoded_normal, stats.decoding_normal);
134 EXPECT_EQ(decode_stats.decoded_plc, stats.decoding_plc); 152 EXPECT_EQ(decode_stats.decoded_plc, stats.decoding_plc);
135 EXPECT_EQ(decode_stats.decoded_cng, stats.decoding_cng); 153 EXPECT_EQ(decode_stats.decoded_cng, stats.decoding_cng);
136 EXPECT_EQ(decode_stats.decoded_plc_cng, stats.decoding_plc_cng); 154 EXPECT_EQ(decode_stats.decoded_plc_cng, stats.decoding_plc_cng);
137 EXPECT_EQ(call_stats.capture_start_ntp_time_ms_, 155 EXPECT_EQ(call_stats.capture_start_ntp_time_ms_,
138 stats.capture_start_ntp_time_ms); 156 stats.capture_start_ntp_time_ms);
139 } 157 }
140 } // namespace test 158 } // namespace test
141 } // namespace webrtc 159 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698