Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1850)

Unified Diff: webrtc/test/direct_transport.cc

Issue 2998923002: Use SingleThreadedTaskQueue in DirectTransport (Closed)
Patch Set: Appease win_msvc_rel. Created 3 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webrtc/test/direct_transport.cc
diff --git a/webrtc/test/direct_transport.cc b/webrtc/test/direct_transport.cc
index 370425c5374930f7562e3f23f71277444a43d2e5..81f3b697102bd3201bd7a6316ff4277f627cde85 100644
--- a/webrtc/test/direct_transport.cc
+++ b/webrtc/test/direct_transport.cc
@@ -10,7 +10,9 @@
#include "webrtc/test/direct_transport.h"
#include "webrtc/call/call.h"
+#include "webrtc/rtc_base/ptr_util.h"
#include "webrtc/system_wrappers/include/clock.h"
+#include "webrtc/test/single_threaded_task_queue.h"
namespace webrtc {
namespace test {
@@ -32,36 +34,71 @@ DirectTransport::DirectTransport(
DirectTransport::DirectTransport(const FakeNetworkPipe::Config& config,
Call* send_call,
std::unique_ptr<Demuxer> demuxer)
+ : DirectTransport(nullptr, config, send_call, std::move(demuxer)) {}
+
+DirectTransport::DirectTransport(
+ SingleThreadedTaskQueueForTesting* task_queue,
+ Call* send_call,
+ const std::map<uint8_t, MediaType>& payload_type_map)
+ : DirectTransport(task_queue,
+ FakeNetworkPipe::Config(),
+ send_call,
+ payload_type_map) {
+}
+
+DirectTransport::DirectTransport(
+ SingleThreadedTaskQueueForTesting* task_queue,
+ const FakeNetworkPipe::Config& config,
+ Call* send_call,
+ const std::map<uint8_t, MediaType>& payload_type_map)
+ : DirectTransport(
+ task_queue,
+ config,
+ send_call,
+ std::unique_ptr<Demuxer>(new DemuxerImpl(payload_type_map))) {
+}
+
+DirectTransport::DirectTransport(SingleThreadedTaskQueueForTesting* task_queue,
+ const FakeNetworkPipe::Config& config,
+ Call* send_call,
+ std::unique_ptr<Demuxer> demuxer)
: send_call_(send_call),
- packet_event_(false, false),
- thread_(NetworkProcess, this, "NetworkProcess"),
clock_(Clock::GetRealTimeClock()),
- shutting_down_(false),
+ task_queue_(task_queue),
fake_network_(clock_, config, std::move(demuxer)) {
- thread_.Start();
+ // TODO(eladalon): When the deprecated ctors are removed, this check
+ // can be restored. https://bugs.chromium.org/p/webrtc/issues/detail?id=8125
+ // RTC_DCHECK(task_queue);
+ if (!task_queue) {
+ deprecated_task_queue_ =
+ rtc::MakeUnique<SingleThreadedTaskQueueForTesting>("deprecated_queue");
+ task_queue_ = deprecated_task_queue_.get();
+ }
+
if (send_call_) {
send_call_->SignalChannelNetworkState(MediaType::AUDIO, kNetworkUp);
send_call_->SignalChannelNetworkState(MediaType::VIDEO, kNetworkUp);
}
+ SendPackets();
}
-DirectTransport::~DirectTransport() { StopSending(); }
+DirectTransport::~DirectTransport() {
+ RTC_DCHECK_CALLED_SEQUENTIALLY(&sequence_checker_);
+ // Constructor updates |next_scheduled_task_|, so it's guaranteed to
+ // be initialized.
+ task_queue_->CancelTask(next_scheduled_task_);
+}
void DirectTransport::SetConfig(const FakeNetworkPipe::Config& config) {
fake_network_.SetConfig(config);
}
void DirectTransport::StopSending() {
- {
- rtc::CritScope crit(&lock_);
- shutting_down_ = true;
- }
-
- packet_event_.Set();
- thread_.Stop();
+ task_queue_->CancelTask(next_scheduled_task_);
}
void DirectTransport::SetReceiver(PacketReceiver* receiver) {
+ RTC_DCHECK_CALLED_SEQUENTIALLY(&sequence_checker_);
fake_network_.SetReceiver(receiver);
}
@@ -74,13 +111,11 @@ bool DirectTransport::SendRtp(const uint8_t* data,
send_call_->OnSentPacket(sent_packet);
}
fake_network_.SendPacket(data, length);
- packet_event_.Set();
return true;
}
bool DirectTransport::SendRtcp(const uint8_t* data, size_t length) {
fake_network_.SendPacket(data, length);
- packet_event_.Set();
return true;
}
@@ -104,18 +139,15 @@ void DirectTransport::ForceDemuxer::DeliverPacket(
packet->data_length(), packet_time);
}
-bool DirectTransport::NetworkProcess(void* transport) {
- return static_cast<DirectTransport*>(transport)->SendPackets();
-}
+void DirectTransport::SendPackets() {
+ RTC_DCHECK_CALLED_SEQUENTIALLY(&sequence_checker_);
-bool DirectTransport::SendPackets() {
fake_network_.Process();
- int64_t wait_time_ms = fake_network_.TimeUntilNextProcess();
- if (wait_time_ms > 0) {
- packet_event_.Wait(static_cast<int>(wait_time_ms));
- }
- rtc::CritScope crit(&lock_);
- return shutting_down_ ? false : true;
+
+ int64_t delay_ms = fake_network_.TimeUntilNextProcess();
+ next_scheduled_task_ = task_queue_->PostDelayedTask([this]() {
+ SendPackets();
+ }, delay_ms);
}
} // namespace test
} // namespace webrtc

Powered by Google App Engine
This is Rietveld 408576698