Merge SendTask implementation for SingleThreadedTaskQueueForTesting and TaskQueueForTest
That allows to use SingleThreadedTaskQueueForTesting via TaskQueueBase interface
but still have access to test-only SendTask function.
Bug: webrtc:10933
Change-Id: I3cc397e55ea2f1ed9e5d885d6a2ccda412beb826
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/156002
Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
Commit-Queue: Danil Chapovalov <danilchap@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#29480}
diff --git a/rtc_base/task_queue_for_test.h b/rtc_base/task_queue_for_test.h
index be91c50..40fc9c8 100644
--- a/rtc_base/task_queue_for_test.h
+++ b/rtc_base/task_queue_for_test.h
@@ -14,14 +14,27 @@
#include <utility>
#include "absl/strings/string_view.h"
+#include "api/task_queue/task_queue_base.h"
#include "rtc_base/checks.h"
#include "rtc_base/event.h"
+#include "rtc_base/location.h"
#include "rtc_base/task_queue.h"
#include "rtc_base/task_utils/to_queued_task.h"
#include "rtc_base/thread_annotations.h"
namespace webrtc {
+template <typename Closure>
+void SendTask(TaskQueueBase* task_queue, Closure&& task, rtc::Location loc) {
+ RTC_CHECK(!task_queue->IsCurrent())
+ << "Called SendTask to a queue from the same queue at " << loc.ToString();
+ rtc::Event event;
+ task_queue->PostTask(
+ ToQueuedTask(std::forward<Closure>(task), [&event] { event.Set(); }));
+ RTC_CHECK(event.Wait(/*give_up_after_ms=*/120'000, /*warn_after_ms=*/10'000))
+ << "Waited too long at " << loc.ToString();
+}
+
class RTC_LOCKABLE TaskQueueForTest : public rtc::TaskQueue {
public:
using rtc::TaskQueue::TaskQueue;
@@ -38,7 +51,7 @@
// task queue (i.e. the Run() method always returns |false|.).
template <class Closure>
void SendTask(Closure* task) {
- RTC_DCHECK(!IsCurrent());
+ RTC_CHECK(!IsCurrent());
rtc::Event event;
PostTask(ToQueuedTask(
[&task] { RTC_CHECK_EQ(false, static_cast<QueuedTask*>(task)->Run()); },
@@ -49,12 +62,8 @@
// A convenience, test-only method that blocks the current thread while
// a task executes on the task queue.
template <class Closure>
- void SendTask(Closure&& task) {
- RTC_DCHECK(!IsCurrent());
- rtc::Event event;
- PostTask(
- ToQueuedTask(std::forward<Closure>(task), [&event] { event.Set(); }));
- event.Wait(rtc::Event::kForever);
+ void SendTask(Closure&& task, rtc::Location loc) {
+ ::webrtc::SendTask(Get(), std::forward<Closure>(task), loc);
}
};