2017-07-03 09:30:10 +02:00
|
|
|
/*!
|
|
|
|
* \brief Test for the chat administration in authentication context.
|
|
|
|
*
|
2018-03-28 15:10:51 +02:00
|
|
|
* \copyright Copyright (c) 2016-2018 Governikus GmbH & Co. KG, Germany
|
2017-07-03 09:30:10 +02:00
|
|
|
*/
|
|
|
|
|
2017-07-03 09:33:28 +02:00
|
|
|
#include "TestAuthContext.h"
|
|
|
|
#include "TestFileHelper.h"
|
2017-07-03 09:30:10 +02:00
|
|
|
|
|
|
|
#include <QSharedPointer>
|
|
|
|
#include <QSignalSpy>
|
|
|
|
#include <QtTest>
|
|
|
|
|
|
|
|
|
|
|
|
using namespace governikus;
|
|
|
|
|
|
|
|
|
|
|
|
class test_AuthContext
|
|
|
|
: public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
private:
|
2017-07-03 09:33:28 +02:00
|
|
|
QScopedPointer<QSignalSpy> mEac1Changed;
|
|
|
|
QScopedPointer<QSignalSpy> mDataChanged;
|
2017-07-03 09:30:10 +02:00
|
|
|
QScopedPointer<QSignalSpy> mEffectiveSignal;
|
2017-07-03 09:33:28 +02:00
|
|
|
QScopedPointer<TestAuthContext> mAuthContext;
|
2017-07-03 09:30:10 +02:00
|
|
|
|
|
|
|
QSharedPointer<CHAT> getChat(const std::initializer_list<AccessRight>& pList)
|
|
|
|
{
|
|
|
|
auto chat = newObject<CHAT>();
|
|
|
|
chat->setAccessRights(QSet<AccessRight>(pList));
|
|
|
|
return chat;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-07-03 09:33:28 +02:00
|
|
|
void clearSignals()
|
2017-07-03 09:30:10 +02:00
|
|
|
{
|
2017-07-03 09:33:28 +02:00
|
|
|
mEac1Changed->clear();
|
|
|
|
mDataChanged->clear();
|
|
|
|
mEffectiveSignal->clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void checkChatSizes(const QString& pTestNum, int pRequired, int pOptional, int pEffective)
|
|
|
|
{
|
|
|
|
qDebug() << "Checking test" << pTestNum;
|
|
|
|
QCOMPARE(mAuthContext->getRequiredAccessRights().size(), pRequired);
|
|
|
|
QCOMPARE(mAuthContext->getOptionalAccessRights().size(), pOptional);
|
|
|
|
QCOMPARE(mAuthContext->getEffectiveAccessRights().size(), pEffective);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void checkAndClearSignals(const QString& pTestNum, int pEac1Data, int pEffective)
|
|
|
|
{
|
|
|
|
qDebug() << "Checking test" << pTestNum;
|
|
|
|
QCOMPARE(mEac1Changed->count(), pEac1Data);
|
|
|
|
QCOMPARE(mDataChanged->count(), pEac1Data);
|
2017-07-03 09:30:10 +02:00
|
|
|
QCOMPARE(mEffectiveSignal->count(), pEffective);
|
|
|
|
|
2017-07-03 09:33:28 +02:00
|
|
|
clearSignals();
|
2017-07-03 09:30:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private Q_SLOTS:
|
|
|
|
void init()
|
|
|
|
{
|
2017-07-03 09:33:28 +02:00
|
|
|
// Creates a context with 17 access rights in cvc
|
|
|
|
// Because required and optional are empty, all 17 rights are optional by default
|
|
|
|
mAuthContext.reset(new TestAuthContext(nullptr, ":/paos/DIDAuthenticateEAC1.xml"));
|
|
|
|
mAuthContext->setRequiredAccessRights({});
|
|
|
|
mAuthContext->setOptionalAccessRights({});
|
|
|
|
|
|
|
|
mEac1Changed.reset(new QSignalSpy(mAuthContext.data(), &AuthContext::fireDidAuthenticateEac1Changed));
|
|
|
|
mDataChanged.reset(new QSignalSpy(mAuthContext.data(), &AuthContext::fireAuthenticationDataChanged));
|
2017-07-03 09:30:10 +02:00
|
|
|
mEffectiveSignal.reset(new QSignalSpy(mAuthContext.data(), &AuthContext::fireEffectiveChatChanged));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void cleanup()
|
|
|
|
{
|
2017-07-03 09:33:28 +02:00
|
|
|
mEac1Changed.reset();
|
2017-07-03 09:30:10 +02:00
|
|
|
mEffectiveSignal.reset();
|
|
|
|
mAuthContext.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-07-03 09:33:28 +02:00
|
|
|
void test_AuthContext_01()
|
2017-07-03 09:30:10 +02:00
|
|
|
{
|
2017-07-03 09:33:28 +02:00
|
|
|
// Exists after creation - All cvc rights are optional and selected
|
|
|
|
checkChatSizes("01-01", 0, 17, 17);
|
2017-07-03 09:30:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-07-03 09:33:28 +02:00
|
|
|
void test_AuthContext_02()
|
2017-07-03 09:30:10 +02:00
|
|
|
{
|
2017-07-03 09:33:28 +02:00
|
|
|
// Try to set required right that is not in cvc
|
|
|
|
mAuthContext->setRequiredAccessRights({AccessRight::READ_DG21});
|
|
|
|
checkChatSizes("02-01", 0, 17, 17);
|
|
|
|
checkAndClearSignals("02-02", 1, 1);
|
|
|
|
|
|
|
|
// Try to set optional right that is not in cvc
|
|
|
|
mAuthContext->setOptionalAccessRights({AccessRight::READ_DG21});
|
|
|
|
checkChatSizes("02-03", 0, 17, 17);
|
|
|
|
checkAndClearSignals("02-04", 1, 1);
|
|
|
|
|
|
|
|
// Try to set a right in required and optional
|
|
|
|
mAuthContext->setOptionalAccessRights({AccessRight::READ_DG05});
|
|
|
|
checkChatSizes("02-05", 0, 1, 1);
|
|
|
|
checkAndClearSignals("02-06", 1, 1);
|
|
|
|
mAuthContext->setRequiredAccessRights({AccessRight::READ_DG05});
|
|
|
|
checkChatSizes("02-07", 1, 0, 1);
|
|
|
|
checkAndClearSignals("02-08", 1, 1);
|
2017-07-03 09:30:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-07-03 09:33:28 +02:00
|
|
|
void test_AuthContext_03()
|
2017-07-03 09:30:10 +02:00
|
|
|
{
|
2017-07-03 09:33:28 +02:00
|
|
|
// Clear effective access rights
|
|
|
|
mAuthContext->setEffectiveAccessRights({});
|
|
|
|
checkChatSizes("03-01", 0, 17, 0);
|
|
|
|
checkAndClearSignals("03-02", 0, 1);
|
2017-07-03 09:30:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-07-03 09:33:28 +02:00
|
|
|
void test_AuthContext_04()
|
2017-07-03 09:30:10 +02:00
|
|
|
{
|
2017-07-03 09:33:28 +02:00
|
|
|
// Set only one access right as optional, required access rights remain empty
|
|
|
|
mAuthContext->setOptionalAccessRights({AccessRight::READ_DG05});
|
|
|
|
checkChatSizes("04-01", 0, 1, 1);
|
|
|
|
QVERIFY(mAuthContext->getOptionalAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
QVERIFY(mAuthContext->getEffectiveAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("04-02", 1, 1);
|
|
|
|
|
|
|
|
// Try to set an optional access right that is already set
|
|
|
|
QVERIFY(mAuthContext->addEffectiveAccessRight(AccessRight::READ_DG05));
|
|
|
|
checkChatSizes("04-03", 0, 1, 1);
|
|
|
|
QVERIFY(mAuthContext->getOptionalAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
QVERIFY(mAuthContext->getEffectiveAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("04-04", 0, 0);
|
|
|
|
|
|
|
|
// Try to remove an optional access right
|
|
|
|
QVERIFY(mAuthContext->removeEffectiveAccessRight(AccessRight::READ_DG05));
|
|
|
|
checkChatSizes("04-05", 0, 1, 0);
|
|
|
|
QVERIFY(mAuthContext->getOptionalAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("04-06", 0, 1);
|
|
|
|
|
|
|
|
// Try to remove an optional access right that is not set
|
|
|
|
QVERIFY(mAuthContext->removeEffectiveAccessRight(AccessRight::READ_DG05));
|
|
|
|
checkChatSizes("04-07", 0, 1, 0);
|
|
|
|
QVERIFY(mAuthContext->getOptionalAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("04-08", 0, 0);
|
|
|
|
|
|
|
|
// Try to set an optional access right
|
|
|
|
QVERIFY(mAuthContext->addEffectiveAccessRight(AccessRight::READ_DG05));
|
|
|
|
checkChatSizes("04-09", 0, 1, 1);
|
|
|
|
QVERIFY(mAuthContext->getOptionalAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
QVERIFY(mAuthContext->getEffectiveAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("04-10", 0, 1);
|
|
|
|
|
|
|
|
// Try to set an access right that is not included in optional or required access rights
|
|
|
|
QVERIFY(!mAuthContext->addEffectiveAccessRight(AccessRight::AGE_VERIFICATION));
|
|
|
|
checkChatSizes("04-11", 0, 1, 1);
|
|
|
|
QVERIFY(mAuthContext->getOptionalAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
QVERIFY(mAuthContext->getEffectiveAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("04-12", 0, 0);
|
2017-07-03 09:30:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-07-03 09:33:28 +02:00
|
|
|
void test_AuthContext_05()
|
2017-07-03 09:30:10 +02:00
|
|
|
{
|
2017-07-03 09:33:28 +02:00
|
|
|
// Set only one access right as required, optional access rights remain empty
|
|
|
|
mAuthContext->setRequiredAccessRights({AccessRight::READ_DG05});
|
|
|
|
checkChatSizes("05-01", 1, 0, 1);
|
|
|
|
QVERIFY(mAuthContext->getRequiredAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
QVERIFY(mAuthContext->getEffectiveAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("05-02", 1, 1);
|
|
|
|
|
|
|
|
// Try to set an required access right that is already set
|
|
|
|
QVERIFY(mAuthContext->addEffectiveAccessRight(AccessRight::READ_DG05));
|
|
|
|
checkChatSizes("05-03", 1, 0, 1);
|
|
|
|
QVERIFY(mAuthContext->getRequiredAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
QVERIFY(mAuthContext->getEffectiveAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("05-04", 0, 0);
|
|
|
|
|
|
|
|
// Try to remove an required access right
|
|
|
|
QVERIFY(!mAuthContext->removeEffectiveAccessRight(AccessRight::READ_DG05));
|
|
|
|
checkChatSizes("05-05", 1, 0, 1);
|
|
|
|
QVERIFY(mAuthContext->getRequiredAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
QVERIFY(mAuthContext->getEffectiveAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("05-06", 0, 0);
|
|
|
|
|
|
|
|
// Try to remove an access right that is not included in optional or required access rights
|
|
|
|
QVERIFY(mAuthContext->removeEffectiveAccessRight(AccessRight::AGE_VERIFICATION));
|
|
|
|
checkChatSizes("05-07", 1, 0, 1);
|
|
|
|
QVERIFY(mAuthContext->getRequiredAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
QVERIFY(mAuthContext->getEffectiveAccessRights().contains(AccessRight::READ_DG05));
|
|
|
|
checkAndClearSignals("05-08", 0, 0);
|
2017-07-03 09:30:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
QTEST_GUILESS_MAIN(test_AuthContext)
|
|
|
|
#include "test_AuthContext.moc"
|