1
0
Fork 0
forked from blue/lmdbal

Sessions to manage db open state

This commit is contained in:
Blue 2025-05-06 00:22:03 +03:00
parent 3701fb92a1
commit f9902bc0b1
Signed by untrusted user: blue
GPG key ID: 9B203B252A63EE38
13 changed files with 342 additions and 124 deletions

View file

@ -3,6 +3,7 @@
#include "base.h"
#include "storage.h"
#include "cache.h"
#include "session.h"
#include <QString>
#include <QVariant>
@ -34,13 +35,14 @@ protected:
}
static void TearDownTestSuite() {
db->close();
session.close();
db->removeDirectory();
delete db;
db = nullptr;
}
static LMDBAL::Base* db;
static LMDBAL::Session session;
LMDBAL::Storage<uint32_t, uint32_t>* t1;
LMDBAL::Storage<QString, QString>* t2;
@ -50,19 +52,20 @@ protected:
LMDBAL::Base* BaseTest::db = nullptr;
LMDBAL::Session BaseTest::session;
TEST_F(BaseTest, RemovingDirectory) {
EXPECT_EQ(db->removeDirectory(), true);
}
TEST_F(BaseTest, OpeningClosingDatabase) {
EXPECT_EQ(db->ready(), false);
db->open();
EXPECT_EQ(db->ready(), true);
db->close();
EXPECT_EQ(db->ready(), false);
db->open();
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), false);
session = db->open();
EXPECT_EQ(db->opened(), true);
session.close();
EXPECT_EQ(db->opened(), false);
session = db->open();
EXPECT_EQ(db->opened(), true);
}
TEST_F(BaseTest, Flags) {
@ -93,7 +96,7 @@ TEST_F(BaseTest, Flags) {
}
TEST_F(BaseTest, AddingIntegerKey) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
t1->addRecord(1, 2);
t1->addRecord(2, 2);
t1->addRecord(3, 15);
@ -101,7 +104,7 @@ TEST_F(BaseTest, AddingIntegerKey) {
}
TEST_F(BaseTest, AddingQStringKey) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
t2->addRecord("hello", "world");
t2->addRecord("aaa", "gagdfsdf");
t2->addRecord("sdfhga", "DSFFDG");
@ -110,7 +113,7 @@ TEST_F(BaseTest, AddingQStringKey) {
}
TEST_F(BaseTest, AddingKeysToCache) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
c1->addRecord(2, "blah balah");
c1->addRecord(-4, "testing goes brrr");
c1->addRecord(40, "whatever");
@ -119,7 +122,7 @@ TEST_F(BaseTest, AddingKeysToCache) {
}
TEST_F(BaseTest, AddingKeysToVariableCache) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
c2->addRecord("regrets", "blah balah");
c2->addRecord("fossil fingers", 842);
c2->addRecord("preloaded cut", 539.75);
@ -132,7 +135,7 @@ TEST_F(BaseTest, AddingKeysToVariableCache) {
}
TEST_F(BaseTest, AddingRepeatingKey) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
EXPECT_THROW(t1->addRecord(3, 24), LMDBAL::Exist);
EXPECT_EQ(t1->getRecord(3), 15);
@ -148,7 +151,7 @@ TEST_F(BaseTest, AddingRepeatingKey) {
}
TEST_F(BaseTest, GettingNotExistingKeys) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
EXPECT_THROW(t2->getRecord("almonds"), LMDBAL::NotFound);
EXPECT_THROW(t1->getRecord(64), LMDBAL::NotFound);
@ -157,21 +160,21 @@ TEST_F(BaseTest, GettingNotExistingKeys) {
}
TEST_F(BaseTest, Persistence) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
uint32_t t1Size = t1->count();
uint32_t t2Size = t2->count();
uint32_t c1Size = c1->count();
uint32_t c2Size = c2->count();
db->close();
delete db;
EXPECT_EQ(session.opened(), false);
db = new LMDBAL::Base("testBase");
t1 = db->addStorage<uint32_t, uint32_t>("table1");
t2 = db->addStorage<QString, QString>("table2");
c1 = db->addCache<int8_t, std::string>("cache1");
c2 = db->addCache<std::string, QVariant>("cache2");
db->open();
session = db->open();
EXPECT_EQ(t1->count(), t1Size);
EXPECT_EQ(t1->getRecord(3), 15);
@ -212,7 +215,7 @@ TEST_F(BaseTest, Persistence) {
}
TEST_F(BaseTest, CountAndDrop) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
EXPECT_EQ(t1->count(), 3);
EXPECT_EQ(t2->count(), 4);
EXPECT_EQ(c1->count(), 4);
@ -237,7 +240,7 @@ TEST_F(BaseTest, CountAndDrop) {
}
TEST_F(BaseTest, Change) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
EXPECT_EQ(t1->count(), 1);
EXPECT_EQ(t2->count(), 1);
EXPECT_EQ(c1->count(), 2);
@ -283,7 +286,7 @@ TEST_F(BaseTest, Change) {
}
TEST_F(BaseTest, Force) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
EXPECT_EQ(t1->forceRecord(58, 35), false); //changing
EXPECT_EQ(t1->forceRecord(68, 36), true); //adding
@ -318,7 +321,7 @@ TEST_F(BaseTest, Force) {
}
TEST_F(BaseTest, ReadAll) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
std::map<uint32_t, uint32_t> m1 = t1->readAll();
std::map<QString, QString> m2 = t2->readAll();
@ -349,7 +352,7 @@ TEST_F(BaseTest, ReadAll) {
}
TEST_F(BaseTest, ReplaceAll) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
t1->replaceAll({
{7, 48},
@ -417,7 +420,7 @@ TEST_F(BaseTest, ReplaceAll) {
}
TEST_F(BaseTest, AddRecords) {
EXPECT_EQ(db->ready(), true);
EXPECT_EQ(db->opened(), true);
LMDBAL::SizeType s1 = t1->addRecords({
{5, 3},