2017-02-19 01:03:48 +08:00
|
|
|
#include <thread>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "transactions/engine.hpp"
|
|
|
|
#include "utils/assert.hpp"
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
// (try to) test correctness of the transaction life cycle
|
|
|
|
constexpr int THREADS = 16;
|
|
|
|
constexpr int TRANSACTIONS = 10;
|
|
|
|
|
|
|
|
tx::Engine engine;
|
|
|
|
std::vector<uint64_t> sums;
|
|
|
|
|
|
|
|
sums.resize(THREADS);
|
|
|
|
|
|
|
|
auto f = [&engine, &sums](int idx, int n) {
|
|
|
|
uint64_t sum = 0;
|
|
|
|
|
|
|
|
for (int i = 0; i < n; ++i) {
|
2017-03-06 21:17:55 +08:00
|
|
|
auto t = engine.begin();
|
|
|
|
sum += t->id;
|
|
|
|
engine.commit(*t);
|
2017-02-19 01:03:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
sums[idx] = sum;
|
|
|
|
};
|
|
|
|
|
|
|
|
std::vector<std::thread> threads;
|
|
|
|
|
|
|
|
for (int i = 0; i < THREADS; ++i)
|
|
|
|
threads.push_back(std::thread(f, i, TRANSACTIONS));
|
|
|
|
|
2017-03-24 00:34:44 +08:00
|
|
|
for (auto &thread : threads) thread.join();
|
2017-02-19 01:03:48 +08:00
|
|
|
|
|
|
|
uint64_t sum_computed = 0;
|
|
|
|
|
|
|
|
for (int i = 0; i < THREADS; ++i) sum_computed += sums[i];
|
|
|
|
|
|
|
|
uint64_t sum_actual = 0;
|
2017-03-24 00:34:44 +08:00
|
|
|
for (uint64_t i = 1; i <= THREADS * TRANSACTIONS; ++i) sum_actual += i;
|
2017-02-19 01:03:48 +08:00
|
|
|
|
|
|
|
std::cout << sum_computed << " " << sum_actual << std::endl;
|
|
|
|
permanent_assert(sum_computed == sum_actual, "sums have to be the same");
|
|
|
|
}
|