webrtc_m130/test/pc/e2e/stats_poller.cc
Artem Titov 987b671017 Add ability to add peer to the stats poller during the test
Bug: b/213863770
Change-Id: I65e0338806f808329725fce50d778738724cf13d
Pair: mbonadei@webrtc.org
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/251693
Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org>
Commit-Queue: Artem Titov <titovartem@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#36000}
2022-02-15 09:09:02 +00:00

58 lines
1.7 KiB
C++

/*
* Copyright (c) 2019 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include "test/pc/e2e/stats_poller.h"
#include <utility>
#include "rtc_base/logging.h"
#include "rtc_base/synchronization/mutex.h"
namespace webrtc {
namespace webrtc_pc_e2e {
void InternalStatsObserver::PollStats() {
peer_->pc()->GetStats(this);
}
void InternalStatsObserver::OnStatsDelivered(
const rtc::scoped_refptr<const RTCStatsReport>& report) {
for (auto* observer : observers_) {
observer->OnStatsReports(pc_label_, report);
}
}
StatsPoller::StatsPoller(std::vector<StatsObserverInterface*> observers,
std::map<std::string, TestPeer*> peers)
: observers_(observers) {
webrtc::MutexLock lock(&mutex_);
for (auto& peer : peers) {
pollers_.push_back(rtc::make_ref_counted<InternalStatsObserver>(
peer.first, peer.second, observers_));
}
}
void StatsPoller::PollStatsAndNotifyObservers() {
webrtc::MutexLock lock(&mutex_);
for (auto& poller : pollers_) {
poller->PollStats();
}
}
void StatsPoller::RegisterParticipantInCall(absl::string_view peer_name,
TestPeer* peer) {
webrtc::MutexLock lock(&mutex_);
pollers_.push_back(rtc::make_ref_counted<InternalStatsObserver>(
peer_name, peer, observers_));
}
} // namespace webrtc_pc_e2e
} // namespace webrtc