1
0
mirror of https://github.com/mariadb-corporation/mariadb-columnstore-engine.git synced 2025-04-20 09:07:44 +03:00

172 lines
5.1 KiB
C++

/* Copyright (C) 2024 MariaDB Corporation
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; version 2 of
the License.
This program 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 this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
MA 02110-1301, USA. */
#include <vector>
#include "fdbcs.hpp"
using namespace std;
using namespace FDBCS;
using std::chrono::duration;
using std::chrono::duration_cast;
using std::chrono::high_resolution_clock;
using std::chrono::milliseconds;
// #define TEST_PERF 1
template <typename T>
static void assert_internal(const T& value, const std::string& errMessage)
{
if (!value)
{
std::cerr << errMessage << std::endl;
abort();
}
}
static std::string generateBlob(const uint32_t len)
{
std::string blob;
blob.reserve(len);
for (uint32_t i = 0; i < len; ++i)
{
blob.push_back('a' + (i % 26));
}
return blob;
}
static void testBlobHandler(std::shared_ptr<FDBCS::FDBDataBase> db)
{
#ifdef TEST_PERF
std::vector<uint32_t> blobSizes{0, 1, 11, 101, 1001, 10001, 100001, 1000001, 10000001, 100000001};
std::vector<uint32_t> blockSizes{10000, 100000};
#else
std::vector<uint32_t> blobSizes{0, 1, 10001, 100001, 10000001, 100000001};
std::vector<uint32_t> blockSizes{100000};
#endif
for (auto blobSize : blobSizes)
{
for (auto blockSize : blockSizes)
{
std::string rootKey = "root";
auto blobA = generateBlob(blobSize);
std::shared_ptr<BoostUIDKeyGenerator> gen = std::make_shared<BoostUIDKeyGenerator>();
BlobHandler handler(gen, blockSize);
#ifdef TEST_PERF
auto t1 = high_resolution_clock::now();
#endif
handler.writeBlob(db, rootKey, blobA);
#ifdef TEST_PERF
auto t2 = high_resolution_clock::now();
auto ms_int = duration_cast<milliseconds>(t2 - t1);
std::cout << "Write blob time: " << ms_int.count() << std::endl;
t1 = high_resolution_clock::now();
#endif
auto p = handler.readBlob(db, rootKey);
#ifdef TEST_PERF
t2 = high_resolution_clock::now();
cout << "size readed " << p.second.size() << endl;
#endif
assert_internal(p.second == blobA, "Blobs not equal");
#ifdef TEST_PERF
ms_int = duration_cast<milliseconds>(t2 - t1);
std::cout << "Read blob time: " << ms_int.count() << std::endl;
t1 = high_resolution_clock::now();
#endif
assert_internal(handler.removeBlob(db, rootKey), "Remove blob error");
#ifdef TEST_PERF
t2 = high_resolution_clock::now();
ms_int = duration_cast<milliseconds>(t2 - t1);
std::cout << "Remove blob time: " << ms_int.count() << std::endl;
#endif
p = handler.readBlob(db, rootKey);
assert_internal(!p.first, "Blob present after remove");
}
}
}
int main()
{
std::string path = "/etc/foundationdb/fdb.cluster";
assert_internal(setAPIVersion(), "Set api version failed.");
FDBNetwork netWork;
// Create and run network.
assert_internal(netWork.setUpAndRunNetwork(), "Set up network failed.");
// Create database.
auto db = DataBaseCreator::createDataBase(path);
assert_internal(db, "Cannot create FDB.");
assert_internal(db->isDataBaseReady(), "FDB is down.");
const std::vector<std::pair<std::string, std::string>> kvArray{
{"key1", "value1"}, {"key2", "value2"}, {"key3", "value3"}};
const std::string endKey = "key4";
// Set a key/value.
{
auto tnx = db->createTransaction();
tnx->set(kvArray[0].first, kvArray[0].second);
assert_internal(tnx->commit(), "Cannot commit set().");
}
// Get a value by a key.
{
auto tnx = db->createTransaction();
auto p = tnx->get(kvArray[0].first);
assert_internal(p.first, "get() failed.");
assert_internal(p.second == kvArray[0].second, "get(): keys are not matched.");
}
// Remove a key.
{
auto tnx = db->createTransaction();
tnx->remove(kvArray[0].first);
assert_internal(tnx->commit(), "Cannot commit remove().");
}
// Check that key is not presetnt anymore.
{
auto tnx = db->createTransaction();
auto p = tnx->get(kvArray[0].first);
assert_internal(!p.first, "Key exists after remove().");
}
// Remove range.
for (const auto& [key, value] : kvArray)
{
{
auto tnx = db->createTransaction();
tnx->set(key, value);
assert_internal(tnx->commit(), "Cannot commit set() for range.");
}
}
{
auto tnx = db->createTransaction();
tnx->removeRange(kvArray.front().first, endKey);
assert_internal(tnx->commit(), "Cannot commit removeRange().");
}
for (const auto& [key, value] : kvArray)
{
{
auto tnx = db->createTransaction();
auto rPair = tnx->get(key);
assert_internal(!rPair.first, "Key exists after remove range.");
}
}
testBlobHandler(db);
return 0;
}