20 #include <ripple/beast/unit_test.h>
22 #include <test/csf/Scheduler.h>
33 using namespace std::chrono_literals;
37 scheduler.
in(1s, [&] { seen.
insert(1); });
38 scheduler.
in(2s, [&] { seen.
insert(2); });
39 auto token = scheduler.
in(3s, [&] { seen.
insert(3); });
40 scheduler.
at(scheduler.
now() + 4s, [&] { seen.insert(4); });
41 scheduler.
at(scheduler.
now() + 8s, [&] { seen.insert(8); });
43 auto start = scheduler.
now();
46 BEAST_EXPECT(seen.
empty());
49 BEAST_EXPECT(scheduler.
now() == (start + 1s));
54 BEAST_EXPECT(scheduler.
now() == (start + 1s));
57 BEAST_EXPECT(scheduler.
step_for(1s));
59 BEAST_EXPECT(scheduler.
now() == (start + 2s));
63 BEAST_EXPECT(scheduler.
step_for(1s));
65 BEAST_EXPECT(scheduler.
now() == (start + 3s));
68 BEAST_EXPECT(scheduler.
step_while([&]() { return seen.size() < 3; }));
70 BEAST_EXPECT(scheduler.
now() == (start + 4s));
73 BEAST_EXPECT(scheduler.
step());
75 BEAST_EXPECT(scheduler.
now() == (start + 8s));
78 BEAST_EXPECT(!scheduler.
step());
80 BEAST_EXPECT(scheduler.
now() == (start + 8s));
BEAST_DEFINE_TESTSUITE(AccountDelete, app, ripple)
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.