statscollector_unittest.cc revision 242068d58cc01640aa9f733fa67f078fc65c4ae5
128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org/*
228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * libjingle
34cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org * Copyright 2014, Google Inc.
428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *
528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * Redistribution and use in source and binary forms, with or without
628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * modification, are permitted provided that the following conditions are met:
728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *
828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *  1. Redistributions of source code must retain the above copyright notice,
928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *     this list of conditions and the following disclaimer.
1028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *  2. Redistributions in binary form must reproduce the above copyright notice,
1128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *     this list of conditions and the following disclaimer in the documentation
1228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *     and/or other materials provided with the distribution.
1328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *  3. The name of the author may not be used to endorse or promote products
1428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *     derived from this software without specific prior written permission.
1528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org *
1628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
1728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
1828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
1928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
2028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
2128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
2228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
2328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
2428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
2528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org */
2728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
2828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include <stdio.h>
2928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
3028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include "talk/app/webrtc/statscollector.h"
3128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
3228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include "talk/app/webrtc/mediastream.h"
3340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org#include "talk/app/webrtc/mediastreaminterface.h"
3440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org#include "talk/app/webrtc/mediastreamtrack.h"
3528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include "talk/app/webrtc/videotrack.h"
364551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org#include "talk/base/base64.h"
374551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org#include "talk/base/fakesslidentity.h"
3828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include "talk/base/gunit.h"
3928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include "talk/media/base/fakemediaengine.h"
4028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include "talk/media/devices/fakedevicemanager.h"
4128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include "talk/p2p/base/fakesession.h"
4228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org#include "talk/session/media/channelmanager.h"
434cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org#include "testing/gmock/include/gmock/gmock.h"
444cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org#include "testing/gtest/include/gtest/gtest.h"
4528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
46b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.orgusing cricket::StatsOptions;
4728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgusing testing::_;
4828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgusing testing::DoAll;
49b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.orgusing testing::Field;
5028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgusing testing::Return;
5128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgusing testing::ReturnNull;
5228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgusing testing::SetArgPointee;
53b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.orgusing webrtc::PeerConnectionInterface;
5440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgusing webrtc::StatsReport;
5540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgusing webrtc::StatsReports;
5628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
5728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgnamespace cricket {
5828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
5928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgclass ChannelManager;
6028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgclass FakeDeviceManager;
6128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
6228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}  // namespace cricket
6328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
6428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgnamespace {
6528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
6628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// Error return values
6728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgconst char kNotFound[] = "NOT FOUND";
6828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgconst char kNoReports[] = "NO REPORTS";
6928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
7097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org// Constant names for track identification.
714cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgconst char kLocalTrackId[] = "local_track_id";
724cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgconst char kRemoteTrackId[] = "remote_track_id";
7397077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.orgconst uint32 kSsrcOfTrack = 1234;
7497077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
7528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgclass MockWebRtcSession : public webrtc::WebRtcSession {
7628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org public:
7728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  explicit MockWebRtcSession(cricket::ChannelManager* channel_manager)
7828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    : WebRtcSession(channel_manager, talk_base::Thread::Current(),
794551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                    talk_base::Thread::Current(), NULL, NULL) {
8028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  }
8140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  MOCK_METHOD0(voice_channel, cricket::VoiceChannel*());
8228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  MOCK_METHOD0(video_channel, cricket::VideoChannel*());
834cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Libjingle uses "local" for a outgoing track, and "remote" for a incoming
844cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // track.
854cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MOCK_METHOD2(GetLocalTrackIdBySsrc, bool(uint32, std::string*));
864cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MOCK_METHOD2(GetRemoteTrackIdBySsrc, bool(uint32, std::string*));
8728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  MOCK_METHOD1(GetStats, bool(cricket::SessionStats*));
884551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  MOCK_METHOD1(GetTransport, cricket::Transport*(const std::string&));
8928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org};
9028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
9128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgclass MockVideoMediaChannel : public cricket::FakeVideoMediaChannel {
9228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org public:
9328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  MockVideoMediaChannel()
9428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    : cricket::FakeVideoMediaChannel(NULL) {
9528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  }
9628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // MOCK_METHOD0(transport_channel, cricket::TransportChannel*());
97b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  MOCK_METHOD2(GetStats, bool(const StatsOptions&, cricket::VideoMediaInfo*));
9828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org};
9928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
10040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgclass MockVoiceMediaChannel : public cricket::FakeVoiceMediaChannel {
10140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org public:
10240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  MockVoiceMediaChannel() : cricket::FakeVoiceMediaChannel(NULL) {
10340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  }
10440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  MOCK_METHOD1(GetStats, bool(cricket::VoiceMediaInfo*));
10540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org};
10640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
10740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgclass FakeAudioProcessor : public webrtc::AudioProcessorInterface {
10840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org public:
10940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  FakeAudioProcessor() {}
11040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  ~FakeAudioProcessor() {}
11140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
11240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org private:
11340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  virtual void GetStats(
11440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      AudioProcessorInterface::AudioProcessorStats* stats) OVERRIDE {
11540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    stats->typing_noise_detected = true;
11640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    stats->echo_return_loss = 2;
11740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    stats->echo_return_loss_enhancement = 3;
11840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    stats->echo_delay_median_ms = 4;
11940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    stats->aec_quality_min = 5.1f;
12040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    stats->echo_delay_std_ms = 6;
12140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  }
12240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org};
12340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
1244cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgclass FakeAudioTrack
12540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    : public webrtc::MediaStreamTrack<webrtc::AudioTrackInterface> {
12640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org public:
1274cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  explicit FakeAudioTrack(const std::string& id)
12840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      : webrtc::MediaStreamTrack<webrtc::AudioTrackInterface>(id),
12940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        processor_(new talk_base::RefCountedObject<FakeAudioProcessor>()) {}
13040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  std::string kind() const OVERRIDE {
13140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    return "audio";
13240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  }
13340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  virtual webrtc::AudioSourceInterface* GetSource() const OVERRIDE {
13440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    return NULL;
13540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  }
13640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  virtual void AddSink(webrtc::AudioTrackSinkInterface* sink) OVERRIDE {}
13740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  virtual void RemoveSink(webrtc::AudioTrackSinkInterface* sink) OVERRIDE {}
13840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  virtual bool GetSignalLevel(int* level) OVERRIDE {
13940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    *level = 1;
14040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    return true;
14140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  }
142b90991dade9139e5c14c3b616a9eff07b9d6fddahenrike@webrtc.org  virtual talk_base::scoped_refptr<webrtc::AudioProcessorInterface>
143b90991dade9139e5c14c3b616a9eff07b9d6fddahenrike@webrtc.org      GetAudioProcessor() OVERRIDE {
144b90991dade9139e5c14c3b616a9eff07b9d6fddahenrike@webrtc.org    return processor_;
14540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  }
14640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
14740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org private:
14840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  talk_base::scoped_refptr<FakeAudioProcessor> processor_;
14940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org};
15040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
15140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgbool GetValue(const StatsReport* report,
152242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org              StatsReport::StatsValueName name,
1534551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org              std::string* value) {
15440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReport::Values::const_iterator it = report->values.begin();
1554551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  for (; it != report->values.end(); ++it) {
1564551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    if (it->name == name) {
1574551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      *value = it->value;
1584551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      return true;
1594551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    }
1604551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  }
1614551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  return false;
1624551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org}
1634551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
16428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgstd::string ExtractStatsValue(const std::string& type,
16540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                              const StatsReports& reports,
166242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org                              StatsReport::StatsValueName name) {
16728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  if (reports.empty()) {
16828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    return kNoReports;
16928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  }
17028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  for (size_t i = 0; i < reports.size(); ++i) {
17128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    if (reports[i].type != type)
17228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      continue;
1734551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    std::string ret;
1744551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    if (GetValue(&reports[i], name, &ret)) {
1754551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      return ret;
17628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    }
17728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  }
17828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
17928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  return kNotFound;
18028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
18128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
18228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// Finds the |n|-th report of type |type| in |reports|.
18328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// |n| starts from 1 for finding the first report.
18440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgconst StatsReport* FindNthReportByType(
18540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    const StatsReports& reports, const std::string& type, int n) {
18628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  for (size_t i = 0; i < reports.size(); ++i) {
18728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    if (reports[i].type == type) {
18828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      n--;
18928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      if (n == 0)
19028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org        return &reports[i];
19128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    }
19228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  }
19328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  return NULL;
19428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
19528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
19640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgconst StatsReport* FindReportById(const StatsReports& reports,
19740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                                  const std::string& id) {
19828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  for (size_t i = 0; i < reports.size(); ++i) {
19928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    if (reports[i].id == id) {
20028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      return &reports[i];
20128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    }
20228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  }
20328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  return NULL;
20428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
20528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
20640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgstd::string ExtractSsrcStatsValue(StatsReports reports,
207242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org                                  StatsReport::StatsValueName name) {
20828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  return ExtractStatsValue(
20940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeSsrc, reports, name);
21028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
21128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
21240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgstd::string ExtractBweStatsValue(StatsReports reports,
213242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org                                 StatsReport::StatsValueName name) {
21428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  return ExtractStatsValue(
21540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeBwe, reports, name);
21628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
21728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
2184551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.orgstd::string DerToPem(const std::string& der) {
2194551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  return talk_base::SSLIdentity::DerToPem(
2204551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        talk_base::kPemTypeCertificate,
2214551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        reinterpret_cast<const unsigned char*>(der.c_str()),
2224551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        der.length());
2234551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org}
2244551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
2254551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.orgstd::vector<std::string> DersToPems(
2264551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    const std::vector<std::string>& ders) {
2274551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::vector<std::string> pems(ders.size());
2284551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::transform(ders.begin(), ders.end(), pems.begin(), DerToPem);
2294551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  return pems;
2304551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org}
2314551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
23240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgvoid CheckCertChainReports(const StatsReports& reports,
2334551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                           const std::vector<std::string>& ders,
2344551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                           const std::string& start_id) {
2354551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::string certificate_id = start_id;
2364551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  size_t i = 0;
2374551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  while (true) {
23840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    const StatsReport* report = FindReportById(reports, certificate_id);
2394551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    ASSERT_TRUE(report != NULL);
24019f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org
2414551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    std::string der_base64;
2424551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    EXPECT_TRUE(GetValue(
24340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        report, StatsReport::kStatsValueNameDer, &der_base64));
2444551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    std::string der = talk_base::Base64::Decode(der_base64,
2454551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                                                talk_base::Base64::DO_STRICT);
2464551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    EXPECT_EQ(ders[i], der);
24719f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org
24819f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org    std::string fingerprint_algorithm;
24919f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org    EXPECT_TRUE(GetValue(
25019f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org        report,
25140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        StatsReport::kStatsValueNameFingerprintAlgorithm,
25219f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org        &fingerprint_algorithm));
25319f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org    // The digest algorithm for a FakeSSLCertificate is always SHA-1.
25419f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org    std::string sha_1_str = talk_base::DIGEST_SHA_1;
25519f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org    EXPECT_EQ(sha_1_str, fingerprint_algorithm);
25619f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org
25719f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org    std::string dummy_fingerprint;  // Value is not checked.
25819f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org    EXPECT_TRUE(GetValue(
25919f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org        report,
26040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        StatsReport::kStatsValueNameFingerprint,
26119f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org        &dummy_fingerprint));
26219f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.org
2634551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    ++i;
2644551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    if (!GetValue(
26540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        report, StatsReport::kStatsValueNameIssuerId, &certificate_id))
2664551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      break;
2674551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  }
2684551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  EXPECT_EQ(ders.size(), i);
2694551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org}
2704551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
2714cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgvoid VerifyVoiceReceiverInfoReport(
2724cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    const StatsReport* report,
2734cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    const cricket::VoiceReceiverInfo& info) {
2743e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  std::string value_in_report;
2753e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
2763e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameAudioOutputLevel, &value_in_report));
2774cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.audio_level), value_in_report);
2783e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
2793e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameBytesReceived, &value_in_report));
2804cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int64>(info.bytes_rcvd), value_in_report);
2813e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
2823e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameJitterReceived, &value_in_report));
2834cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.jitter_ms), value_in_report);
2843e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
2853e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameJitterBufferMs, &value_in_report));
2864cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.jitter_buffer_ms), value_in_report);
2873e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
2883e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNamePreferredJitterBufferMs,
2893e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      &value_in_report));
2904cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.jitter_buffer_preferred_ms),
2913e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      value_in_report);
2923e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
2933e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameCurrentDelayMs, &value_in_report));
2944cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.delay_estimate_ms), value_in_report);
2953e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
2963e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameExpandRate, &value_in_report));
2974cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<float>(info.expand_rate), value_in_report);
2983e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
2993e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNamePacketsReceived, &value_in_report));
3004cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.packets_rcvd), value_in_report);
3013e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
3023e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameDecodingCTSG, &value_in_report));
3034cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.decoding_calls_to_silence_generator),
3043e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      value_in_report);
3053e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
3063e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameDecodingCTN, &value_in_report));
3074cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.decoding_calls_to_neteq),
3083e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      value_in_report);
3093e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
3103e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameDecodingNormal, &value_in_report));
3114cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.decoding_normal), value_in_report);
3123e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
3133e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameDecodingPLC, &value_in_report));
3144cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.decoding_plc), value_in_report);
3153e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
3163e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameDecodingCNG, &value_in_report));
3174cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.decoding_cng), value_in_report);
3183e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  EXPECT_TRUE(GetValue(
3193e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      report, StatsReport::kStatsValueNameDecodingPLCCNG, &value_in_report));
3204cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(info.decoding_plc_cng), value_in_report);
3217e71b77f8aab5b7a6f2b669c16f90ec9a4b4609cbuildbot@webrtc.org  EXPECT_TRUE(GetValue(
3227e71b77f8aab5b7a6f2b669c16f90ec9a4b4609cbuildbot@webrtc.org      report, StatsReport::kStatsValueNameCodecName, &value_in_report));
3233e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org}
3243e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org
3253e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org
32640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgvoid VerifyVoiceSenderInfoReport(const StatsReport* report,
32740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                                 const cricket::VoiceSenderInfo& sinfo) {
32840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  std::string value_in_report;
32940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
33040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameCodecName, &value_in_report));
33140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(sinfo.codec_name, value_in_report);
33240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
33340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameBytesSent, &value_in_report));
33440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int64>(sinfo.bytes_sent), value_in_report);
33540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
33640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNamePacketsSent, &value_in_report));
33740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.packets_sent), value_in_report);
33840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
339ffe2620c97c2b7bfe42b04453b5a981dbf1e5f06henrike@webrtc.org      report, StatsReport::kStatsValueNamePacketsLost, &value_in_report));
340ffe2620c97c2b7bfe42b04453b5a981dbf1e5f06henrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.packets_lost), value_in_report);
341ffe2620c97c2b7bfe42b04453b5a981dbf1e5f06henrike@webrtc.org  EXPECT_TRUE(GetValue(
34240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameRtt, &value_in_report));
34340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.rtt_ms), value_in_report);
34440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
34540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameRtt, &value_in_report));
34640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.rtt_ms), value_in_report);
34740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
34840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameJitterReceived, &value_in_report));
34940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.jitter_ms), value_in_report);
35040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
35140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameEchoCancellationQualityMin,
35240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      &value_in_report));
35340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<float>(sinfo.aec_quality_min), value_in_report);
35440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
35540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameEchoDelayMedian, &value_in_report));
35640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.echo_delay_median_ms),
35740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org            value_in_report);
35840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
35940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameEchoDelayStdDev, &value_in_report));
36040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.echo_delay_std_ms),
36140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org            value_in_report);
36240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
36340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameEchoReturnLoss, &value_in_report));
36440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.echo_return_loss),
36540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org            value_in_report);
36640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
36740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameEchoReturnLossEnhancement,
36840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      &value_in_report));
36940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.echo_return_loss_enhancement),
37040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org            value_in_report);
37140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
37240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameAudioInputLevel, &value_in_report));
37340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<int>(sinfo.audio_level), value_in_report);
37440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_TRUE(GetValue(
37540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      report, StatsReport::kStatsValueNameTypingNoiseState, &value_in_report));
37640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  std::string typing_detected = sinfo.typing_noise_detected ? "true" : "false";
37740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(typing_detected, value_in_report);
37840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org}
37940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
3804cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org// Helper methods to avoid duplication of code.
3814cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgvoid InitVoiceSenderInfo(cricket::VoiceSenderInfo* voice_sender_info) {
3824cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->add_ssrc(kSsrcOfTrack);
3834cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->codec_name = "fake_codec";
3844cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->bytes_sent = 100;
3854cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->packets_sent = 101;
3864cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->rtt_ms = 102;
3874cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->fraction_lost = 103;
3884cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->jitter_ms = 104;
3894cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->packets_lost = 105;
3904cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->ext_seqnum = 106;
3914cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->audio_level = 107;
3924cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->echo_return_loss = 108;
3934cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->echo_return_loss_enhancement = 109;
3944cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->echo_delay_median_ms = 110;
3954cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->echo_delay_std_ms = 111;
3964cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->aec_quality_min = 112.0f;
3974cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->typing_noise_detected = false;
3984cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org}
3994cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
4004cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgvoid UpdateVoiceSenderInfoFromAudioTrack(
4014cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    FakeAudioTrack* audio_track, cricket::VoiceSenderInfo* voice_sender_info) {
4024cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  audio_track->GetSignalLevel(&voice_sender_info->audio_level);
4034cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  webrtc::AudioProcessorInterface::AudioProcessorStats audio_processor_stats;
4044cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  audio_track->GetAudioProcessor()->GetStats(&audio_processor_stats);
4054cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->typing_noise_detected =
4064cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      audio_processor_stats.typing_noise_detected;
4074cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->echo_return_loss = audio_processor_stats.echo_return_loss;
4084cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->echo_return_loss_enhancement =
4094cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      audio_processor_stats.echo_return_loss_enhancement;
4104cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->echo_delay_median_ms =
4114cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      audio_processor_stats.echo_delay_median_ms;
4124cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->aec_quality_min = audio_processor_stats.aec_quality_min;
4134cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_sender_info->echo_delay_std_ms =
4144cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      audio_processor_stats.echo_delay_std_ms;
4154cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org}
4164cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
4174cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgvoid InitVoiceReceiverInfo(cricket::VoiceReceiverInfo* voice_receiver_info) {
4184cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->add_ssrc(kSsrcOfTrack);
4194cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->bytes_rcvd = 110;
4204cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->packets_rcvd = 111;
4214cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->packets_lost = 112;
4224cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->fraction_lost = 113;
4234cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->packets_lost = 114;
4244cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->ext_seqnum = 115;
4254cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->jitter_ms = 116;
4264cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->jitter_buffer_ms = 117;
4274cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->jitter_buffer_preferred_ms = 118;
4284cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->delay_estimate_ms = 119;
4294cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->audio_level = 120;
4304cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  voice_receiver_info->expand_rate = 121;
4314cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org}
4324cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
43328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgclass StatsCollectorTest : public testing::Test {
43428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org protected:
43528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  StatsCollectorTest()
43628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    : media_engine_(new cricket::FakeMediaEngine),
43728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      channel_manager_(
43828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org          new cricket::ChannelManager(media_engine_,
43928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org                                      new cricket::FakeDeviceManager(),
44028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org                                      talk_base::Thread::Current())),
4414cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      session_(channel_manager_.get()) {
44228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    // By default, we ignore session GetStats calls.
44328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org    EXPECT_CALL(session_, GetStats(_)).WillRepeatedly(Return(false));
44428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  }
44528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
44697077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // This creates a standard setup with a transport called "trspname"
44797077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // having one transport channel
44897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // and the specified virtual connection name.
449242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  void InitSessionStats(const std::string& vc_name) {
45097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    const std::string kTransportName("trspname");
45197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    cricket::TransportStats transport_stats;
45297077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    cricket::TransportChannelStats channel_stats;
45397077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    channel_stats.component = 1;
45497077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    transport_stats.content_name = kTransportName;
45597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    transport_stats.channel_stats.push_back(channel_stats);
45697077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
45797077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    session_stats_.transport_stats[kTransportName] = transport_stats;
45897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    session_stats_.proxy_to_transport[vc_name] = kTransportName;
45997077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  }
46097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
4614cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Adds a outgoing video track with a given SSRC into the stats.
4624cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  void AddOutgoingVideoTrackStats() {
46397077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    stream_ = webrtc::MediaStream::Create("streamlabel");
4644cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    track_= webrtc::VideoTrack::Create(kLocalTrackId, NULL);
46597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org    stream_->AddTrack(track_);
4664cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    EXPECT_CALL(session_, GetLocalTrackIdBySsrc(kSsrcOfTrack, _))
4674cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org        .WillRepeatedly(DoAll(SetArgPointee<1>(kLocalTrackId), Return(true)));
46897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  }
46997077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
4704cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Adds a incoming video track with a given SSRC into the stats.
4714cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  void AddIncomingVideoTrackStats() {
4724cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    stream_ = webrtc::MediaStream::Create("streamlabel");
4734cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    track_= webrtc::VideoTrack::Create(kRemoteTrackId, NULL);
4744cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    stream_->AddTrack(track_);
4754cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    EXPECT_CALL(session_, GetRemoteTrackIdBySsrc(kSsrcOfTrack, _))
47601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        .WillRepeatedly(DoAll(SetArgPointee<1>(kRemoteTrackId), Return(true)));
4774cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    }
4784cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
4794cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Adds a outgoing audio track with a given SSRC into the stats.
4804cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  void AddOutgoingAudioTrackStats() {
48140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    if (stream_ == NULL)
48240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      stream_ = webrtc::MediaStream::Create("streamlabel");
48340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
4844cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    audio_track_ = new talk_base::RefCountedObject<FakeAudioTrack>(
4854cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org        kLocalTrackId);
48640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    stream_->AddTrack(audio_track_);
4874cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    EXPECT_CALL(session_, GetLocalTrackIdBySsrc(kSsrcOfTrack, _))
48801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        .WillOnce(DoAll(SetArgPointee<1>(kLocalTrackId), Return(true)));
4894cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  }
4904cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
4914cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Adds a incoming audio track with a given SSRC into the stats.
4924cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  void AddIncomingAudioTrackStats() {
4934cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    if (stream_ == NULL)
4944cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      stream_ = webrtc::MediaStream::Create("streamlabel");
4954cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
4964cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    audio_track_ = new talk_base::RefCountedObject<FakeAudioTrack>(
4974cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org        kRemoteTrackId);
4984cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    stream_->AddTrack(audio_track_);
4994cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org    EXPECT_CALL(session_, GetRemoteTrackIdBySsrc(kSsrcOfTrack, _))
50001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        .WillOnce(DoAll(SetArgPointee<1>(kRemoteTrackId), Return(true)));
50101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  }
50201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
50301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  void SetupAndVerifyAudioTrackStats(
50401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      FakeAudioTrack* audio_track,
50501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      webrtc::MediaStream* stream,
50601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      webrtc::StatsCollector* stats,
50701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      cricket::VoiceChannel* voice_channel,
50801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      const std::string& vc_name,
50901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      MockVoiceMediaChannel* media_channel,
51001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      cricket::VoiceSenderInfo* voice_sender_info,
51101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      cricket::VoiceReceiverInfo* voice_receiver_info,
51201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      cricket::VoiceMediaInfo* stats_read,
51301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      StatsReports* reports) {
51401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    // A track can't have both sender report and recv report at the same time
51501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    // for now, this might change in the future though.
51601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    ASSERT((voice_sender_info == NULL) ^ (voice_receiver_info == NULL));
51701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
51801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    // Instruct the session to return stats containing the transport channel.
51901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    InitSessionStats(vc_name);
52001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_CALL(session_, GetStats(_))
52101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        .WillRepeatedly(DoAll(SetArgPointee<0>(session_stats_),
52201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org                              Return(true)));
52301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
52401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    // Constructs an ssrc stats update.
52501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    if (voice_sender_info)
52601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      stats_read->senders.push_back(*voice_sender_info);
52701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    if (voice_receiver_info)
52801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      stats_read->receivers.push_back(*voice_receiver_info);
52901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
53001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_CALL(session_, voice_channel()).WillRepeatedly(
53101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        Return(voice_channel));
53201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
53301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_CALL(*media_channel, GetStats(_))
53401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        .WillOnce(DoAll(SetArgPointee<0>(*stats_read), Return(true)));
53501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
53601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    stats->UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
53701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    stats->ClearUpdateStatsCache();
53801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    stats->GetStats(NULL, reports);
53901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
54001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    // Verify the existence of the track report.
54101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    const StatsReport* report = FindNthReportByType(
54201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        *reports, StatsReport::kStatsReportTypeSsrc, 1);
54301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_FALSE(report == NULL);
54401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    std::string track_id = ExtractSsrcStatsValue(
54501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        *reports, StatsReport::kStatsValueNameTrackId);
54601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_EQ(audio_track->id(), track_id);
54701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    std::string ssrc_id = ExtractSsrcStatsValue(
54801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        *reports, StatsReport::kStatsValueNameSsrc);
54901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_EQ(talk_base::ToString<uint32>(kSsrcOfTrack), ssrc_id);
55001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
55101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    // Verifies the values in the track report.
55201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    if (voice_sender_info) {
55301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      UpdateVoiceSenderInfoFromAudioTrack(audio_track, voice_sender_info);
55401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      VerifyVoiceSenderInfoReport(report, *voice_sender_info);
55501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    }
55601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    if (voice_receiver_info) {
55701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      VerifyVoiceReceiverInfoReport(report, *voice_receiver_info);
55801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    }
55901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
56001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    // Verify we get the same result by passing a track to GetStats().
56101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    StatsReports track_reports;  // returned values.
56201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    stats->GetStats(audio_track, &track_reports);
56301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    const StatsReport* track_report = FindNthReportByType(
56401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org        track_reports, StatsReport::kStatsReportTypeSsrc, 1);
56501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_TRUE(track_report);
56601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    track_id = ExtractSsrcStatsValue(track_reports,
56701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org                                     StatsReport::kStatsValueNameTrackId);
56801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_EQ(audio_track->id(), track_id);
56901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    ssrc_id = ExtractSsrcStatsValue(track_reports,
57001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org                                    StatsReport::kStatsValueNameSsrc);
57101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    EXPECT_EQ(talk_base::ToString<uint32>(kSsrcOfTrack), ssrc_id);
57201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    if (voice_sender_info)
57301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      VerifyVoiceSenderInfoReport(track_report, *voice_sender_info);
57401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    if (voice_receiver_info)
57501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org    VerifyVoiceReceiverInfoReport(track_report, *voice_receiver_info);
57640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  }
57740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
5784551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  void TestCertificateReports(const talk_base::FakeSSLCertificate& local_cert,
5794551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                              const std::vector<std::string>& local_ders,
5804551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                              const talk_base::FakeSSLCertificate& remote_cert,
5814551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                              const std::vector<std::string>& remote_ders) {
58203505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org    webrtc::StatsCollector stats(&session_);  // Implementation under test.
58340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    StatsReports reports;  // returned values.
5844551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
5854551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    // Fake stats to process.
5864551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    cricket::TransportChannelStats channel_stats;
5874551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    channel_stats.component = 1;
5884551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
5894551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    cricket::TransportStats transport_stats;
5904551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    transport_stats.content_name = "audio";
5914551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    transport_stats.channel_stats.push_back(channel_stats);
5924551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
5934551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    cricket::SessionStats session_stats;
5944551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    session_stats.transport_stats[transport_stats.content_name] =
5954551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        transport_stats;
5964551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
5974551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    // Fake certificates to report.
5984551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    talk_base::FakeSSLIdentity local_identity(local_cert);
5994551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    talk_base::scoped_ptr<talk_base::FakeSSLCertificate> remote_cert_copy(
6004551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        remote_cert.GetReference());
6014551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
6024551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    // Fake transport object.
6034551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    talk_base::scoped_ptr<cricket::FakeTransport> transport(
6044551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        new cricket::FakeTransport(
6054551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org            session_.signaling_thread(),
6064551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org            session_.worker_thread(),
6074551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org            transport_stats.content_name));
6084551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    transport->SetIdentity(&local_identity);
6094551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    cricket::FakeTransportChannel* channel =
6104551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        static_cast<cricket::FakeTransportChannel*>(
6114551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org            transport->CreateChannel(channel_stats.component));
6124551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    EXPECT_FALSE(channel == NULL);
6134551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    channel->SetRemoteCertificate(remote_cert_copy.get());
6144551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
6154551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    // Configure MockWebRtcSession
6164551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    EXPECT_CALL(session_, GetTransport(transport_stats.content_name))
6174551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      .WillOnce(Return(transport.get()));
6184551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    EXPECT_CALL(session_, GetStats(_))
6194551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      .WillOnce(DoAll(SetArgPointee<0>(session_stats),
6204551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                      Return(true)));
62140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
62240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
6234551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
624b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
6254551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
6264551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    stats.GetStats(NULL, &reports);
6274551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
62840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org    const StatsReport* channel_report = FindNthReportByType(
62940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        reports, StatsReport::kStatsReportTypeComponent, 1);
6304551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    EXPECT_TRUE(channel_report != NULL);
6314551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
6324551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    // Check local certificate chain.
6334551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    std::string local_certificate_id = ExtractStatsValue(
63440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        StatsReport::kStatsReportTypeComponent,
6354551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        reports,
63640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        StatsReport::kStatsValueNameLocalCertificateId);
637b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    if (local_ders.size() > 0) {
638b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      EXPECT_NE(kNotFound, local_certificate_id);
639b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      CheckCertChainReports(reports, local_ders, local_certificate_id);
640b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    } else {
641b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      EXPECT_EQ(kNotFound, local_certificate_id);
642b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    }
6434551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
6444551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    // Check remote certificate chain.
6454551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    std::string remote_certificate_id = ExtractStatsValue(
64640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        StatsReport::kStatsReportTypeComponent,
6474551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org        reports,
64840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org        StatsReport::kStatsValueNameRemoteCertificateId);
649b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    if (remote_ders.size() > 0) {
650b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      EXPECT_NE(kNotFound, remote_certificate_id);
651b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      CheckCertChainReports(reports, remote_ders, remote_certificate_id);
652b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    } else {
653b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      EXPECT_EQ(kNotFound, remote_certificate_id);
654b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    }
6554551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  }
65697077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
65728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::FakeMediaEngine* media_engine_;
65828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  talk_base::scoped_ptr<cricket::ChannelManager> channel_manager_;
65928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  MockWebRtcSession session_;
66097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  cricket::SessionStats session_stats_;
66197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  talk_base::scoped_refptr<webrtc::MediaStream> stream_;
66297077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  talk_base::scoped_refptr<webrtc::VideoTrack> track_;
6634cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  talk_base::scoped_refptr<FakeAudioTrack> audio_track_;
66428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org};
66528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
66628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// This test verifies that 64-bit counters are passed successfully.
66728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgTEST_F(StatsCollectorTest, BytesCounterHandles64Bits) {
66803505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
6694cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
67028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
67128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      media_engine_, media_channel, &session_, "", false, NULL);
67240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;  // returned values.
67328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoSenderInfo video_sender_info;
67428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoMediaInfo stats_read;
67528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // The number of bytes must be larger than 0xFFFFFFFF for this test.
67628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const int64 kBytesSent = 12345678901234LL;
67728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const std::string kBytesSentString("12345678901234");
67828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
6794cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingVideoTrackStats();
68097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.AddStream(stream_);
68128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
68228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // Construct a stats value to read.
6835bc25c41fc7880545052770dbcfe67f233c9b0c0sergeyu@chromium.org  video_sender_info.add_ssrc(1234);
68428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  video_sender_info.bytes_sent = kBytesSent;
68528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats_read.senders.push_back(video_sender_info);
68628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
68740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(Return(&video_channel));
68840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
689b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_CALL(*media_channel, GetStats(_, _))
690242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      .WillOnce(DoAll(SetArgPointee<1>(stats_read),
691242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org                      Return(true)));
692b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
69328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats.GetStats(NULL, &reports);
694242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  std::string result = ExtractSsrcStatsValue(reports,
695242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      StatsReport::kStatsValueNameBytesSent);
69628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_EQ(kBytesSentString, result);
69728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
69828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
69928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// Test that BWE information is reported via stats.
70028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgTEST_F(StatsCollectorTest, BandwidthEstimationInfoIsReported) {
70103505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
7024cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
70328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
70428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      media_engine_, media_channel, &session_, "", false, NULL);
70540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;  // returned values.
70628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoSenderInfo video_sender_info;
70728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoMediaInfo stats_read;
70828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // Set up an SSRC just to test that we get both kinds of stats back: SSRC and
70928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // BWE.
71028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const int64 kBytesSent = 12345678901234LL;
71128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const std::string kBytesSentString("12345678901234");
71228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
7134cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingVideoTrackStats();
71497077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.AddStream(stream_);
71528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
71628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // Construct a stats value to read.
7175bc25c41fc7880545052770dbcfe67f233c9b0c0sergeyu@chromium.org  video_sender_info.add_ssrc(1234);
71828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  video_sender_info.bytes_sent = kBytesSent;
71928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats_read.senders.push_back(video_sender_info);
72028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::BandwidthEstimationInfo bwe;
72128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const int kTargetEncBitrate = 123456;
72228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const std::string kTargetEncBitrateString("123456");
72328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  bwe.target_enc_bitrate = kTargetEncBitrate;
72428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats_read.bw_estimations.push_back(bwe);
72528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
72640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(Return(&video_channel));
72740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
728b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_CALL(*media_channel, GetStats(_, _))
729b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    .WillOnce(DoAll(SetArgPointee<1>(stats_read),
73028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org                    Return(true)));
73197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
732b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
73328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats.GetStats(NULL, &reports);
734242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  std::string result = ExtractSsrcStatsValue(reports,
735242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      StatsReport::kStatsValueNameBytesSent);
73628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_EQ(kBytesSentString, result);
737242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  result = ExtractBweStatsValue(reports,
738242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      StatsReport::kStatsValueNameTargetEncBitrate);
73928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_EQ(kTargetEncBitrateString, result);
74028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
74128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
74228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// This test verifies that an object of type "googSession" always
74328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// exists in the returned stats.
74428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgTEST_F(StatsCollectorTest, SessionObjectExists) {
74503505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
74640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;  // returned values.
74740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
74840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
749b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
75028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats.GetStats(NULL, &reports);
75140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const StatsReport* session_report = FindNthReportByType(
75240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsReportTypeSession, 1);
75328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_FALSE(session_report == NULL);
75428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
75528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
75628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// This test verifies that only one object of type "googSession" exists
75728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// in the returned stats.
75828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgTEST_F(StatsCollectorTest, OnlyOneSessionObjectExists) {
75903505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
76040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;  // returned values.
76140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
76240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
763b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
764b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
76528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats.GetStats(NULL, &reports);
76640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const StatsReport* session_report = FindNthReportByType(
76740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsReportTypeSession, 1);
76828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_FALSE(session_report == NULL);
76928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  session_report = FindNthReportByType(
77040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsReportTypeSession, 2);
77128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_EQ(NULL, session_report);
77228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
77328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
77428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// This test verifies that the empty track report exists in the returned stats
77528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// without calling StatsCollector::UpdateStats.
77628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgTEST_F(StatsCollectorTest, TrackObjectExistsWithoutUpdateStats) {
77703505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
7784cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
77928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
78028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      media_engine_, media_channel, &session_, "", false, NULL);
7814cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingVideoTrackStats();
78297077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.AddStream(stream_);
78328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
78428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // Verfies the existence of the track report.
78503505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  StatsReports reports;
78628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats.GetStats(NULL, &reports);
78728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_EQ((size_t)1, reports.size());
78840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(std::string(StatsReport::kStatsReportTypeTrack),
78928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org            reports[0].type);
79028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
79128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  std::string trackValue =
79240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      ExtractStatsValue(StatsReport::kStatsReportTypeTrack,
79328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org                        reports,
79440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                        StatsReport::kStatsValueNameTrackId);
7954cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(kLocalTrackId, trackValue);
79628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
79728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
79828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// This test verifies that the empty track report exists in the returned stats
79928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// when StatsCollector::UpdateStats is called with ssrc stats.
80028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgTEST_F(StatsCollectorTest, TrackAndSsrcObjectExistAfterUpdateSsrcStats) {
80103505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
8024cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
80328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
80428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      media_engine_, media_channel, &session_, "", false, NULL);
8054cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingVideoTrackStats();
80697077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.AddStream(stream_);
80728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
80828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // Constructs an ssrc stats update.
80928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoSenderInfo video_sender_info;
81028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoMediaInfo stats_read;
81128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const int64 kBytesSent = 12345678901234LL;
81228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
81328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // Construct a stats value to read.
8145bc25c41fc7880545052770dbcfe67f233c9b0c0sergeyu@chromium.org  video_sender_info.add_ssrc(1234);
81528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  video_sender_info.bytes_sent = kBytesSent;
81628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats_read.senders.push_back(video_sender_info);
81728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
81840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(Return(&video_channel));
81940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
820b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_CALL(*media_channel, GetStats(_, _))
821b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    .WillOnce(DoAll(SetArgPointee<1>(stats_read),
82228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org                    Return(true)));
82328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
824b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
82503505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  StatsReports reports;
82628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats.GetStats(NULL, &reports);
82797077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // |reports| should contain at least one session report, one track report,
82897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // and one ssrc report.
82997077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  EXPECT_LE((size_t)3, reports.size());
83040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const StatsReport* track_report = FindNthReportByType(
83140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsReportTypeTrack, 1);
8324cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_TRUE(track_report);
83328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
8344cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Get report for the specific |track|.
83597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.GetStats(track_, &reports);
83697077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // |reports| should contain at least one session report, one track report,
83797077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // and one ssrc report.
83897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  EXPECT_LE((size_t)3, reports.size());
83928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  track_report = FindNthReportByType(
84040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsReportTypeTrack, 1);
8414cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_TRUE(track_report);
84228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
84328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  std::string ssrc_id = ExtractSsrcStatsValue(
84440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsValueNameSsrc);
84528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<uint32>(kSsrcOfTrack), ssrc_id);
84628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
84728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  std::string track_id = ExtractSsrcStatsValue(
84840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsValueNameTrackId);
8494cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(kLocalTrackId, track_id);
85028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
85128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
85228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// This test verifies that an SSRC object has the identifier of a Transport
85328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org// stats object, and that this transport stats object exists in stats.
85428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.orgTEST_F(StatsCollectorTest, TransportObjectLinkedFromSsrcObject) {
85503505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
856242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  // Ignore unused callback (logspam).
857242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  EXPECT_CALL(session_, GetTransport(_))
858242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      .WillOnce(Return(static_cast<cricket::Transport*>(NULL)));
8594cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
86028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // The content_name known by the video channel.
86128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const std::string kVcName("vcname");
86228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
86328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      media_engine_, media_channel, &session_, kVcName, false, NULL);
8644cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingVideoTrackStats();
86597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.AddStream(stream_);
86628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
86728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // Constructs an ssrc stats update.
86828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoSenderInfo video_sender_info;
86928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  cricket::VideoMediaInfo stats_read;
87028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  const int64 kBytesSent = 12345678901234LL;
87128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
87228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  // Construct a stats value to read.
8735bc25c41fc7880545052770dbcfe67f233c9b0c0sergeyu@chromium.org  video_sender_info.add_ssrc(1234);
87428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  video_sender_info.bytes_sent = kBytesSent;
87528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats_read.senders.push_back(video_sender_info);
87628e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
87740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(Return(&video_channel));
87840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
879b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_CALL(*media_channel, GetStats(_, _))
880b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    .WillRepeatedly(DoAll(SetArgPointee<1>(stats_read),
88128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org                          Return(true)));
88228e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
88397077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  InitSessionStats(kVcName);
88428e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  EXPECT_CALL(session_, GetStats(_))
88540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      .WillRepeatedly(DoAll(SetArgPointee<0>(session_stats_),
88640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                            Return(true)));
88728e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
888b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
88903505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  StatsReports reports;
89028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  stats.GetStats(NULL, &reports);
89128e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  std::string transport_id = ExtractStatsValue(
89240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeSsrc,
89328e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org      reports,
89440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsValueNameTransportId);
89528e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  ASSERT_NE(kNotFound, transport_id);
89640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const StatsReport* transport_report = FindReportById(reports,
89740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                                                       transport_id);
89828e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org  ASSERT_FALSE(transport_report == NULL);
89928e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}
90028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org
90197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org// This test verifies that a remote stats object will not be created for
90297077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org// an outgoing SSRC where remote stats are not returned.
90397077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.orgTEST_F(StatsCollectorTest, RemoteSsrcInfoIsAbsent) {
90403505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
9054cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
90697077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // The content_name known by the video channel.
90797077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  const std::string kVcName("vcname");
90897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
90997077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org      media_engine_, media_channel, &session_, kVcName, false, NULL);
9104cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingVideoTrackStats();
91197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.AddStream(stream_);
91297077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
91340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
91440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
91597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
916b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
91740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;
91897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.GetStats(NULL, &reports);
91940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const StatsReport* remote_report = FindNthReportByType(reports,
92040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeRemoteSsrc, 1);
92197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  EXPECT_TRUE(remote_report == NULL);
92297077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org}
92397077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
92497077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org// This test verifies that a remote stats object will be created for
92597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org// an outgoing SSRC where stats are returned.
92697077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.orgTEST_F(StatsCollectorTest, RemoteSsrcInfoIsPresent) {
92703505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
928242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  // Ignore unused callback (logspam).
929242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  EXPECT_CALL(session_, GetTransport(_))
930242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      .WillOnce(Return(static_cast<cricket::Transport*>(NULL)));
9314cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
93297077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // The content_name known by the video channel.
93397077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  const std::string kVcName("vcname");
93497077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
93597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org      media_engine_, media_channel, &session_, kVcName, false, NULL);
9364cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingVideoTrackStats();
93797077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.AddStream(stream_);
93897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
93997077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // Instruct the session to return stats containing the transport channel.
94097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  InitSessionStats(kVcName);
94197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  EXPECT_CALL(session_, GetStats(_))
94240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      .WillRepeatedly(DoAll(SetArgPointee<0>(session_stats_),
94340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                            Return(true)));
94497077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
94597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  // Constructs an ssrc stats update.
94697077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  cricket::VideoMediaInfo stats_read;
94797077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
94897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  cricket::SsrcReceiverInfo remote_ssrc_stats;
94997077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  remote_ssrc_stats.timestamp = 12345.678;
95097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  remote_ssrc_stats.ssrc = kSsrcOfTrack;
95197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  cricket::VideoSenderInfo video_sender_info;
9525bc25c41fc7880545052770dbcfe67f233c9b0c0sergeyu@chromium.org  video_sender_info.add_ssrc(kSsrcOfTrack);
95397077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  video_sender_info.remote_stats.push_back(remote_ssrc_stats);
95497077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats_read.senders.push_back(video_sender_info);
95597077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
95640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(Return(&video_channel));
95740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
958b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_CALL(*media_channel, GetStats(_, _))
959b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    .WillRepeatedly(DoAll(SetArgPointee<1>(stats_read),
96097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org                          Return(true)));
96197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
962b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
96303505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  StatsReports reports;
96497077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  stats.GetStats(NULL, &reports);
9654cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
96640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const StatsReport* remote_report = FindNthReportByType(reports,
96740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeRemoteSsrc, 1);
96897077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  EXPECT_FALSE(remote_report == NULL);
96997077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org  EXPECT_NE(0, remote_report->timestamp);
97097077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org}
97197077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
9724cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org// This test verifies that the empty track report exists in the returned stats
9734cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org// when StatsCollector::UpdateStats is called with ssrc stats.
9744cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgTEST_F(StatsCollectorTest, ReportsFromRemoteTrack) {
97503505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
9764cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
9774cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
9784cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      media_engine_, media_channel, &session_, "", false, NULL);
9794cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddIncomingVideoTrackStats();
9804cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.AddStream(stream_);
9814cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
9824cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Constructs an ssrc stats update.
9834cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  cricket::VideoReceiverInfo video_receiver_info;
9844cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  cricket::VideoMediaInfo stats_read;
9854cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  const int64 kNumOfPacketsConcealed = 54321;
9864cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
9874cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Construct a stats value to read.
9884cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  video_receiver_info.add_ssrc(1234);
9894cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  video_receiver_info.packets_concealed = kNumOfPacketsConcealed;
9904cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats_read.receivers.push_back(video_receiver_info);
9914cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
9924cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(Return(&video_channel));
9934cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
9944cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_CALL(*media_channel, GetStats(_, _))
9954cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      .WillOnce(DoAll(SetArgPointee<1>(stats_read),
9964cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org                      Return(true)));
9974cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
9984cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
99903505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  StatsReports reports;
10004cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.GetStats(NULL, &reports);
10014cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // |reports| should contain at least one session report, one track report,
10024cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // and one ssrc report.
10034cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_LE(static_cast<size_t>(3), reports.size());
10044cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  const StatsReport* track_report = FindNthReportByType(
10054cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      reports, StatsReport::kStatsReportTypeTrack, 1);
10064cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_TRUE(track_report);
10074cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
10084cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  std::string ssrc_id = ExtractSsrcStatsValue(
10094cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      reports, StatsReport::kStatsValueNameSsrc);
10104cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(talk_base::ToString<uint32>(kSsrcOfTrack), ssrc_id);
10114cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
10124cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  std::string track_id = ExtractSsrcStatsValue(
10134cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      reports, StatsReport::kStatsValueNameTrackId);
10144cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(kRemoteTrackId, track_id);
10154cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org}
10164cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
10174551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org// This test verifies that all chained certificates are correctly
10184551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org// reported
101919f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.orgTEST_F(StatsCollectorTest, ChainedCertificateReportsCreated) {
10204551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Build local certificate chain.
10214551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::vector<std::string> local_ders(5);
10224551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  local_ders[0] = "These";
10234551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  local_ders[1] = "are";
10244551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  local_ders[2] = "some";
10254551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  local_ders[3] = "der";
10264551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  local_ders[4] = "values";
10274551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  talk_base::FakeSSLCertificate local_cert(DersToPems(local_ders));
10284551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10294551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Build remote certificate chain
10304551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::vector<std::string> remote_ders(4);
10314551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  remote_ders[0] = "A";
10324551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  remote_ders[1] = "non-";
10334551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  remote_ders[2] = "intersecting";
10344551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  remote_ders[3] = "set";
10354551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  talk_base::FakeSSLCertificate remote_cert(DersToPems(remote_ders));
10364551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10374551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  TestCertificateReports(local_cert, local_ders, remote_cert, remote_ders);
10384551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org}
10394551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10404551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org// This test verifies that all certificates without chains are correctly
10414551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org// reported.
104219f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.orgTEST_F(StatsCollectorTest, ChainlessCertificateReportsCreated) {
10434551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Build local certificate.
10444551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::string local_der = "This is the local der.";
10454551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  talk_base::FakeSSLCertificate local_cert(DerToPem(local_der));
10464551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10474551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Build remote certificate.
10484551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::string remote_der = "This is somebody else's der.";
10494551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  talk_base::FakeSSLCertificate remote_cert(DerToPem(remote_der));
10504551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10514551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  TestCertificateReports(local_cert, std::vector<std::string>(1, local_der),
10524551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                         remote_cert, std::vector<std::string>(1, remote_der));
10534551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org}
10544551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10554551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org// This test verifies that the stats are generated correctly when no
10564551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org// transport is present.
105719f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.orgTEST_F(StatsCollectorTest, NoTransport) {
105803505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
105940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;  // returned values.
10604551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10614551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Fake stats to process.
10624551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  cricket::TransportChannelStats channel_stats;
10634551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  channel_stats.component = 1;
10644551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10654551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  cricket::TransportStats transport_stats;
10664551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  transport_stats.content_name = "audio";
10674551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  transport_stats.channel_stats.push_back(channel_stats);
10684551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10694551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  cricket::SessionStats session_stats;
10704551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  session_stats.transport_stats[transport_stats.content_name] =
10714551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      transport_stats;
10724551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10734551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Configure MockWebRtcSession
10744551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  EXPECT_CALL(session_, GetTransport(transport_stats.content_name))
10754551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    .WillOnce(ReturnNull());
10764551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  EXPECT_CALL(session_, GetStats(_))
10774551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    .WillOnce(DoAll(SetArgPointee<0>(session_stats),
10784551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                    Return(true)));
107997077a3ab27259164eb121034b6e0ebe9ba592dfwu@webrtc.org
108040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
108140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
10824551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
1083b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
10844551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  stats.GetStats(NULL, &reports);
10854551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10864551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Check that the local certificate is absent.
10874551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::string local_certificate_id = ExtractStatsValue(
108840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeComponent,
10894551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      reports,
109040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsValueNameLocalCertificateId);
10914551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  ASSERT_EQ(kNotFound, local_certificate_id);
10924551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
10934551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Check that the remote certificate is absent.
10944551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::string remote_certificate_id = ExtractStatsValue(
109540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeComponent,
10964551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      reports,
109740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsValueNameRemoteCertificateId);
10984551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  ASSERT_EQ(kNotFound, remote_certificate_id);
10994551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org}
11004551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
11014551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org// This test verifies that the stats are generated correctly when the transport
11024551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org// does not have any certificates.
110319f27e6a24f877fc2b0409a94b02d5f40ba3dc8cmallinath@webrtc.orgTEST_F(StatsCollectorTest, NoCertificates) {
110403505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
110540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;  // returned values.
11064551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
11074551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Fake stats to process.
11084551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  cricket::TransportChannelStats channel_stats;
11094551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  channel_stats.component = 1;
11104551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
11114551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  cricket::TransportStats transport_stats;
11124551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  transport_stats.content_name = "audio";
11134551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  transport_stats.channel_stats.push_back(channel_stats);
11144551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
11154551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  cricket::SessionStats session_stats;
11164551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  session_stats.transport_stats[transport_stats.content_name] =
11174551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      transport_stats;
11184551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
11194551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Fake transport object.
11204551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  talk_base::scoped_ptr<cricket::FakeTransport> transport(
11214551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      new cricket::FakeTransport(
11224551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org          session_.signaling_thread(),
11234551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org          session_.worker_thread(),
11244551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org          transport_stats.content_name));
11254551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
11264551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Configure MockWebRtcSession
11274551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  EXPECT_CALL(session_, GetTransport(transport_stats.content_name))
11284551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    .WillOnce(Return(transport.get()));
11294551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  EXPECT_CALL(session_, GetStats(_))
11304551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org    .WillOnce(DoAll(SetArgPointee<0>(session_stats),
11314551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org                    Return(true)));
113240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
113340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
11344551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
1135b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
11364551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  stats.GetStats(NULL, &reports);
11374551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
11384551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Check that the local certificate is absent.
11394551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::string local_certificate_id = ExtractStatsValue(
114040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeComponent,
11414551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      reports,
114240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsValueNameLocalCertificateId);
11434551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  ASSERT_EQ(kNotFound, local_certificate_id);
11444551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
11454551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  // Check that the remote certificate is absent.
11464551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  std::string remote_certificate_id = ExtractStatsValue(
114740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsReportTypeComponent,
11484551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org      reports,
114940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      StatsReport::kStatsValueNameRemoteCertificateId);
11504551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org  ASSERT_EQ(kNotFound, remote_certificate_id);
11514551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org}
11524551b793dea4b5451cbfa13b206b6d11a25081d0wu@webrtc.org
1153b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org// This test verifies that a remote certificate with an unsupported digest
1154b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org// algorithm is correctly ignored.
1155b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.orgTEST_F(StatsCollectorTest, UnsupportedDigestIgnored) {
1156b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  // Build a local certificate.
1157b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  std::string local_der = "This is the local der.";
1158b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  talk_base::FakeSSLCertificate local_cert(DerToPem(local_der));
1159b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org
1160b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  // Build a remote certificate with an unsupported digest algorithm.
1161b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  std::string remote_der = "This is somebody else's der.";
1162b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  talk_base::FakeSSLCertificate remote_cert(DerToPem(remote_der));
1163b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  remote_cert.set_digest_algorithm("foobar");
1164b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org
1165b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  TestCertificateReports(local_cert, std::vector<std::string>(1, local_der),
1166b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org                         remote_cert, std::vector<std::string>());
1167b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org}
1168b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org
1169b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org// Verifies the correct optons are passed to the VideoMediaChannel when using
1170b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org// verbose output level.
1171b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.orgTEST_F(StatsCollectorTest, StatsOutputLevelVerbose) {
117203505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
11734cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVideoMediaChannel* media_channel = new MockVideoMediaChannel();
1174b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  cricket::VideoChannel video_channel(talk_base::Thread::Current(),
1175b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      media_engine_, media_channel, &session_, "", false, NULL);
1176b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org
1177b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  cricket::VideoMediaInfo stats_read;
1178b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  cricket::BandwidthEstimationInfo bwe;
1179b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  bwe.total_received_propagation_delta_ms = 10;
1180b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  bwe.recent_received_propagation_delta_ms.push_back(100);
1181b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  bwe.recent_received_propagation_delta_ms.push_back(200);
1182b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  bwe.recent_received_packet_group_arrival_time_ms.push_back(1000);
1183b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  bwe.recent_received_packet_group_arrival_time_ms.push_back(2000);
1184b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats_read.bw_estimations.push_back(bwe);
1185b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org
1186b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_CALL(session_, video_channel())
1187b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    .WillRepeatedly(Return(&video_channel));
118840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(ReturnNull());
1189b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org
1190b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  StatsOptions options;
1191b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  options.include_received_propagation_stats = true;
1192b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_CALL(*media_channel, GetStats(
1193b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      Field(&StatsOptions::include_received_propagation_stats, true),
1194b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org      _))
1195b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org    .WillOnce(DoAll(SetArgPointee<1>(stats_read),
1196b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org                    Return(true)));
1197b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org
1198b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelDebug);
119903505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  StatsReports reports;  // returned values.
1200b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  stats.GetStats(NULL, &reports);
1201b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  std::string result = ExtractBweStatsValue(
1202242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      reports,
1203242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      StatsReport::kStatsValueNameRecvPacketGroupPropagationDeltaSumDebug);
1204b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_EQ("10", result);
1205b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  result = ExtractBweStatsValue(
1206242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      reports,
1207242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      StatsReport::kStatsValueNameRecvPacketGroupPropagationDeltaDebug);
1208b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_EQ("[100, 200]", result);
1209b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  result = ExtractBweStatsValue(
1210242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      reports, StatsReport::kStatsValueNameRecvPacketGroupArrivalTimeDebug);
1211b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org  EXPECT_EQ("[1000, 2000]", result);
1212b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org}
1213b9a088b920d1ba16e0593698d4a613bb7bb5481fwu@webrtc.org
121440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org// This test verifies that a local stats object can get statistics via
121540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org// AudioTrackInterface::GetStats() method.
121640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgTEST_F(StatsCollectorTest, GetStatsFromLocalAudioTrack) {
121703505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
1218242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  // Ignore unused callback (logspam).
1219242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  EXPECT_CALL(session_, GetTransport(_))
1220242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      .WillOnce(Return(static_cast<cricket::Transport*>(NULL)));
1221242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org
122240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  MockVoiceMediaChannel* media_channel = new MockVoiceMediaChannel();
122340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  // The content_name known by the voice channel.
122440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const std::string kVcName("vcname");
122540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  cricket::VoiceChannel voice_channel(talk_base::Thread::Current(),
122640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      media_engine_, media_channel, &session_, kVcName, false);
12274cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingAudioTrackStats();
122840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  stats.AddStream(stream_);
122901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  stats.AddLocalAudioTrack(audio_track_, kSsrcOfTrack);
123040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
123140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  cricket::VoiceSenderInfo voice_sender_info;
12324cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  InitVoiceSenderInfo(&voice_sender_info);
123340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
123440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  cricket::VoiceMediaInfo stats_read;
123540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;  // returned values.
123601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  SetupAndVerifyAudioTrackStats(
123701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      audio_track_.get(), stream_.get(), &stats, &voice_channel, kVcName,
123801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      media_channel, &voice_sender_info, NULL, &stats_read, &reports);
123940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
12404cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Verify that there is no remote report for the local audio track because
12414cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // we did not set it up.
12424cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  const StatsReport* remote_report = FindNthReportByType(reports,
12434cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      StatsReport::kStatsReportTypeRemoteSsrc, 1);
12444cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_TRUE(remote_report == NULL);
12454cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org}
12463e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org
12473e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org// This test verifies that audio receive streams populate stats reports
12483e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org// correctly.
12493e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.orgTEST_F(StatsCollectorTest, GetStatsFromRemoteStream) {
125003505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
1251242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  // Ignore unused callback (logspam).
1252242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  EXPECT_CALL(session_, GetTransport(_))
1253242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      .WillOnce(Return(static_cast<cricket::Transport*>(NULL)));
12543e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  MockVoiceMediaChannel* media_channel = new MockVoiceMediaChannel();
12553e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  // The content_name known by the voice channel.
12563e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  const std::string kVcName("vcname");
12573e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  cricket::VoiceChannel voice_channel(talk_base::Thread::Current(),
12583e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org      media_engine_, media_channel, &session_, kVcName, false);
12594cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddIncomingAudioTrackStats();
12603e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  stats.AddStream(stream_);
12613e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org
12623e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  cricket::VoiceReceiverInfo voice_receiver_info;
12634cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  InitVoiceReceiverInfo(&voice_receiver_info);
12647e71b77f8aab5b7a6f2b669c16f90ec9a4b4609cbuildbot@webrtc.org  voice_receiver_info.codec_name = "fake_codec";
12653e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org
12663e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  cricket::VoiceMediaInfo stats_read;
12673e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org  StatsReports reports;  // returned values.
126801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  SetupAndVerifyAudioTrackStats(
126901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      audio_track_.get(), stream_.get(), &stats, &voice_channel, kVcName,
127001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      media_channel, NULL, &voice_receiver_info, &stats_read, &reports);
12713e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org}
12723e01e0b16cbde481241b9bcfdbbdd591cd920b99buildbot@webrtc.org
127340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org// This test verifies that a local stats object won't update its statistics
127440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org// after a RemoveLocalAudioTrack() call.
127540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.orgTEST_F(StatsCollectorTest, GetStatsAfterRemoveAudioStream) {
127603505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
1277242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  // Ignore unused callback (logspam).
1278242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  EXPECT_CALL(session_, GetTransport(_))
1279242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      .WillOnce(Return(static_cast<cricket::Transport*>(NULL)));
128040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  MockVoiceMediaChannel* media_channel = new MockVoiceMediaChannel();
128140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  // The content_name known by the voice channel.
128240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const std::string kVcName("vcname");
128340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  cricket::VoiceChannel voice_channel(talk_base::Thread::Current(),
128440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      media_engine_, media_channel, &session_, kVcName, false);
12854cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingAudioTrackStats();
128640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  stats.AddStream(stream_);
128740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  stats.AddLocalAudioTrack(audio_track_.get(), kSsrcOfTrack);
128840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
128940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  // Instruct the session to return stats containing the transport channel.
129040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  InitSessionStats(kVcName);
129140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, GetStats(_))
129240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      .WillRepeatedly(DoAll(SetArgPointee<0>(session_stats_),
129340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                            Return(true)));
129440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
129540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  stats.RemoveLocalAudioTrack(audio_track_.get(), kSsrcOfTrack);
129640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  cricket::VoiceSenderInfo voice_sender_info;
12974cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  InitVoiceSenderInfo(&voice_sender_info);
129840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
129940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  // Constructs an ssrc stats update.
130040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  cricket::VoiceMediaInfo stats_read;
130140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  stats_read.senders.push_back(voice_sender_info);
130240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
130340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(Return(&voice_channel));
130440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
130540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_CALL(*media_channel, GetStats(_))
130640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      .WillRepeatedly(DoAll(SetArgPointee<0>(stats_read),
130740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org                            Return(true)));
130840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
130940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  StatsReports reports;  // returned values.
131040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
131140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  stats.GetStats(NULL, &reports);
131240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
131340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  // The report will exist since we don't remove them in RemoveStream().
131440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  const StatsReport* report = FindNthReportByType(
131540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsReportTypeSsrc, 1);
131640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_FALSE(report == NULL);
131740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  std::string track_id = ExtractSsrcStatsValue(
131840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsValueNameTrackId);
13194cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(kLocalTrackId, track_id);
132040b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  std::string ssrc_id = ExtractSsrcStatsValue(
132140b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org      reports, StatsReport::kStatsValueNameSsrc);
132240b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  EXPECT_EQ(talk_base::ToString<uint32>(kSsrcOfTrack), ssrc_id);
132340b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
132440b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  // Verifies the values in the track report, no value will be changed by the
132540b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  // AudioTrackInterface::GetSignalValue() and
132640b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  // AudioProcessorInterface::AudioProcessorStats::GetStats();
132740b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org  VerifyVoiceSenderInfoReport(report, voice_sender_info);
132840b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org}
132940b3b68cdf47d7c9c3b57fca5d0a372292025f9ehenrike@webrtc.org
13304cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org// This test verifies that when ongoing and incoming audio tracks are using
13314cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org// the same ssrc, they populate stats reports correctly.
13324cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.orgTEST_F(StatsCollectorTest, LocalAndRemoteTracksWithSameSsrc) {
133303505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
1334242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  // Ignore unused callback (logspam).
1335242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  EXPECT_CALL(session_, GetTransport(_))
1336242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      .WillOnce(Return(static_cast<cricket::Transport*>(NULL)));
13374cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  MockVoiceMediaChannel* media_channel = new MockVoiceMediaChannel();
13384cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // The content_name known by the voice channel.
13394cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  const std::string kVcName("vcname");
13404cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  cricket::VoiceChannel voice_channel(talk_base::Thread::Current(),
13414cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      media_engine_, media_channel, &session_, kVcName, false);
13424cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13434cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Create a local stream with a local audio track and adds it to the stats.
13444cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  AddOutgoingAudioTrackStats();
13454cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.AddStream(stream_);
13464cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.AddLocalAudioTrack(audio_track_.get(), kSsrcOfTrack);
13474cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13484cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Create a remote stream with a remote audio track and adds it to the stats.
13494cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  talk_base::scoped_refptr<webrtc::MediaStream> remote_stream(
13504cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      webrtc::MediaStream::Create("remotestreamlabel"));
13514cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  talk_base::scoped_refptr<FakeAudioTrack> remote_track(
13524cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      new talk_base::RefCountedObject<FakeAudioTrack>(kRemoteTrackId));
13534cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_CALL(session_, GetRemoteTrackIdBySsrc(kSsrcOfTrack, _))
135401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      .WillOnce(DoAll(SetArgPointee<1>(kRemoteTrackId), Return(true)));
13554cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  remote_stream->AddTrack(remote_track);
13564cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.AddStream(remote_stream);
13574cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13584cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Instruct the session to return stats containing the transport channel.
13594cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  InitSessionStats(kVcName);
13604cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_CALL(session_, GetStats(_))
13614cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      .WillRepeatedly(DoAll(SetArgPointee<0>(session_stats_),
13624cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org                            Return(true)));
13634cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13644cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  cricket::VoiceSenderInfo voice_sender_info;
13654cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  InitVoiceSenderInfo(&voice_sender_info);
13664cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13674cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Some of the contents in |voice_sender_info| needs to be updated from the
13684cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // |audio_track_|.
13694cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  UpdateVoiceSenderInfoFromAudioTrack(audio_track_.get(), &voice_sender_info);
13704cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13714cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  cricket::VoiceReceiverInfo voice_receiver_info;
13724cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  InitVoiceReceiverInfo(&voice_receiver_info);
13734cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13744cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Constructs an ssrc stats update.
13754cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  cricket::VoiceMediaInfo stats_read;
13764cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats_read.senders.push_back(voice_sender_info);
13774cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats_read.receivers.push_back(voice_receiver_info);
13784cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13794cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_CALL(session_, voice_channel()).WillRepeatedly(Return(&voice_channel));
13804cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_CALL(session_, video_channel()).WillRepeatedly(ReturnNull());
13814cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_CALL(*media_channel, GetStats(_))
13824cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      .WillRepeatedly(DoAll(SetArgPointee<0>(stats_read),
13834cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org                            Return(true)));
13844cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13854cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  StatsReports reports;  // returned values.
13864cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.UpdateStats(PeerConnectionInterface::kStatsOutputLevelStandard);
13874cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13884cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Get stats for the local track.
13894cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.GetStats(audio_track_.get(), &reports);
13904cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  const StatsReport* track_report = FindNthReportByType(
13914cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      reports, StatsReport::kStatsReportTypeSsrc, 1);
13924cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_TRUE(track_report);
13934cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  std::string track_id = ExtractSsrcStatsValue(
13944cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org      reports, StatsReport::kStatsValueNameTrackId);
13954cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(kLocalTrackId, track_id);
13964cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  VerifyVoiceSenderInfoReport(track_report, voice_sender_info);
13974cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
13984cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  // Get stats for the remote track.
13994cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  stats.GetStats(remote_track.get(), &reports);
14004cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  track_report = FindNthReportByType(reports,
14014cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org                                     StatsReport::kStatsReportTypeSsrc, 1);
14024cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_TRUE(track_report);
14034cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  track_id = ExtractSsrcStatsValue(reports,
14044cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org                                   StatsReport::kStatsValueNameTrackId);
14054cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  EXPECT_EQ(kRemoteTrackId, track_id);
14064cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org  VerifyVoiceReceiverInfoReport(track_report, voice_receiver_info);
14074cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org}
14084cb012858f7461015e405c0c2cfc4b9f10a086cexians@webrtc.org
140901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org// This test verifies that when two outgoing audio tracks are using the same
141001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org// ssrc at different times, they populate stats reports correctly.
141101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org// TODO(xians): Figure out if it is possible to encapsulate the setup and
141201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org// avoid duplication of code in test cases.
141301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.orgTEST_F(StatsCollectorTest, TwoLocalTracksWithSameSsrc) {
141403505bcb7a369add7abfe306004e7803ab096f21tommi@webrtc.org  webrtc::StatsCollector stats(&session_);  // Implementation under test.
1415242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  // Ignore unused callback (logspam).
1416242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org  EXPECT_CALL(session_, GetTransport(_))
1417242068d58cc01640aa9f733fa67f078fc65c4ae5tommi@webrtc.org      .WillRepeatedly(Return(static_cast<cricket::Transport*>(NULL)));
141801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  MockVoiceMediaChannel* media_channel = new MockVoiceMediaChannel();
141901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  // The content_name known by the voice channel.
142001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  const std::string kVcName("vcname");
142101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  cricket::VoiceChannel voice_channel(talk_base::Thread::Current(),
142201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      media_engine_, media_channel, &session_, kVcName, false);
142301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
142401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  // Create a local stream with a local audio track and adds it to the stats.
142501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  AddOutgoingAudioTrackStats();
142601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  stats.AddStream(stream_);
142701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  stats.AddLocalAudioTrack(audio_track_, kSsrcOfTrack);
142801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
142901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  cricket::VoiceSenderInfo voice_sender_info;
143001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  voice_sender_info.add_ssrc(kSsrcOfTrack);
143101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
143201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  cricket::VoiceMediaInfo stats_read;
143301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  StatsReports reports;  // returned values.
143401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  SetupAndVerifyAudioTrackStats(
143501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      audio_track_.get(), stream_.get(), &stats, &voice_channel, kVcName,
143601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      media_channel, &voice_sender_info, NULL, &stats_read, &reports);
143701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
143801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  // Remove the previous audio track from the stream.
143901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  stream_->RemoveTrack(audio_track_.get());
144001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  stats.RemoveLocalAudioTrack(audio_track_.get(), kSsrcOfTrack);
144101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
144201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  // Create a new audio track and adds it to the stream and stats.
144301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  static const std::string kNewTrackId = "new_track_id";
144401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  talk_base::scoped_refptr<FakeAudioTrack> new_audio_track(
144501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      new talk_base::RefCountedObject<FakeAudioTrack>(kNewTrackId));
144601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  EXPECT_CALL(session_, GetLocalTrackIdBySsrc(kSsrcOfTrack, _))
144701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      .WillOnce(DoAll(SetArgPointee<1>(kNewTrackId), Return(true)));
144801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  stream_->AddTrack(new_audio_track);
144901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
145001bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  stats.AddLocalAudioTrack(new_audio_track, kSsrcOfTrack);
145101bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  stats.ClearUpdateStatsCache();
145201bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  cricket::VoiceSenderInfo new_voice_sender_info;
145301bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  InitVoiceSenderInfo(&new_voice_sender_info);
145401bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  cricket::VoiceMediaInfo new_stats_read;
145501bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org  SetupAndVerifyAudioTrackStats(
145601bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      new_audio_track.get(), stream_.get(), &stats, &voice_channel, kVcName,
145701bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org      media_channel, &new_voice_sender_info, NULL, &new_stats_read, &reports);
145801bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org}
145901bda2068bebb65a610c0d951f938db5dd028394xians@webrtc.org
146028e20752806a492f5a6a5d343c02f9556f39b1cdhenrike@webrtc.org}  // namespace
1461