-
Notifications
You must be signed in to change notification settings - Fork 316
/
Copy pathdeadline_benchmark.cpp
55 lines (39 loc) · 1.59 KB
/
deadline_benchmark.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include <benchmark/benchmark.h>
#include <chrono>
#include <userver/engine/deadline.hpp>
#include <utils/gbench_auxilary.hpp>
USERVER_NAMESPACE_BEGIN
namespace {
void deadline_from_duration(benchmark::State& state, std::chrono::nanoseconds duration) {
for ([[maybe_unused]] auto _ : state) {
auto deadline = engine::Deadline::FromDuration(duration);
benchmark::DoNotOptimize(deadline);
}
}
void deadline_is_reached(benchmark::State& state, std::chrono::nanoseconds duration) {
auto deadline = engine::Deadline::FromDuration(duration);
for ([[maybe_unused]] auto _ : state) {
bool is_reached = deadline.IsReached();
benchmark::DoNotOptimize(is_reached);
}
}
void deadline_1us_interval_construction(benchmark::State& state) {
deadline_from_duration(state, std::chrono::microseconds{1});
}
void deadline_20ms_interval_construction(benchmark::State& state) {
deadline_from_duration(state, std::chrono::milliseconds{20});
}
void deadline_1us_interval_reached(benchmark::State& state) {
deadline_is_reached(state, std::chrono::microseconds{1});
}
void deadline_20ms_interval_reached(benchmark::State& state) {
deadline_is_reached(state, std::chrono::milliseconds{20});
}
void deadline_100s_interval_reached(benchmark::State& state) { deadline_is_reached(state, std::chrono::seconds{100}); }
} // namespace
BENCHMARK(deadline_1us_interval_construction);
BENCHMARK(deadline_20ms_interval_construction);
BENCHMARK(deadline_1us_interval_reached);
BENCHMARK(deadline_20ms_interval_reached);
BENCHMARK(deadline_100s_interval_reached);
USERVER_NAMESPACE_END