/*
* Copyright (C) 2018 ScyllaDB
*/
/*
* This file is part of Scylla.
*
* Scylla is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Scylla is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Scylla. If not, see .
*/
#pragma once
#include
#include
#include
namespace tests::random {
namespace internal {
std::random_device::result_type get_seed()
{
std::random_device rd;
auto seed = rd();
std::cout << "tests::random seed = " << seed << "\n";
return seed;
}
}
static std::default_random_engine gen(internal::get_seed());
template
T get_int() {
std::uniform_int_distribution dist;
return dist(gen);
}
template
T get_int(T max) {
std::uniform_int_distribution dist(0, max);
return dist(gen);
}
template
T get_int(T min, T max) {
std::uniform_int_distribution dist(min, max);
return dist(gen);
}
bool get_bool() {
static std::bernoulli_distribution dist;
return dist(gen);
}
bytes get_bytes(size_t n) {
bytes b(bytes::initialized_later(), n);
boost::generate(b, [] { return get_int(); });
return b;
}
bytes get_bytes() {
return get_bytes(get_int(128 * 1024));
}
sstring get_sstring(size_t n) {
sstring str(sstring::initialized_later(), n);
boost::generate(str, [] { return get_int('a', 'z'); });
return str;
}
sstring get_sstring() {
return get_sstring(get_int(1024));
}
}