20 #include <ripple/basics/ByteUtilities.h>
21 #include <ripple/beast/unit_test.h>
22 #include <test/csf/Scheduler.h>
35 using namespace std::chrono_literals;
39 scheduler.
in(1s, [&] { seen.
insert(1); });
40 scheduler.
in(2s, [&] { seen.
insert(2); });
41 auto token = scheduler.
in(3s, [&] { seen.
insert(3); });
42 scheduler.
at(scheduler.
now() + 4s, [&] { seen.insert(4); });
43 scheduler.
at(scheduler.
now() + 8s, [&] { seen.insert(8); });
45 auto start = scheduler.
now();
48 BEAST_EXPECT(seen.
empty());
51 BEAST_EXPECT(scheduler.
now() == (start + 1s));
56 BEAST_EXPECT(scheduler.
now() == (start + 1s));
59 BEAST_EXPECT(scheduler.
step_for(1s));
61 BEAST_EXPECT(scheduler.
now() == (start + 2s));
65 BEAST_EXPECT(scheduler.
step_for(1s));
67 BEAST_EXPECT(scheduler.
now() == (start + 3s));
70 BEAST_EXPECT(scheduler.
step_while([&]() { return seen.size() < 3; }));
72 BEAST_EXPECT(scheduler.
now() == (start + 4s));
75 BEAST_EXPECT(scheduler.
step());
77 BEAST_EXPECT(scheduler.
now() == (start + 8s));
80 BEAST_EXPECT(!scheduler.
step());
82 BEAST_EXPECT(scheduler.
now() == (start + 8s));
void cancel(cancel_token const &token)
Cancel a timer.
bool step_while(Function &&func)
Run the scheduler while a condition is true.
Simulated discrete-event scheduler.
bool step_one()
Run the scheduler for up to one event.
cancel_token in(duration const &delay, Function &&f)
Schedule an event after a specified duration passes.
bool step_until(time_point const &until)
Run the scheduler until the specified time.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
cancel_token at(time_point const &when, Function &&f)
Schedule an event at a specific time.
bool step()
Run the scheduler until no events remain.
time_point now() const
Return the current network time.
bool step_for(std::chrono::duration< Period, Rep > const &amount)
Run the scheduler until time has elapsed.
BEAST_DEFINE_TESTSUITE(DeliverMin, app, ripple)