Files
sqlgen/tests/sqlite/test_cache.cpp
Dr. Patrick Urbanke (劉自成) 86ee6e2bcc Added a caching strategy (#83)
2025-11-01 14:30:58 +01:00

46 lines
1.0 KiB
C++

#include <gtest/gtest.h>
#include <rfl.hpp>
#include <rfl/json.hpp>
#include <sqlgen.hpp>
#include <sqlgen/sqlite.hpp>
#include <vector>
namespace test_cache {
struct User {
std::string name;
int age;
};
TEST(sqlite, test_cache) {
const auto conn = sqlgen::sqlite::connect();
const auto user = User{.name = "John", .age = 30};
sqlgen::write(conn, user);
using namespace sqlgen;
using namespace sqlgen::literals;
const auto query = sqlgen::read<User> | where("name"_c == "John");
const auto cached_query = sqlgen::cache<100>(query);
const auto user1 = conn.and_then(cache<100>(query)).value();
EXPECT_EQ(cached_query.cache(conn).size(), 1);
const auto user2 = cached_query(conn).value();
const auto user3 = cached_query(conn).value();
EXPECT_EQ(user1.name, "John");
EXPECT_EQ(user1.age, 30);
EXPECT_EQ(user2.name, "John");
EXPECT_EQ(user2.age, 30);
EXPECT_EQ(cached_query.cache(conn).size(), 1);
EXPECT_EQ(user3.name, "John");
EXPECT_EQ(user3.age, 30);
}
} // namespace test_cache