mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-04-03 20:47:37 +03:00
Fix multiple TOTP issues
* Fix #9847 - don't provide TOTP values if settings are blank or completely wrong * Fix #6838 - don't reset the ui when creating a new entry and applying TOTP to it * Move totp source into the core folder
This commit is contained in:
parent
5d64292ed8
commit
9f3b4dc5ea
16 changed files with 52 additions and 17 deletions
|
@ -22,9 +22,9 @@
|
|||
#include <QTest>
|
||||
|
||||
#include "core/Group.h"
|
||||
#include "core/Totp.h"
|
||||
#include "crypto/Crypto.h"
|
||||
#include "format/CsvExporter.h"
|
||||
#include "totp/totp.h"
|
||||
|
||||
QTEST_GUILESS_MAIN(TestCsvExporter)
|
||||
|
||||
|
|
|
@ -20,9 +20,9 @@
|
|||
#include "config-keepassx-tests.h"
|
||||
#include "core/Group.h"
|
||||
#include "core/Metadata.h"
|
||||
#include "core/Totp.h"
|
||||
#include "crypto/Crypto.h"
|
||||
#include "format/OpVaultReader.h"
|
||||
#include "totp/totp.h"
|
||||
|
||||
#include <QJsonObject>
|
||||
#include <QList>
|
||||
|
|
|
@ -19,8 +19,8 @@
|
|||
#include "TestTotp.h"
|
||||
|
||||
#include "core/Entry.h"
|
||||
#include "core/Totp.h"
|
||||
#include "crypto/Crypto.h"
|
||||
#include "totp/totp.h"
|
||||
|
||||
#include <QTest>
|
||||
|
||||
|
@ -97,6 +97,14 @@ void TestTotp::testParseSecret()
|
|||
QCOMPARE(settings->digits, 6u);
|
||||
QCOMPARE(settings->step, 30u);
|
||||
QCOMPARE(settings->algorithm, Totp::Algorithm::Sha1);
|
||||
|
||||
// Blank settings (expected failure)
|
||||
settings = Totp::parseSettings("", "");
|
||||
QVERIFY(settings.isNull());
|
||||
|
||||
// TOTP Settings with blank secret (expected failure)
|
||||
settings = Totp::parseSettings("30;8", "");
|
||||
QVERIFY(settings.isNull());
|
||||
}
|
||||
|
||||
void TestTotp::testTotpCode()
|
||||
|
@ -164,4 +172,8 @@ void TestTotp::testEntryHistory()
|
|||
entry.setTotp(settings);
|
||||
QCOMPARE(entry.historyItems().size(), 2);
|
||||
QCOMPARE(entry.totpSettings()->key, QString("foo"));
|
||||
// Nullptr Settings (expected reset of TOTP)
|
||||
entry.setTotp(nullptr);
|
||||
QVERIFY(!entry.hasTotp());
|
||||
QCOMPARE(entry.historyItems().size(), 3);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue