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}
This commit is contained in:
committed by
Commit Bot
parent
35214fcfe2
commit
eb90e6ffe3
@ -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 @@ class RTC_LOCKABLE TaskQueueForTest : public rtc::TaskQueue {
|
||||
// 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 @@ class RTC_LOCKABLE TaskQueueForTest : public rtc::TaskQueue {
|
||||
// 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);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user