18#define ORAL_FACTORY_SQLITE 1
19#define ORAL_FACTORY_POSTGRES 2
21#if ORAL_FACTORY == ORAL_FACTORY_SQLITE
25#elif ORAL_FACTORY == ORAL_FACTORY_POSTGRES
33#error "Unknown oral tests factory"
37template<
typename T,
typename =
decltype (T {}.AsTuple ())>
40 return left.AsTuple () == right.AsTuple ();
45 template<
typename T,
typename... Args>
48 return QTest::toString (pkey.
Val_);
52#define TOSTRING(n) inline char* toString (const n& rec) { return toString (#n, rec); }
54template<
typename T,
typename TupleType =
decltype (T {}.AsTuple ())>
57 using QTest::toString;
59 QByteArray ba { name };
62 std::apply ([&ba] (
const auto&... args) { (ba.append (
toString (args)).append (
", "), ...); }, t.AsTuple ());
64 if (std::tuple_size<TupleType>::value >= 1)
68 return qstrdup (ba.data ());
75#if ORAL_FACTORY == ORAL_FACTORY_SQLITE
77 db.setDatabaseName (name);
79 throw std::runtime_error {
"cannot create test database" };
84#elif ORAL_FACTORY == ORAL_FACTORY_POSTGRES
89 db.setHostName (
"localhost");
91 db.setUserName (qgetenv (
"TEST_POSTGRES_USERNAME"));
96 throw std::runtime_error {
"cannot create test database" };
107 for (
int i = 0; i < count; ++i)
108 adapted->Insert ({ i, QString::number (i) });
static UTIL_DB_API void DumpError(const QSqlError &error)
Dumps the error to the qWarning() stream.
char * toString(const char *name, const T &t)
auto operator==(const T &left, const T &right)
QSqlQuery RunTextQuery(const QSqlDatabase &db, const QString &text)
Runs the given query text on the given db.
QString GenConnectionName(const QString &base)
Generates an unique thread-safe connection name.
ObjectInfo_ptr< T > AdaptPtr(const QSqlDatabase &db)
detail::SQLite::ImplFactory SQLiteImplFactory
detail::PostgreSQL::ImplFactory PostgreSQLImplFactory
char * toString(const PKey< T, Args... > &pkey)
auto PrepareRecords(QSqlDatabase db, int count=3)
QSqlDatabase MakeDatabase(const QString &name=":memory:")