diff options
| author | Ingo Klöcker <[email protected]> | 2022-08-09 10:19:04 +0000 | 
|---|---|---|
| committer | Ingo Klöcker <[email protected]> | 2022-08-09 12:52:42 +0000 | 
| commit | db7d79063f57c6e0ccf382fdf1cf47d514e12f6e (patch) | |
| tree | c01b545cc8311bbdee69404a95a0c6a89023ffad /lang/qt/tests | |
| parent | cpp: Add support for gpgme_op_set_uid_flag (diff) | |
| download | gpgme-db7d79063f57c6e0ccf382fdf1cf47d514e12f6e.tar.gz gpgme-db7d79063f57c6e0ccf382fdf1cf47d514e12f6e.zip  | |
qt: Add job to set the primary user ID of OpenPGP keys
* lang/qt/src/qgpgmesetprimaryuseridjob.cpp,
lang/qt/src/qgpgmesetprimaryuseridjob.h,
lang/qt/src/setprimaryuseridjob.h: New.
* lang/qt/src/protocol.h (class Protocol): Add pure virtual member
function setPrimaryUserIDJob.
* lang/qt/src/protocol_p.h (Protocol::setPrimaryUserIDJob): New.
* lang/qt/src/job.cpp, lang/qt/src/Makefile.am: Update accordingly.
* lang/qt/tests/t-setprimaryuserid.cpp: New.
* lang/qt/tests/Makefile.am: Add new test.
--
GnuPG-bug-id: 5938
Diffstat (limited to 'lang/qt/tests')
| -rw-r--r-- | lang/qt/tests/Makefile.am | 7 | ||||
| -rw-r--r-- | lang/qt/tests/t-setprimaryuserid.cpp | 165 | 
2 files changed, 170 insertions, 2 deletions
diff --git a/lang/qt/tests/Makefile.am b/lang/qt/tests/Makefile.am index 65fd0196..5724a2df 100644 --- a/lang/qt/tests/Makefile.am +++ b/lang/qt/tests/Makefile.am @@ -30,7 +30,7 @@ the_tests = \  	t-addexistingsubkey \  	t-keylist t-keylocate t-ownertrust t-tofuinfo \  	t-encrypt t-verify t-various t-config t-remarks t-trustsignatures \ -	t-changeexpiryjob t-wkdlookup t-import t-revokekey +	t-changeexpiryjob t-wkdlookup t-import t-revokekey t-setprimaryuserid  TESTS = initial.test $(the_tests) final.test @@ -39,7 +39,8 @@ moc_files = \  	t-keylist.moc t-keylocate.moc t-ownertrust.moc t-tofuinfo.moc \  	t-encrypt.moc t-support.hmoc t-wkspublish.moc t-verify.moc \  	t-various.moc t-config.moc t-remarks.moc t-trustsignatures.moc \ -	t-changeexpiryjob.moc t-wkdlookup.moc t-import.moc t-revokekey.moc +	t-changeexpiryjob.moc t-wkdlookup.moc t-import.moc t-revokekey.moc \ +	t-setprimaryuserid.moc  AM_LDFLAGS = -no-install @@ -71,6 +72,7 @@ t_changeexpiryjob_SOURCES = t-changeexpiryjob.cpp $(support_src)  t_wkdlookup_SOURCES = t-wkdlookup.cpp $(support_src)  t_import_SOURCES = t-import.cpp $(support_src)  t_revokekey_SOURCES = t-revokekey.cpp $(support_src) +t_setprimaryuserid_SOURCES = t-setprimaryuserid.cpp $(support_src)  run_exportjob_SOURCES = run-exportjob.cpp  run_importjob_SOURCES = run-importjob.cpp  run_keyformailboxjob_SOURCES = run-keyformailboxjob.cpp @@ -86,6 +88,7 @@ noinst_PROGRAMS = \  	t-keylist t-keylocate t-ownertrust t-tofuinfo t-encrypt \  	run-keyformailboxjob t-wkspublish t-verify t-various t-config t-remarks \  	t-trustsignatures t-changeexpiryjob t-wkdlookup t-import t-revokekey \ +	t-setprimaryuserid \  	run-importjob run-exportjob run-receivekeysjob run-refreshkeysjob  CLEANFILES = secring.gpg pubring.gpg pubring.kbx trustdb.gpg dirmngr.conf \ diff --git a/lang/qt/tests/t-setprimaryuserid.cpp b/lang/qt/tests/t-setprimaryuserid.cpp new file mode 100644 index 00000000..c1bd1069 --- /dev/null +++ b/lang/qt/tests/t-setprimaryuserid.cpp @@ -0,0 +1,165 @@ +/* t-setprimaryuserid.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 <keylistjob.h> +#include <protocol.h> + +#include <context.h> +#include <engineinfo.h> +#include <keylistresult.h> + +using namespace QGpgME; +using namespace GpgME; + +class TestSetPrimaryUserID: public QGpgMETest +{ +    Q_OBJECT + +private Q_SLOTS: +    void testSetPrimaryUserID() +    { +        Key key; +        { +            std::unique_ptr<KeyListJob> job{openpgp()->keyListJob()}; +            std::vector<GpgME::Key> keys; +            GpgME::KeyListResult result = job->exec({QStringLiteral("[email protected]")}, true, keys); +            QVERIFY(!result.error()); +            QVERIFY(keys.size() == 1); +            key = keys.front(); +        } + +        QCOMPARE(key.numUserIDs(), 3u); +        const std::string oldPrimaryUserId = key.userID(0).id(); +        const std::string newPrimaryUserId = key.userID(1).id(); +        const std::string newPrimaryUserIdHash = key.userID(1).uidhash(); + +        { +            std::unique_ptr<Context> ctx{Context::createForProtocol(key.protocol())}; +            QVERIFY(ctx); +            hookUpPassphraseProvider(ctx.get()); + +            if (GpgME::engineInfo(GpgME::GpgEngine).engineVersion() >= "2.3.8") { +                QVERIFY(!ctx->setPrimaryUid(key, newPrimaryUserIdHash.c_str())); +            } else { +                QVERIFY(!ctx->setPrimaryUid(key, newPrimaryUserId.c_str())); +            } +        } +        key.update(); + +        QCOMPARE(key.userID(0).id(), newPrimaryUserId); + +        { +            std::unique_ptr<Context> ctx{Context::createForProtocol(key.protocol())}; +            QVERIFY(ctx); +            hookUpPassphraseProvider(ctx.get()); + +            QVERIFY(!ctx->setPrimaryUid(key, oldPrimaryUserId.c_str())); +        } +        key.update(); + +        QCOMPARE(key.userID(0).id(), oldPrimaryUserId); +    } + +    void testErrorHandling_noSecretKey() +    { +        if (GpgME::engineInfo(GpgME::GpgEngine).engineVersion() < "2.3.8") { +            QSKIP("gpg < 2.3.8 does not report status error"); +        } +        Key key; +        { +            std::unique_ptr<KeyListJob> job{openpgp()->keyListJob()}; +            std::vector<GpgME::Key> keys; +            GpgME::KeyListResult result = job->exec({QStringLiteral("[email protected]")}, false, keys); +            QVERIFY(!result.error()); +            QVERIFY(keys.size() == 1); +            key = keys.front(); +        } + +        QCOMPARE(key.numUserIDs(), 2u); +        const std::string newPrimaryUserId = key.userID(1).id(); + +        { +            std::unique_ptr<Context> ctx{Context::createForProtocol(key.protocol())}; +            QVERIFY(ctx); +            auto err = ctx->setPrimaryUid(key, newPrimaryUserId.c_str()); +            QCOMPARE(err.code(), static_cast<int>(GPG_ERR_NO_SECKEY)); +        } +    } + +    void testErrorHandling_noUserID() +    { +        if (GpgME::engineInfo(GpgME::GpgEngine).engineVersion() < "2.3.8") { +            QSKIP("gpg < 2.3.8 does not report status error"); +        } +        Key key; +        { +            std::unique_ptr<KeyListJob> job{openpgp()->keyListJob()}; +            std::vector<GpgME::Key> keys; +            GpgME::KeyListResult result = job->exec({QStringLiteral("[email protected]")}, true, keys); +            QVERIFY(!result.error()); +            QVERIFY(keys.size() == 1); +            key = keys.front(); +        } +        { +            std::unique_ptr<Context> ctx{Context::createForProtocol(key.protocol())}; +            QVERIFY(ctx); +            auto err = ctx->setPrimaryUid(key, "bravo"); +            QCOMPARE(err.code(), static_cast<int>(GPG_ERR_NO_USER_ID)); +        } +    } + +    void initTestCase() +    { +        QGpgMETest::initTestCase(); +        const QString gpgHome = qgetenv("GNUPGHOME"); +        QVERIFY(copyKeyrings(gpgHome, mDir.path())); +        qputenv("GNUPGHOME", mDir.path().toUtf8()); +        QFile conf(mDir.path() + QStringLiteral("/gpg.conf")); +        QVERIFY(conf.open(QIODevice::WriteOnly)); +        if (GpgME::engineInfo(GpgME::GpgEngine).engineVersion() >= "2.2.18") { +            conf.write("allow-weak-key-signatures\n"); +        } +        conf.close(); +    } + +private: +    QTemporaryDir mDir; +}; + +QTEST_MAIN(TestSetPrimaryUserID) + +#include "t-setprimaryuserid.moc"  | 
