blob: d8d5b2d1bb5fa0b9f2079cd4cc3260bdf91206d3 [file] [log] [blame]
/*
* 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.
*/
#ifndef TEST_PC_E2E_TEST_PEER_H_
#define TEST_PC_E2E_TEST_PEER_H_
#include <memory>
#include <vector>
#include "absl/memory/memory.h"
#include "absl/types/variant.h"
#include "api/test/frame_generator_interface.h"
#include "api/test/peerconnection_quality_test_fixture.h"
#include "pc/peer_connection_wrapper.h"
#include "test/pc/e2e/peer_configurer.h"
#include "test/pc/e2e/peer_connection_quality_test_params.h"
namespace webrtc {
namespace webrtc_pc_e2e {
// Describes a single participant in the call.
class TestPeer final {
public:
Params* params() const { return params_.get(); }
PeerConfigurerImpl::VideoSource ReleaseVideoSource(size_t i) {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return std::move(video_sources_[i]);
}
PeerConnectionFactoryInterface* pc_factory() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->pc_factory();
}
PeerConnectionInterface* pc() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->pc();
}
MockPeerConnectionObserver* observer() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->observer();
}
std::unique_ptr<SessionDescriptionInterface> CreateOffer() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->CreateOffer();
}
std::unique_ptr<SessionDescriptionInterface> CreateAnswer() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->CreateAnswer();
}
bool SetLocalDescription(std::unique_ptr<SessionDescriptionInterface> desc,
std::string* error_out = nullptr) {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->SetLocalDescription(std::move(desc), error_out);
}
bool SetRemoteDescription(std::unique_ptr<SessionDescriptionInterface> desc,
std::string* error_out = nullptr) {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->SetRemoteDescription(std::move(desc), error_out);
}
rtc::scoped_refptr<RtpTransceiverInterface> AddTransceiver(
cricket::MediaType media_type,
const RtpTransceiverInit& init) {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->AddTransceiver(media_type, init);
}
rtc::scoped_refptr<RtpSenderInterface> AddTrack(
rtc::scoped_refptr<MediaStreamTrackInterface> track,
const std::vector<std::string>& stream_ids = {}) {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->AddTrack(track, stream_ids);
}
rtc::scoped_refptr<DataChannelInterface> CreateDataChannel(
const std::string& label) {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->CreateDataChannel(label);
}
PeerConnectionInterface::SignalingState signaling_state() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->signaling_state();
}
bool IsIceGatheringDone() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->IsIceGatheringDone();
}
bool IsIceConnected() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->IsIceConnected();
}
rtc::scoped_refptr<const RTCStatsReport> GetStats() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
return wrapper_->GetStats();
}
void DetachAecDump() {
RTC_CHECK(wrapper_) << "TestPeer is already closed";
if (audio_processing_) {
audio_processing_->DetachAecDump();
}
}
// Adds provided |candidates| to the owned peer connection.
bool AddIceCandidates(
std::vector<std::unique_ptr<IceCandidateInterface>> candidates);
// Closes underlying peer connection and destroys all related objects freeing
// up related resources.
void Close();
protected:
friend class TestPeerFactory;
TestPeer(rtc::scoped_refptr<PeerConnectionFactoryInterface> pc_factory,
rtc::scoped_refptr<PeerConnectionInterface> pc,
std::unique_ptr<MockPeerConnectionObserver> observer,
std::unique_ptr<Params> params,
std::vector<PeerConfigurerImpl::VideoSource> video_sources,
rtc::scoped_refptr<AudioProcessing> audio_processing,
std::unique_ptr<rtc::Thread> worker_thread);
private:
// Keeps ownership of worker thread. It has to be destroyed after |wrapper_|.
std::unique_ptr<rtc::Thread> worker_thread_;
std::unique_ptr<PeerConnectionWrapper> wrapper_;
std::unique_ptr<Params> params_;
std::vector<PeerConfigurerImpl::VideoSource> video_sources_;
rtc::scoped_refptr<AudioProcessing> audio_processing_;
std::vector<std::unique_ptr<IceCandidateInterface>> remote_ice_candidates_;
};
} // namespace webrtc_pc_e2e
} // namespace webrtc
#endif // TEST_PC_E2E_TEST_PEER_H_