aboutsummaryrefslogtreecommitdiffstats
path: root/src/test/GpgFrontendTest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/GpgFrontendTest.cpp')
-rw-r--r--src/test/GpgFrontendTest.cpp113
1 files changed, 113 insertions, 0 deletions
diff --git a/src/test/GpgFrontendTest.cpp b/src/test/GpgFrontendTest.cpp
new file mode 100644
index 00000000..95b4179a
--- /dev/null
+++ b/src/test/GpgFrontendTest.cpp
@@ -0,0 +1,113 @@
+/**
+ * Copyright (C) 2021 Saturneric <[email protected]>
+ *
+ * This file is part of GpgFrontend.
+ *
+ * GpgFrontend 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, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * GpgFrontend 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 GpgFrontend. If not, see <https://www.gnu.org/licenses/>.
+ *
+ * The initial version of the source code is inherited from
+ * the gpg4usb project, which is under GPL-3.0-or-later.
+ *
+ * All the source code of GpgFrontend was modified and released by
+ * Saturneric <[email protected]> starting on May 12, 2021.
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ *
+ */
+
+#include "GpgFrontendTest.h"
+
+#include <gtest/gtest.h>
+
+#include "core/GpgConstants.h"
+#include "core/function/GlobalSettingStation.h"
+#include "core/function/basic/ChannelObject.h"
+#include "core/function/gpg/GpgContext.h"
+#include "core/function/gpg/GpgKeyImportExporter.h"
+#include "core/utils/IOUtils.h"
+
+namespace GpgFrontend::Test {
+
+auto GenerateRandomString(size_t length) -> QString {
+ const QString characters =
+ "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
+ std::random_device random_device;
+ std::mt19937 generator(random_device());
+ std::uniform_int_distribution<> distribution(0, characters.size() - 1);
+
+ QString random_string;
+ for (size_t i = 0; i < length; ++i) {
+ random_string += characters[distribution(generator)];
+ }
+
+ return random_string;
+}
+
+void ConfigureGpgContext() {
+ auto db_path = QDir(QDir::tempPath() + "/" + GenerateRandomString(12));
+ GF_TEST_LOG_DEBUG("setting up new database path for test case: {}",
+ db_path.path());
+
+ if (db_path.exists()) db_path.rmdir(".");
+ db_path.mkpath(".");
+
+ GpgContext::CreateInstance(
+ kGpgFrontendDefaultChannel, [=]() -> ChannelObjectPtr {
+ GpgContextInitArgs args;
+ args.test_mode = true;
+ args.offline_mode = true;
+ args.db_path = db_path.path();
+
+ return ConvertToChannelObjectPtr<>(SecureCreateUniqueObject<GpgContext>(
+ args, kGpgFrontendDefaultChannel));
+ });
+}
+
+void ImportPrivateKeys(const QString& data_path, QSettings settings) {
+ auto key_files = QDir(":/test/key").entryList();
+
+ for (const auto& key_file : key_files) {
+ auto [success, gf_buffer] =
+ ReadFileGFBuffer(QString(":/test/key") + "/" + key_file);
+ if (success) {
+ GpgKeyImportExporter::GetInstance(kGpgFrontendDefaultChannel)
+ .ImportKey(gf_buffer);
+ } else {
+ GF_TEST_LOG_ERROR("read from key file failed: {}", key_file);
+ }
+ }
+}
+
+void SetupGlobalTestEnv() {
+ auto app_path = GlobalSettingStation::GetInstance().GetAppDir();
+ auto test_path = app_path + "/test";
+ auto test_config_path = test_path + "/conf/test.ini";
+ auto test_data_path = test_path + "/data";
+
+ GF_TEST_LOG_INFO("test config file path: {}", test_config_path);
+ GF_TEST_LOG_INFO("test data file path: {}", test_data_path);
+
+ ImportPrivateKeys(test_data_path,
+ QSettings(test_config_path, QSettings::IniFormat));
+}
+
+auto ExecuteAllTestCase(GpgFrontendContext args) -> int {
+ ConfigureGpgContext();
+ SetupGlobalTestEnv();
+
+ testing::InitGoogleTest(&args.argc, args.argv);
+ return RUN_ALL_TESTS();
+}
+
+} // namespace GpgFrontend::Test \ No newline at end of file