Allow injection of custom network models in place of FakeNetworkPipe.

Adds a constructor for DirectTransport that takes a pointer to an instance 
of a class derived from FakeNetworkPipe. Said class can override Process() 
and SendPacket(...) members thereby emulating any desired network behavior.

Bug: b/67487983
Change-Id: I829fd3506124db61587af19192a14fdf62b06ca5
Reviewed-on: https://webrtc-review.googlesource.com/14620
Commit-Queue: Christoffer Rodbro <crodbro@webrtc.org>
Reviewed-by: Stefan Holmer <stefan@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#20443}
This commit is contained in:
Christoffer Rodbro 2017-10-24 16:26:49 +02:00 committed by Commit Bot
parent 0295a967c0
commit d2817d80b5
4 changed files with 46 additions and 20 deletions

View File

@ -46,13 +46,19 @@ DirectTransport::DirectTransport(SingleThreadedTaskQueueForTesting* task_queue,
: send_call_(send_call), : send_call_(send_call),
clock_(Clock::GetRealTimeClock()), clock_(Clock::GetRealTimeClock()),
task_queue_(task_queue), task_queue_(task_queue),
fake_network_(clock_, config, std::move(demuxer)) { fake_network_(rtc::MakeUnique<FakeNetworkPipe>(clock_, config,
RTC_DCHECK(task_queue); std::move(demuxer))) {
if (send_call_) { Start();
send_call_->SignalChannelNetworkState(MediaType::AUDIO, kNetworkUp); }
send_call_->SignalChannelNetworkState(MediaType::VIDEO, kNetworkUp);
} DirectTransport::DirectTransport(SingleThreadedTaskQueueForTesting* task_queue,
SendPackets(); std::unique_ptr<FakeNetworkPipe> pipe,
Call* send_call)
: send_call_(send_call),
clock_(Clock::GetRealTimeClock()),
task_queue_(task_queue),
fake_network_(std::move(pipe)) {
Start();
} }
DirectTransport::~DirectTransport() { DirectTransport::~DirectTransport() {
@ -63,7 +69,7 @@ DirectTransport::~DirectTransport() {
} }
void DirectTransport::SetConfig(const FakeNetworkPipe::Config& config) { void DirectTransport::SetConfig(const FakeNetworkPipe::Config& config) {
fake_network_.SetConfig(config); fake_network_->SetConfig(config);
} }
void DirectTransport::StopSending() { void DirectTransport::StopSending() {
@ -73,7 +79,7 @@ void DirectTransport::StopSending() {
void DirectTransport::SetReceiver(PacketReceiver* receiver) { void DirectTransport::SetReceiver(PacketReceiver* receiver) {
RTC_DCHECK_CALLED_SEQUENTIALLY(&sequence_checker_); RTC_DCHECK_CALLED_SEQUENTIALLY(&sequence_checker_);
fake_network_.SetReceiver(receiver); fake_network_->SetReceiver(receiver);
} }
bool DirectTransport::SendRtp(const uint8_t* data, bool DirectTransport::SendRtp(const uint8_t* data,
@ -84,25 +90,34 @@ bool DirectTransport::SendRtp(const uint8_t* data,
clock_->TimeInMilliseconds()); clock_->TimeInMilliseconds());
send_call_->OnSentPacket(sent_packet); send_call_->OnSentPacket(sent_packet);
} }
fake_network_.SendPacket(data, length); fake_network_->SendPacket(data, length);
return true; return true;
} }
bool DirectTransport::SendRtcp(const uint8_t* data, size_t length) { bool DirectTransport::SendRtcp(const uint8_t* data, size_t length) {
fake_network_.SendPacket(data, length); fake_network_->SendPacket(data, length);
return true; return true;
} }
int DirectTransport::GetAverageDelayMs() { int DirectTransport::GetAverageDelayMs() {
return fake_network_.AverageDelay(); return fake_network_->AverageDelay();
}
void DirectTransport::Start() {
RTC_DCHECK(task_queue_);
if (send_call_) {
send_call_->SignalChannelNetworkState(MediaType::AUDIO, kNetworkUp);
send_call_->SignalChannelNetworkState(MediaType::VIDEO, kNetworkUp);
}
SendPackets();
} }
void DirectTransport::SendPackets() { void DirectTransport::SendPackets() {
RTC_DCHECK_CALLED_SEQUENTIALLY(&sequence_checker_); RTC_DCHECK_CALLED_SEQUENTIALLY(&sequence_checker_);
fake_network_.Process(); fake_network_->Process();
int64_t delay_ms = fake_network_.TimeUntilNextProcess(); int64_t delay_ms = fake_network_->TimeUntilNextProcess();
next_scheduled_task_ = task_queue_->PostDelayedTask([this]() { next_scheduled_task_ = task_queue_->PostDelayedTask([this]() {
SendPackets(); SendPackets();
}, delay_ms); }, delay_ms);

View File

@ -46,6 +46,9 @@ class DirectTransport : public Transport {
Call* send_call, Call* send_call,
std::unique_ptr<Demuxer> demuxer); std::unique_ptr<Demuxer> demuxer);
DirectTransport(SingleThreadedTaskQueueForTesting* task_queue,
std::unique_ptr<FakeNetworkPipe> pipe, Call* send_call);
~DirectTransport() override; ~DirectTransport() override;
void SetConfig(const FakeNetworkPipe::Config& config); void SetConfig(const FakeNetworkPipe::Config& config);
@ -64,6 +67,7 @@ class DirectTransport : public Transport {
private: private:
void SendPackets(); void SendPackets();
void Start();
Call* const send_call_; Call* const send_call_;
Clock* const clock_; Clock* const clock_;
@ -72,7 +76,7 @@ class DirectTransport : public Transport {
SingleThreadedTaskQueueForTesting::TaskId next_scheduled_task_ SingleThreadedTaskQueueForTesting::TaskId next_scheduled_task_
RTC_GUARDED_BY(&sequence_checker_); RTC_GUARDED_BY(&sequence_checker_);
FakeNetworkPipe fake_network_; std::unique_ptr<FakeNetworkPipe> fake_network_;
rtc::SequencedTaskChecker sequence_checker_; rtc::SequencedTaskChecker sequence_checker_;
}; };

View File

@ -114,21 +114,20 @@ class FakeNetworkPipe {
const FakeNetworkPipe::Config& config, const FakeNetworkPipe::Config& config,
std::unique_ptr<Demuxer> demuxer, std::unique_ptr<Demuxer> demuxer,
uint64_t seed); uint64_t seed);
~FakeNetworkPipe(); virtual ~FakeNetworkPipe();
// Sets a new configuration. This won't affect packets already in the pipe. // Sets a new configuration. This won't affect packets already in the pipe.
void SetConfig(const FakeNetworkPipe::Config& config); void SetConfig(const FakeNetworkPipe::Config& config);
// Sends a new packet to the link. // Sends a new packet to the link.
void SendPacket(const uint8_t* packet, size_t packet_length); virtual void SendPacket(const uint8_t* packet, size_t packet_length);
// Must not be called in parallel with SendPacket or Process. // Must not be called in parallel with SendPacket or Process.
void SetReceiver(PacketReceiver* receiver); void SetReceiver(PacketReceiver* receiver);
// Processes the network queues and trigger PacketReceiver::IncomingPacket for // Processes the network queues and trigger PacketReceiver::IncomingPacket for
// packets ready to be delivered. // packets ready to be delivered.
void Process(); virtual void Process();
int64_t TimeUntilNextProcess() const; int64_t TimeUntilNextProcess() const;
// Get statistics. // Get statistics.
@ -137,7 +136,7 @@ class FakeNetworkPipe {
size_t dropped_packets() { return dropped_packets_; } size_t dropped_packets() { return dropped_packets_; }
size_t sent_packets() { return sent_packets_; } size_t sent_packets() { return sent_packets_; }
private: protected:
Clock* const clock_; Clock* const clock_;
rtc::CriticalSection lock_; rtc::CriticalSection lock_;
const std::unique_ptr<Demuxer> demuxer_; const std::unique_ptr<Demuxer> demuxer_;

View File

@ -105,6 +105,14 @@ class PacketTransport : public test::DirectTransport {
observer_(observer), observer_(observer),
transport_type_(transport_type) {} transport_type_(transport_type) {}
PacketTransport(SingleThreadedTaskQueueForTesting* task_queue,
Call* send_call, RtpRtcpObserver* observer,
TransportType transport_type,
std::unique_ptr<FakeNetworkPipe> nw_pipe)
: test::DirectTransport(task_queue, std::move(nw_pipe), send_call),
observer_(observer),
transport_type_(transport_type) {}
private: private:
bool SendRtp(const uint8_t* packet, bool SendRtp(const uint8_t* packet,
size_t length, size_t length,