diff options
author | Andre Heinecke <[email protected]> | 2017-01-11 15:18:17 +0000 |
---|---|---|
committer | Andre Heinecke <[email protected]> | 2017-01-11 15:18:17 +0000 |
commit | 9e643ab67168dfbd189ccc0bfed8fb59253ee79c (patch) | |
tree | 524bf21c931324d461587fef10a7f5abf26740fe /lang/qt | |
parent | cpp: Add revuid and adduid support (diff) | |
download | gpgme-9e643ab67168dfbd189ccc0bfed8fb59253ee79c.tar.gz gpgme-9e643ab67168dfbd189ccc0bfed8fb59253ee79c.zip |
qt: Add test for uid functions
* lang/qt/tests/t-various.cpp: New.
* lang/qt/tests/Makefile.am: Update accordingly.
Diffstat (limited to 'lang/qt')
-rw-r--r-- | lang/qt/tests/Makefile.am | 8 | ||||
-rw-r--r-- | lang/qt/tests/t-various.cpp | 126 |
2 files changed, 131 insertions, 3 deletions
diff --git a/lang/qt/tests/Makefile.am b/lang/qt/tests/Makefile.am index ad08ad43..aba7be84 100644 --- a/lang/qt/tests/Makefile.am +++ b/lang/qt/tests/Makefile.am @@ -25,10 +25,11 @@ TESTS_ENVIRONMENT = GNUPGHOME=$(abs_builddir) EXTRA_DIST = initial.test TESTS = initial.test t-keylist t-keylocate t-ownertrust t-tofuinfo \ - t-encrypt t-verify + t-encrypt t-verify t-various 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-encrypt.moc t-support.hmoc t-wkspublish.moc t-verify.moc \ + t-various.moc AM_LDFLAGS = -no-install @@ -57,6 +58,7 @@ t_tofuinfo_SOURCES = t-tofuinfo.cpp $(support_src) t_encrypt_SOURCES = t-encrypt.cpp $(support_src) t_wkspublish_SOURCES = t-wkspublish.cpp $(support_src) t_verify_SOURCES = t-verify.cpp $(support_src) +t_various_SOURCES = t-various.cpp $(support_src) run_keyformailboxjob_SOURCES = run-keyformailboxjob.cpp nodist_t_keylist_SOURCES = $(moc_files) @@ -64,7 +66,7 @@ nodist_t_keylist_SOURCES = $(moc_files) BUILT_SOURCES = $(moc_files) noinst_PROGRAMS = t-keylist t-keylocate t-ownertrust t-tofuinfo t-encrypt \ - run-keyformailboxjob t-wkspublish t-verify + run-keyformailboxjob t-wkspublish t-verify t-various CLEANFILES = secring.gpg pubring.gpg pubring.kbx trustdb.gpg dirmngr.conf \ gpg-agent.conf pubring.kbx~ S.gpg-agent gpg.conf pubring.gpg~ \ diff --git a/lang/qt/tests/t-various.cpp b/lang/qt/tests/t-various.cpp new file mode 100644 index 00000000..330e62d8 --- /dev/null +++ b/lang/qt/tests/t-various.cpp @@ -0,0 +1,126 @@ +/* t-various.cpp + + This file is part of qgpgme, the Qt API binding for gpgme + Copyright (c) 2017 Intevation GmbH + + 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 <QDebug> +#include <QTest> +#include <QSignalSpy> +#include "keylistjob.h" +#include "protocol.h" +#include "keylistresult.h" +#include "context.h" +#include "engineinfo.h" + +#include "t-support.h" + +using namespace QGpgME; +using namespace GpgME; + +class TestVarious: public QGpgMETest +{ + Q_OBJECT + +Q_SIGNALS: + void asyncDone(); + +private Q_SLOTS: + + void testQuickUid() + { + if (GpgME::engineInfo(GpgME::GpgEngine).engineVersion() < "2.1.13") { + return; + } + KeyListJob *job = openpgp()->keyListJob(false, true, true); + std::vector<GpgME::Key> keys; + GpgME::KeyListResult result = job->exec(QStringList() << QStringLiteral("[email protected]"), + false, keys); + delete job; + Q_ASSERT (!result.error()); + Q_ASSERT (keys.size() == 1); + Key key = keys.front(); + + QVERIFY (key.numUserIDs() == 3); + const char uid[] = "Foo Bar (with comment) <[email protected]>"; + + auto ctx = Context::createForProtocol(key.protocol()); + Q_ASSERT (ctx); + TestPassphraseProvider provider; + ctx->setPassphraseProvider(&provider); + ctx->setPinentryMode(Context::PinentryLoopback); + + QVERIFY(!ctx->addUid(key, uid)); + delete ctx; + key.update(); + + QVERIFY (key.numUserIDs() == 4); + bool id_found = false;; + for (const auto &u: key.userIDs()) { + if (!strcmp (u.id(), uid)) { + QVERIFY (!u.isRevoked()); + id_found = true; + break; + } + } + QVERIFY (id_found); + + ctx = Context::createForProtocol(key.protocol()); + QVERIFY (!ctx->revUid(key, uid)); + delete ctx; + key.update(); + + bool id_revoked = false;; + for (const auto &u: key.userIDs()) { + if (!strcmp (u.id(), uid)) { + id_revoked = true; + break; + } + } + Q_ASSERT(id_revoked); + } + + void initTestCase() + { + QGpgMETest::initTestCase(); + const QString gpgHome = qgetenv("GNUPGHOME"); + Q_ASSERT(copyKeyrings(gpgHome, mDir.path())); + qputenv("GNUPGHOME", mDir.path().toUtf8()); + } + +private: + QTemporaryDir mDir; +}; + +QTEST_MAIN(TestVarious) + +#include "t-various.moc" |