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:
parent
0295a967c0
commit
d2817d80b5
@ -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);
|
||||||
|
|||||||
@ -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_;
|
||||||
};
|
};
|
||||||
|
|||||||
@ -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_;
|
||||||
|
|||||||
@ -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,
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user