2017-06-21 17:29:13 +08:00
|
|
|
#include <benchmark/benchmark.h>
|
|
|
|
#include <benchmark/benchmark_api.h>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
|
2017-04-10 18:12:40 +08:00
|
|
|
#include "mvcc/record.hpp"
|
|
|
|
#include "mvcc/version_list.hpp"
|
2017-11-29 23:03:42 +08:00
|
|
|
#include "transactions/engine_master.hpp"
|
2017-04-10 18:12:40 +08:00
|
|
|
|
2017-09-27 20:45:50 +08:00
|
|
|
class Prop : public mvcc::Record<Prop> {
|
|
|
|
public:
|
|
|
|
Prop() = default;
|
|
|
|
Prop *CloneData() { return new Prop; }
|
|
|
|
};
|
2017-04-10 18:12:40 +08:00
|
|
|
|
|
|
|
// Benchmark multiple updates, and finds, focused on finds.
|
|
|
|
// This a rather weak test, but I'm not sure what's the better way to test this
|
|
|
|
// in the future.
|
|
|
|
// TODO(dgleich): Refresh this.
|
|
|
|
void MvccMix(benchmark::State &state) {
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
state.PauseTiming();
|
2017-11-29 23:03:42 +08:00
|
|
|
tx::MasterEngine engine;
|
2017-06-12 16:21:19 +08:00
|
|
|
auto t1 = engine.Begin();
|
2017-11-13 16:50:49 +08:00
|
|
|
mvcc::VersionList<Prop> version_list(*t1, 0);
|
2017-04-10 18:12:40 +08:00
|
|
|
|
2017-11-29 23:03:42 +08:00
|
|
|
engine.Commit(*t1);
|
2017-06-12 16:21:19 +08:00
|
|
|
auto t2 = engine.Begin();
|
2017-04-10 18:12:40 +08:00
|
|
|
|
|
|
|
state.ResumeTiming();
|
|
|
|
version_list.update(*t2);
|
|
|
|
state.PauseTiming();
|
|
|
|
|
|
|
|
state.ResumeTiming();
|
|
|
|
version_list.find(*t2);
|
|
|
|
state.PauseTiming();
|
|
|
|
|
2017-11-29 23:03:42 +08:00
|
|
|
engine.Abort(*t2);
|
2017-04-10 18:12:40 +08:00
|
|
|
|
2017-06-12 16:21:19 +08:00
|
|
|
auto t3 = engine.Begin();
|
2017-04-10 18:12:40 +08:00
|
|
|
state.ResumeTiming();
|
|
|
|
version_list.update(*t3);
|
|
|
|
state.PauseTiming();
|
2017-06-12 16:21:19 +08:00
|
|
|
auto t4 = engine.Begin();
|
2017-04-10 18:12:40 +08:00
|
|
|
|
|
|
|
// Repeat find state.range(0) number of times.
|
|
|
|
state.ResumeTiming();
|
|
|
|
for (int i = 0; i < state.range(0); ++i) {
|
|
|
|
version_list.find(*t4);
|
|
|
|
}
|
|
|
|
state.PauseTiming();
|
|
|
|
|
2017-11-29 23:03:42 +08:00
|
|
|
engine.Commit(*t3);
|
|
|
|
engine.Commit(*t4);
|
2017-04-10 18:12:40 +08:00
|
|
|
state.ResumeTiming();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
BENCHMARK(MvccMix)
|
|
|
|
->RangeMultiplier(2) // Multiply next range testdata size by 2
|
|
|
|
->Range(1 << 14, 1 << 23) // 1<<14, 1<<15, 1<<16, ...
|
|
|
|
->Unit(benchmark::kMillisecond);
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
DEFINE_string(hehehe, "bok", "ne");
|
2017-04-10 18:12:40 +08:00
|
|
|
int main(int argc, char **argv) {
|
2017-06-21 17:29:13 +08:00
|
|
|
google::InitGoogleLogging(argv[0]);
|
2017-04-10 18:12:40 +08:00
|
|
|
|
|
|
|
::benchmark::Initialize(&argc, argv);
|
|
|
|
::benchmark::RunSpecifiedBenchmarks();
|
|
|
|
return 0;
|
|
|
|
}
|