qt,tests: Add test for remarks

* lang/qt/tests/t-various.cpp (testRemark): New.
This commit is contained in:
Andre Heinecke 2019-10-29 16:36:45 +01:00
parent 373acd6923
commit 1f3ca698f1
No known key found for this signature in database
GPG Key ID: 2978E9D40CBABA5C

View File

@ -46,6 +46,7 @@
#include "dn.h"
#include "data.h"
#include "dataprovider.h"
#include "signkeyjob.h"
#include "t-support.h"
@ -170,6 +171,116 @@ private Q_SLOTS:
QVERIFY(id_revoked);
}
void testRemark()
{
// Get the signing key (alfa)
auto ctx = Context::create(OpenPGP);
QVERIFY (ctx);
Error err;
auto seckey = ctx->key("A0FF4590BB6122EDEF6E3C542D727CC768697734", err, true);
QVERIFY (!seckey.isNull());
QVERIFY (!err);
// Get the target key (mallory / mike)
auto target = ctx->key("2686AA191A278013992C72EBBE794852BE5CF886", err, false);
QVERIFY (!target.isNull());
QVERIFY (!err);
QVERIFY (target.numUserIDs());
// Create the job
auto job = openpgp()->signKeyJob();
QVERIFY (job);
// Hack in the passphrase provider
auto jobCtx = Job::context(job);
TestPassphraseProvider provider;
jobCtx->setPassphraseProvider(&provider);
jobCtx->setPinentryMode(Context::PinentryLoopback);
// Setup the job
job->setExportable(false);
std::vector<unsigned int> uids;
uids.push_back(0);
job->setUserIDsToSign(uids);
job->setSigningKey(seckey);
job->setRemark(QStringLiteral("Mallory is evil 😠"));
connect(job, &SignKeyJob::result, this, [this] (const GpgME::Error &err2,
const QString,
const GpgME::Error) {
Q_EMIT asyncDone();
QVERIFY(!err2);
});
job->start(target);
QSignalSpy spy (this, SIGNAL(asyncDone()));
QVERIFY(spy.wait(QSIGNALSPY_TIMEOUT));
// At this point the remark should have been added.
target.update();
const char *remark = target.userID(0).remark(seckey, err);
QVERIFY(!err);
Q_ASSERT(remark);
QCOMPARE(QString::fromUtf8(remark), QStringLiteral("Mallory is evil 😠"));
// Try to replace it without dupeOK
auto job2 = openpgp()->signKeyJob();
QVERIFY (job2);
// Hack in the passphrase provider
auto jobCtx2 = Job::context(job2);
jobCtx2->setPassphraseProvider(&provider);
jobCtx2->setPinentryMode(Context::PinentryLoopback);
// Setup the job
job2->setExportable(false);
job2->setUserIDsToSign(uids);
job2->setSigningKey(seckey);
job2->setRemark(QStringLiteral("Mallory is nice"));
connect(job2, &SignKeyJob::result, this, [this] (const GpgME::Error &err2,
const QString,
const GpgME::Error) {
Q_EMIT asyncDone();
QVERIFY(err2);
});
job2->start(target);
QVERIFY(spy.wait(QSIGNALSPY_TIMEOUT));
// Now replace the remark
auto job3 = openpgp()->signKeyJob();
QVERIFY (job3);
// Hack in the passphrase provider
auto jobCtx3 = Job::context(job3);
jobCtx3->setPassphraseProvider(&provider);
jobCtx3->setPinentryMode(Context::PinentryLoopback);
// Setup the job
job3->setExportable(false);
job3->setUserIDsToSign(uids);
job3->setSigningKey(seckey);
job3->setDupeOk(true);
job3->setRemark(QStringLiteral("Mallory is nice"));
connect(job3, &SignKeyJob::result, this, [this] (const GpgME::Error &err2,
const QString,
const GpgME::Error) {
Q_EMIT asyncDone();
QVERIFY(!err2);
});
job3->start(target);
QVERIFY(spy.wait(QSIGNALSPY_TIMEOUT));
target.update();
remark = target.userID(0).remark(seckey, err);
QVERIFY(!err);
Q_ASSERT(remark);
Q_ASSERT(QString::fromUtf8(remark) == QStringLiteral("Mallory is nice"));
}
void testVersion()
{
QVERIFY(EngineInfo::Version("2.1.0") < EngineInfo::Version("2.1.1"));