diff options
| author | Andre Heinecke <[email protected]> | 2016-12-21 09:32:25 +0000 | 
|---|---|---|
| committer | Andre Heinecke <[email protected]> | 2017-01-16 13:13:39 +0000 | 
| commit | 8aba08d1d0871f439fb7193adc4a2f43a81ee216 (patch) | |
| tree | e6edce19484370a83beb99ceb12b9d3ca7e13437 | |
| parent | tests: Fix distcheck. (diff) | |
| download | gpgme-8aba08d1d0871f439fb7193adc4a2f43a81ee216.tar.gz gpgme-8aba08d1d0871f439fb7193adc4a2f43a81ee216.zip | |
qt: Add test for CryptoConfig
* lang/qt/tests/t-config.cpp: New.
* lang/qt/tests/Makefile.am: Update accordingly.
| -rw-r--r-- | lang/qt/tests/Makefile.am | 7 | ||||
| -rw-r--r-- | lang/qt/tests/t-config.cpp | 94 | 
2 files changed, 98 insertions, 3 deletions
| diff --git a/lang/qt/tests/Makefile.am b/lang/qt/tests/Makefile.am index aba7be84..e3aa3be6 100644 --- a/lang/qt/tests/Makefile.am +++ b/lang/qt/tests/Makefile.am @@ -25,11 +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-various +        t-encrypt t-verify t-various t-config  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-various.moc t-config.moc  AM_LDFLAGS = -no-install @@ -59,6 +59,7 @@ 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) +t_config_SOURCES = t-config.cpp $(support_src)  run_keyformailboxjob_SOURCES = run-keyformailboxjob.cpp  nodist_t_keylist_SOURCES = $(moc_files) @@ -66,7 +67,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 t-various +    run-keyformailboxjob t-wkspublish t-verify t-various t-config  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-config.cpp b/lang/qt/tests/t-config.cpp new file mode 100644 index 00000000..046147ce --- /dev/null +++ b/lang/qt/tests/t-config.cpp @@ -0,0 +1,94 @@ +/* t-config.cpp + +    This file is part of qgpgme, the Qt API binding for gpgme +    Copyright (c) 2016 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 <QTemporaryDir> +#include "t-support.h" +#include "protocol.h" +#include "cryptoconfig.h" +#include <unistd.h> + +using namespace QGpgME; + +class CryptoConfigTest: public QGpgMETest +{ +    Q_OBJECT + +private Q_SLOTS: +    void testKeyserver() +    { +        // Repeatedly set a config value and clear it +        // this war broken at some point so it gets a +        // unit test. +        for (int i = 0; i < 10; i++) { +            auto conf = cryptoConfig(); +            Q_ASSERT (conf); +            auto entry = conf->entry(QStringLiteral("gpg"), +                    QStringLiteral("Keyserver"), +                    QStringLiteral("keyserver")); +            Q_ASSERT(entry); +            const QString url(QStringLiteral("hkp://foo.bar.baz")); +            entry->setStringValue(url); +            conf->sync(false); +            conf->clear(); +            entry = conf->entry(QStringLiteral("gpg"), +                    QStringLiteral("Keyserver"), +                    QStringLiteral("keyserver")); +            QCOMPARE (entry->stringValue(), url); +            entry->setStringValue(QString()); +            conf->sync(false); +            conf->clear(); +            entry = conf->entry(QStringLiteral("gpg"), +                    QStringLiteral("Keyserver"), +                    QStringLiteral("keyserver")); +            QCOMPARE (entry->stringValue(), QString()); +        } +    } + +    void initTestCase() +    { +        QGpgMETest::initTestCase(); +        const QString gpgHome = qgetenv("GNUPGHOME"); +        qputenv("GNUPGHOME", mDir.path().toUtf8()); +        Q_ASSERT(mDir.isValid()); +    } +private: +    QTemporaryDir mDir; + +}; + +QTEST_MAIN(CryptoConfigTest) + +#include "t-config.moc" | 
