/* * Copyright 2025 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef TEST_TIME_CONTROLLER_SIMULATED_TIME_TASK_QUEUE_CONTROLLER_H_ #define TEST_TIME_CONTROLLER_SIMULATED_TIME_TASK_QUEUE_CONTROLLER_H_ #include "api/task_queue/task_queue_factory.h" #include "api/units/time_delta.h" #include "api/units/timestamp.h" #include "rtc_base/synchronization/yield_policy.h" #include "system_wrappers/include/clock.h" #include "test/time_controller/simulated_time_controller_impl.h" namespace webrtc { // This is a lightweight version of the `GlobalSimulatedTimeController`. It // supports simulated time `TaskQueue`s, but not simulated time `Thread`s. The // benefit is that it does not have a dependence on setting the process-global // clock, and it can thus be `testonly=false`, for consumers that require that. class SimulatedTimeTaskQueueController { public: explicit SimulatedTimeTaskQueueController(Timestamp start_time); ~SimulatedTimeTaskQueueController(); // Clock for the simulated time. Clock* GetClock(); // Task queues run on simulated time. TaskQueueFactory* GetTaskQueueFactory(); // Advance simulated time by `duration` and run all relevant tasks. void AdvanceTime(TimeDelta duration); private: SimulatedClock sim_clock_; sim_time_impl::SimulatedTimeControllerImpl impl_; ScopedYieldPolicy yield_policy_; }; } // namespace webrtc #endif // TEST_TIME_CONTROLLER_SIMULATED_TIME_TASK_QUEUE_CONTROLLER_H_