aboutsummaryrefslogtreecommitdiffstats
path: root/lang/qt/tests/t-addexistingsubkey.cpp
diff options
context:
space:
mode:
authorIngo Klöcker <[email protected]>2025-02-03 09:49:25 +0000
committerIngo Klöcker <[email protected]>2025-02-03 09:55:40 +0000
commit763d5f5d6a88ec938b8678ab597e1404af724553 (patch)
tree7f3791e3560bd3a51470494bf965b9f9a40a87bd /lang/qt/tests/t-addexistingsubkey.cpp
parentbuild: Fix generation of ChangeLog on secondary working trees (diff)
downloadgpgme-763d5f5d6a88ec938b8678ab597e1404af724553.tar.gz
gpgme-763d5f5d6a88ec938b8678ab597e1404af724553.zip
cpp,qt: Remove C++ and Qt bindings
* README: Update. * configure.ac: Remove checks, variables and file generations related to the C++/Qt bindings. Remove cpp and qt* from available_languages and default_languages. * lang/Makefile.am (DIST_SUBDIRS): Remove cpp and qt. * lang/cpp, lang/qt: Remove. * m4/ax_check_compile_flag.m4, m4/ax_cxx_compile_stdcxx.m4, m4/ax_gcc_func_attribute.m4, m4/pkg.m4, m4/qt5.m4, m4/qt6.m4: Remove. -- The C++ and Qt bindings have been moved to separate Git repositories: gpgmepp and gpgmeqt. GnuPG-bug-id: 7262
Diffstat (limited to 'lang/qt/tests/t-addexistingsubkey.cpp')
-rw-r--r--lang/qt/tests/t-addexistingsubkey.cpp266
1 files changed, 0 insertions, 266 deletions
diff --git a/lang/qt/tests/t-addexistingsubkey.cpp b/lang/qt/tests/t-addexistingsubkey.cpp
deleted file mode 100644
index df620ddb..00000000
--- a/lang/qt/tests/t-addexistingsubkey.cpp
+++ /dev/null
@@ -1,266 +0,0 @@
-/* t-addexistingsubkey.cpp
-
- This file is part of qgpgme, the Qt API binding for gpgme
- Copyright (c) 2022 g10 Code GmbH
- Software engineering by Ingo Klöcker <[email protected]>
-
- QGpgME 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 2 of the
- License, or (at your option) any later version.
-
- QGpgME 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 this program; if not, write to the Free Software
- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
-
- In addition, as a special exception, the copyright holders give
- permission to link the code of this program with any edition of
- the Qt library by Trolltech AS, Norway (or with modified versions
- of Qt that use the same license as Qt), and distribute linked
- combinations including the two. You must obey the GNU General
- Public License in all respects for all of the code used other than
- Qt. If you modify this file, you may extend this exception to
- your version of the file, but you are not obligated to do so. If
- you do not wish to do so, delete this exception statement from
- your version.
-*/
-#ifdef HAVE_CONFIG_H
- #include "config.h"
-#endif
-
-#include "t-support.h"
-
-#include "addexistingsubkeyjob.h"
-#include "protocol.h"
-
-#include <QSignalSpy>
-#include <QTest>
-
-#include <gpgme++/context.h>
-#include <gpgme++/data.h>
-#include <gpgme++/engineinfo.h>
-
-#include <algorithm>
-
-using namespace QGpgME;
-using namespace GpgME;
-
-static const char *requiredVersion = "2.3.5";
-
-/* Test keys
- sec# ed25519 2022-01-13 [SC]
- 1CB8C6A0317AA83F44FE009932392C82B814C8E0
- uid [ unknown] [email protected]
- ssb cv25519 2022-01-13 [E]
- ssb cv25519 2022-01-13 [E] [expires: 2100-01-01]
-
- sec ed25519 2022-01-13 [SC]
- C3C87F0A3920B01F9E4450EA2B79F21D4DD10BFC
- uid [ unknown] [email protected]
- ssb cv25519 2022-01-13 [E]
- * generated with
-export GNUPGHOME=$(mktemp -d)
-gpg -K
-gpg --batch --pinentry-mode loopback --passphrase abc --quick-gen-key [email protected] default default never
-fpr=$(gpg -k --with-colons [email protected] | grep ^fpr | head -1 | cut -d ':' -f 10)
-gpg --batch --pinentry-mode loopback --passphrase abc --quick-add-key ${fpr} default default 21000101T120000
-gpg --batch --pinentry-mode loopback --passphrase abc --quick-gen-key [email protected] default default never
-gpg -K
-gpg --export-secret-subkeys --armor --batch --pinentry-mode loopback --passphrase abc --comment [email protected] [email protected] | sed 's/\(.*\)/ "\1\\n"/'
-gpg --export-secret-keys --armor --batch --pinentry-mode loopback --passphrase abc --comment [email protected] [email protected] | sed 's/\(.*\)/ "\1\\n"/'
-#rm -rf ${GNUPGHOME}
-unset GNUPGHOME
-*/
-static const char *testKeyData =
- "-----BEGIN PGP PRIVATE KEY BLOCK-----\n"
- "Comment: [email protected]\n"
- "\n"
- "lDsEYd/ujBYJKwYBBAHaRw8BAQdAwiZPINTcrpgmu6ZWSaPZlcRSd4nDuofVMhe7\n"
- "c2XrFyT/AGUAR05VAbQWc291cmNlLWtleUBleGFtcGxlLm5ldIiUBBMWCgA8FiEE\n"
- "HLjGoDF6qD9E/gCZMjksgrgUyOAFAmHf7owCGwMFCwkIBwIDIgIBBhUKCQgLAgQW\n"
- "AgMBAh4HAheAAAoJEDI5LIK4FMjgupIA/Au2YEAT9dYdJd0eJCJerG5YAeoB+uBs\n"
- "mBkgr6xXE0bIAP43b6u1Jtvf/Wm3BhRbLd5Tg67Ba4CIZ8ZLGng73FBoBpyLBGHf\n"
- "7owSCisGAQQBl1UBBQEBB0Cpg8Qof/WShxROZZtmPnw24vTk0R8nIAF1CZJ0bG/C\n"
- "SwMBCAf+BwMCtzxziVxQEor8w/VVzHp4/hVSCUyrpiX7Djf04cIMs2bFPduZLgxb\n"
- "c1SXhlgiqU0YBNntbGGNdKjTP6FMbYWq1+NwQm6ZXtC76LPG7syM94h4BBgWCgAg\n"
- "FiEEHLjGoDF6qD9E/gCZMjksgrgUyOAFAmHf7owCGwwACgkQMjksgrgUyOCI0wEA\n"
- "+f56fkvDDUwMOMw7n4+GKpfJXpWhVL08ttccbBOa/9IA/2HYA/78ZaD8E5EyqAEK\n"
- "Aj9Au+2oJu9V5qo92QEoqwYHnIsEYd/vgxIKKwYBBAGXVQEFAQEHQBa9FxJkm/9D\n"
- "xABildkaYMrbJbu8BPk6uv9V8aLmv9FnAwEIB/4HAwIPhcbN8s6OzPz8/g78TrCh\n"
- "xqQb2kygCEj+OQ4/XXU3lus2b5xS5h44LGt99Wisqx+wVPDXmPDJOaxjhHXDmJxd\n"
- "/LplIEhykojSm3uUDxERiH4EGBYKACYWIQQcuMagMXqoP0T+AJkyOSyCuBTI4AUC\n"
- "Yd/vgwIbDAUJkqcQPQAKCRAyOSyCuBTI4IUjAP9BTfOD+jy6lLmzNO9pquRSAxi/\n"
- "PQuglGtpS0LQEJMEOwD+PFnsMe2EtQ+WVSDBeB7O0m61EXeY+RhpuhNtsNXVuwc=\n"
- "=wIPU\n"
- "-----END PGP PRIVATE KEY BLOCK-----\n"
- "-----BEGIN PGP PRIVATE KEY BLOCK-----\n"
- "Comment: [email protected]\n"
- "\n"
- "lIYEYd/v/RYJKwYBBAHaRw8BAQdAKoILWXG3yaLb2EniNKQLUjwsrvy5vgAN299J\n"
- "W5cFbrz+BwMC/uKbCq3sK5H8QVtEQ/IxGmjWNBpy6c8EDlOG4APi4o4VE+bEYD8w\n"
- "J3Kk/lzSm6ZT5vC6DDASks797omjXD+J7zZ0vtTPvheYi/nsVz2UebQWdGFyZ2V0\n"
- "LWtleUBleGFtcGxlLm5ldIiUBBMWCgA8FiEEw8h/CjkgsB+eRFDqK3nyHU3RC/wF\n"
- "AmHf7/0CGwMFCwkIBwIDIgIBBhUKCQgLAgQWAgMBAh4HAheAAAoJECt58h1N0Qv8\n"
- "rXcBAPxnkXqpp4IY3iTKV5XAdo7Uys7U/joUD73rj2XEvgI1AQDhKK4PLxPhf3ki\n"
- "FKU0RA7itxzOH+F8bQ5BdYS49jDPCpyLBGHf7/0SCisGAQQBl1UBBQEBB0Dq9rwA\n"
- "hAA2UFJShFsLFp7+g4uhWDfuDa3VjeIQRM+9QgMBCAf+BwMCMfCTl0LNqsn836t5\n"
- "f2ZHBuMcNs4JWYmdLAIVaewEHq7zhOsX3iB+/yxwu9g2mXc4XUJ1iQzXLOYwgGov\n"
- "8jIovrr01hDkSg4rvM9JKMWdd4h4BBgWCgAgFiEEw8h/CjkgsB+eRFDqK3nyHU3R\n"
- "C/wFAmHf7/0CGwwACgkQK3nyHU3RC/xyfAEAqnMdSv6FTAwAWrYvJqJtSVoEhjMn\n"
- "3c2qMsu34Bk86/MBAKHbLFmdyePvHaxKeO8CkQDoJzK8rYzw3RAmq/5JsQkL\n"
- "=rOVf\n"
- "-----END PGP PRIVATE KEY BLOCK-----\n";
-
-class AddExistingSubkeyJobTest : public QGpgMETest
-{
- Q_OBJECT
-
-private Q_SLOTS:
-
- void initTestCase()
- {
- QGpgMETest::initTestCase();
-
- // set up the test fixture for this test
- qputenv("GNUPGHOME", mGnupgHomeTestFixture.path().toUtf8());
- QVERIFY(importSecretKeys(testKeyData, 2));
- }
-
- void init()
- {
- if (GpgME::engineInfo(GpgME::GpgEngine).engineVersion() < requiredVersion) {
- QSKIP("gpg does not yet support adding an existing subkey to another key via the command API");
- }
-
- // set up a copy of the test fixture for each test function
- mGnupgHomeTestCopy.reset(new QTemporaryDir{});
- QVERIFY(copyKeyrings(mGnupgHomeTestFixture.path(), mGnupgHomeTestCopy->path()));
- qputenv("GNUPGHOME", mGnupgHomeTestCopy->path().toUtf8());
- }
-
- void testAddExistingSubkeyAsync()
- {
- // Get the key the subkey should be added to
- auto key = getTestKey("[email protected]");
- QVERIFY(!key.isNull());
-
- // Get the key with the subkey to add
- auto sourceKey = getTestKey("[email protected]", 3);
- QVERIFY(!sourceKey.isNull());
-
- auto job = std::unique_ptr<AddExistingSubkeyJob>{openpgp()->addExistingSubkeyJob()};
- hookUpPassphraseProvider(job.get());
-
- Error result;
- connect(job.get(), &AddExistingSubkeyJob::result,
- job.get(), [this, &result](const Error &result_) {
- result = result_;
- Q_EMIT asyncDone();
- });
- QVERIFY(!job->start(key, sourceKey.subkey(1)));
- job.release(); // after the job has been started it's on its own
-
- QSignalSpy spy (this, SIGNAL(asyncDone()));
- QVERIFY(spy.wait(QSIGNALSPY_TIMEOUT));
-
- QCOMPARE(result.code(), static_cast<int>(GPG_ERR_NO_ERROR));
- key.update();
- QCOMPARE(key.numSubkeys(), 3u);
- }
-
- void testAddExistingSubkeySync()
- {
- // Get the key the subkey should be added to
- auto key = getTestKey("[email protected]");
- QVERIFY(!key.isNull());
-
- // Get the key with the subkey to add
- auto sourceKey = getTestKey("[email protected]", 3);
- QVERIFY(!sourceKey.isNull());
- auto sourceSubkey = sourceKey.subkey(1);
- QVERIFY(sourceSubkey.expirationTime() == 0);
-
- auto job = std::unique_ptr<AddExistingSubkeyJob>{openpgp()->addExistingSubkeyJob()};
- hookUpPassphraseProvider(job.get());
-
- const auto result = job->exec(key, sourceSubkey);
-
- QCOMPARE(result.code(), static_cast<int>(GPG_ERR_NO_ERROR));
- key.update();
- QCOMPARE(key.numSubkeys(), 3u);
- QCOMPARE(key.subkey(2).expirationTime(), 0);
- }
-
- void testAddExistingSubkeyWithExpiration()
- {
- // Get the key the subkey should be added to
- auto key = getTestKey("[email protected]");
- QVERIFY(!key.isNull());
-
- // Get the key with the subkey to add
- auto sourceKey = getTestKey("[email protected]", 3);
- QVERIFY(!sourceKey.isNull());
- auto sourceSubkey = sourceKey.subkey(2);
- QVERIFY(sourceSubkey.expirationTime() != 0);
-
- auto job = std::unique_ptr<AddExistingSubkeyJob>{openpgp()->addExistingSubkeyJob()};
- hookUpPassphraseProvider(job.get());
-
- const auto result = job->exec(key, sourceSubkey);
-
- if (sourceSubkey.expirationTime() > 0) {
- QCOMPARE(result.code(), static_cast<int>(GPG_ERR_NO_ERROR));
- key.update();
- QCOMPARE(key.numSubkeys(), 3u);
-
- // allow 1 second different expiration because gpg calculates with
- // expiration as difference to current time and takes current time
- // several times
- const auto allowedDeltaTSeconds = 1;
- const auto expectedExpirationRange = std::make_pair(
- uint_least32_t(sourceSubkey.expirationTime()) - allowedDeltaTSeconds,
- uint_least32_t(sourceSubkey.expirationTime()) + allowedDeltaTSeconds);
- const auto actualExpiration = uint_least32_t(key.subkey(2).expirationTime());
- QVERIFY2(actualExpiration >= expectedExpirationRange.first,
- ("actual: " + std::to_string(actualExpiration) +
- "; expected: " + std::to_string(expectedExpirationRange.first)).c_str());
- QVERIFY2(actualExpiration <= expectedExpirationRange.second,
- ("actual: " + std::to_string(actualExpiration) +
- "; expected: " + std::to_string(expectedExpirationRange.second)).c_str());
- } else {
- // on 32-bit systems the expiration date of the test key overflows;
- // in this case we expect an appropriate error code
- QCOMPARE(result.code(), static_cast<int>(GPG_ERR_INV_TIME));
- }
- }
-
-private:
- Key getTestKey(const char *pattern, unsigned int expectedSubkeys = 2)
- {
- auto ctx = Context::create(OpenPGP);
- VERIFY_OR_OBJECT(ctx);
-
- Error err;
- auto key = ctx->key(pattern, err, /*secret=*/true);
- VERIFY_OR_OBJECT(!err);
- VERIFY_OR_OBJECT(!key.isNull());
- COMPARE_OR_OBJECT(key.numSubkeys(), expectedSubkeys);
- for (unsigned int i = 0; i < key.numSubkeys(); ++i) {
- VERIFY_OR_OBJECT(!key.subkey(i).isNull());
- }
- return key;
- }
-
-private:
- QTemporaryDir mGnupgHomeTestFixture;
- std::unique_ptr<QTemporaryDir> mGnupgHomeTestCopy;
-};
-
-QTEST_MAIN(AddExistingSubkeyJobTest)
-
-#include "t-addexistingsubkey.moc"