* -------------------------------------------------------------------------
* This file is part of the MindStudio project.
* Copyright (c) 2025 Huawei Technologies Co.,Ltd.
*
* MindStudio is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
*
* http://license.coscl.org.cn/MulanPSL2
*
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
* -------------------------------------------------------------------------
*/
#ifndef PROFILER_SERVER_DATABASETESTCASEMOCKUTIL_H
#define PROFILER_SERVER_DATABASETESTCASEMOCKUTIL_H
#include <iostream>
#include <sqlite3.h>
#include <string>
#include "DatabaseTestConst.h"
namespace Dic::Global::PROFILER::MockUtil {
class DatabaseTestCaseMockUtil {
public:
static void OpenDB(sqlite3 *&db) {
int rc = sqlite3_open(":memory:", &db);
if (rc != SQLITE_OK) {
std::cout << "create db failed" << std::endl;
sqlite3_close(db);
}
}
static void CreateTable(sqlite3 *&db, const std::string &sql) {
int rc = sqlite3_exec(db, sql.c_str(), nullptr, nullptr, nullptr);
if (rc != SQLITE_OK) {
std::cout << "Create table is failed" << std::endl;
sqlite3_close(db);
}
}
static void CreateTablesFromList(sqlite3 *&db, const std::vector<TableName> &list) {
for (const auto &item : list) {
if (CREATE_TABLE_SQL_MAP.find(item) != CREATE_TABLE_SQL_MAP.end()) {
CreateTable(db, CREATE_TABLE_SQL_MAP.at(item));
}
}
}
static void ExecuteSql(sqlite3 *&db, const std::string &sql) {
int rc = sqlite3_exec(db, sql.c_str(), nullptr, nullptr, nullptr);
if (rc != SQLITE_OK) {
std::cout << "Execute sql is failed" << std::endl;
sqlite3_free(nullptr);
sqlite3_close(db);
}
}
static void OpenDBAndCreateTable(sqlite3 *&db, const std::string &sql) {
OpenDB(db);
CreateTable(db, sql);
}
static void InsertData(sqlite3 *&db, const std::string &sql) {
int rc = sqlite3_exec(db, sql.c_str(), nullptr, nullptr, nullptr);
if (rc != SQLITE_OK) {
std::cout << "Insert data is failed" << std::endl;
sqlite3_free(nullptr);
sqlite3_close(db);
return;
}
}
};
}
#endif