diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/GpgCoreTestKeygen.cpp | 76 | ||||
-rw-r--r-- | test/GpgFrontendTest.h | 23 |
2 files changed, 92 insertions, 7 deletions
diff --git a/test/GpgCoreTestKeygen.cpp b/test/GpgCoreTestKeygen.cpp index 05d77af1..b703ee40 100644 --- a/test/GpgCoreTestKeygen.cpp +++ b/test/GpgCoreTestKeygen.cpp @@ -33,6 +33,7 @@ TEST_F(GpgCoreTest, GenerateKeyTest) { keygen_info->setName("foo"); keygen_info->setEmail("[email protected]"); keygen_info->setComment(""); + keygen_info->setKeySize(1024); keygen_info->setAlgo("rsa"); keygen_info->setNonExpired(true); keygen_info->setNonPassPhrase(true); @@ -50,3 +51,78 @@ TEST_F(GpgCoreTest, GenerateKeyTest) { ASSERT_TRUE(key.good()); key_opera.DeleteKey(fpr); } + +TEST_F(GpgCoreTest, GenerateKeyTest_1) { + auto& key_opera = GpgFrontend::GpgKeyOpera::GetInstance(default_channel); + auto keygen_info = std::make_unique<GpgFrontend::GenKeyInfo>(); + keygen_info->setName("foo"); + keygen_info->setEmail("[email protected]"); + keygen_info->setComment("hello gpgfrontend"); + keygen_info->setAlgo("rsa"); + keygen_info->setKeySize(4096); + keygen_info->setNonExpired(false); + keygen_info->setExpired(boost::posix_time::second_clock::local_time() + + boost::posix_time::hours(24)); + keygen_info->setNonPassPhrase(false); + + GpgFrontend::GpgGenKeyResult result = nullptr; + auto err = GpgFrontend::check_gpg_error_2_err_code( + key_opera.GenerateKey(keygen_info, result)); + ASSERT_EQ(err, GPG_ERR_NO_ERROR); + + auto fpr = result->fpr; + ASSERT_FALSE(fpr == nullptr); + + auto key = + GpgFrontend::GpgKeyGetter::GetInstance(default_channel).GetKey(fpr); + ASSERT_TRUE(key.good()); + key_opera.DeleteKey(fpr); +} + +TEST_F(GpgCoreTest, GenerateKeyTest_4) { + auto& key_opera = GpgFrontend::GpgKeyOpera::GetInstance(default_channel); + auto keygen_info = std::make_unique<GpgFrontend::GenKeyInfo>(); + keygen_info->setName("foo"); + keygen_info->setEmail("[email protected]"); + keygen_info->setComment(""); + keygen_info->setAlgo("dsa"); + keygen_info->setNonExpired(true); + keygen_info->setNonPassPhrase(false); + + GpgFrontend::GpgGenKeyResult result = nullptr; + auto err = GpgFrontend::check_gpg_error_2_err_code( + key_opera.GenerateKey(keygen_info, result)); + ASSERT_EQ(err, GPG_ERR_NO_ERROR); + + auto fpr = result->fpr; + ASSERT_FALSE(fpr == nullptr); + + auto key = + GpgFrontend::GpgKeyGetter::GetInstance(default_channel).GetKey(fpr); + ASSERT_TRUE(key.good()); + key_opera.DeleteKey(fpr); +} + +TEST_F(GpgCoreTest, GenerateKeyTest_5) { + auto& key_opera = GpgFrontend::GpgKeyOpera::GetInstance(default_channel); + auto keygen_info = std::make_unique<GpgFrontend::GenKeyInfo>(); + keygen_info->setName("foo"); + keygen_info->setEmail("[email protected]"); + keygen_info->setComment(""); + keygen_info->setAlgo("ed25519"); + keygen_info->setNonExpired(true); + keygen_info->setNonPassPhrase(false); + + GpgFrontend::GpgGenKeyResult result = nullptr; + auto err = GpgFrontend::check_gpg_error_2_err_code( + key_opera.GenerateKey(keygen_info, result)); + ASSERT_EQ(err, GPG_ERR_NO_ERROR); + + auto fpr = result->fpr; + ASSERT_FALSE(fpr == nullptr); + + auto key = + GpgFrontend::GpgKeyGetter::GetInstance(default_channel).GetKey(fpr); + ASSERT_TRUE(key.good()); + key_opera.DeleteKey(fpr); +} diff --git a/test/GpgFrontendTest.h b/test/GpgFrontendTest.h index 83778ee6..84476106 100644 --- a/test/GpgFrontendTest.h +++ b/test/GpgFrontendTest.h @@ -40,6 +40,7 @@ #include "gpg/GpgConstants.h" #include "gpg/function/GpgKeyImportExporter.h" +#include "gpg/function/GpgKeyOpera.h" class GpgCoreTest : public ::testing::Test { protected: @@ -70,6 +71,10 @@ class GpgCoreTest : public ::testing::Test { defaultConf.setToDefault(); el::Loggers::reconfigureLogger("default", defaultConf); + defaultConf.setGlobally(el::ConfigurationType::Format, + "%datetime %level %func %msg"); + el::Loggers::reconfigureLogger("default", defaultConf); + using namespace libconfig; Config cfg; ASSERT_NO_THROW(cfg.readFile(config_path.c_str())); @@ -90,12 +95,18 @@ class GpgCoreTest : public ::testing::Test { import_data_alone(); } - void TearDown() override {} + void TearDown() override { + auto key_ids = std::make_unique<GpgFrontend::KeyIdArgsList>(); + key_ids->push_back("81704859182661FB"); + key_ids->push_back("06F1C7E7240C94E8"); + key_ids->push_back("8465C55B25C9B7D1"); + key_ids->push_back("021D89771B680FFB"); + GpgFrontend::GpgKeyOpera::GetInstance(default_channel) + .DeleteKeys(std::move(key_ids)); + } private: void import_data() { - GpgFrontend::GpgContext::GetInstance(default_channel) - .SetPassphraseCb(GpgFrontend::GpgContext::test_passphrase_cb); for (const auto& secret_key : secret_keys_) { auto secret_key_copy = std::make_unique<GpgFrontend::ByteArray>(*secret_key); @@ -105,8 +116,6 @@ class GpgCoreTest : public ::testing::Test { } void import_data_alone() { - GpgFrontend::GpgContext::GetInstance(gpg_alone_channel) - .SetPassphraseCb(GpgFrontend::GpgContext::test_passphrase_cb); for (auto& secret_key : secret_keys_) { auto secret_key_copy = std::make_unique<GpgFrontend::ByteArray>(*secret_key); @@ -157,6 +166,7 @@ class GpgCoreTest : public ::testing::Test { args.independent_database = true; args.db_path = db_path.string(); args.gpg_path = gpg_path.string(); + args.test_mode = true; return std::make_unique<GpgFrontend::GpgContext>(args); }); } @@ -181,8 +191,7 @@ class GpgCoreTest : public ::testing::Test { GpgFrontend::GpgContext::CreateInstance( default_channel, [&]() -> std::unique_ptr<GpgFrontend::GpgContext> { GpgFrontend::GpgContextInitArgs args; - args.independent_database = true; - args.db_path = db_path.string(); + args.test_mode = true; return std::make_unique<GpgFrontend::GpgContext>(args); }); } |