20#include <test/csf/Scheduler.h>
21#include <xrpl/beast/unit_test.h>
34 using namespace std::chrono_literals;
38 scheduler.
in(1s, [&] { seen.
insert(1); });
39 scheduler.
in(2s, [&] { seen.
insert(2); });
40 auto token = scheduler.
in(3s, [&] { seen.
insert(3); });
41 scheduler.
at(scheduler.
now() + 4s, [&] { seen.insert(4); });
42 scheduler.
at(scheduler.
now() + 8s, [&] { seen.insert(8); });
44 auto start = scheduler.
now();
47 BEAST_EXPECT(seen.
empty());
50 BEAST_EXPECT(scheduler.
now() == (start + 1s));
55 BEAST_EXPECT(scheduler.
now() == (start + 1s));
58 BEAST_EXPECT(scheduler.
step_for(1s));
60 BEAST_EXPECT(scheduler.
now() == (start + 2s));
64 BEAST_EXPECT(scheduler.
step_for(1s));
66 BEAST_EXPECT(scheduler.
now() == (start + 3s));
69 BEAST_EXPECT(scheduler.
step_while([&]() { return seen.size() < 3; }));
71 BEAST_EXPECT(scheduler.
now() == (start + 4s));
74 BEAST_EXPECT(scheduler.
step());
76 BEAST_EXPECT(scheduler.
now() == (start + 8s));
79 BEAST_EXPECT(!scheduler.
step());
81 BEAST_EXPECT(scheduler.
now() == (start + 8s));
85BEAST_DEFINE_TESTSUITE(Scheduler, test,
ripple);
void run() override
Runs the suite.
Simulated discrete-event scheduler.
bool step_one()
Run the scheduler for up to one event.
bool step_while(Function &&func)
Run the scheduler while a condition is true.
cancel_token at(time_point const &when, Function &&f)
Schedule an event at a specific time.
bool step_for(std::chrono::duration< Period, Rep > const &amount)
Run the scheduler until time has elapsed.
time_point now() const
Return the current network time.
bool step_until(time_point const &until)
Run the scheduler until the specified time.
void cancel(cancel_token const &token)
Cancel a timer.
bool step()
Run the scheduler until no events remain.
cancel_token in(duration const &delay, Function &&f)
Schedule an event after a specified duration passes.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.