blob: 926963cebefc8c7a72708efc47899c7d018a019d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
// Copyright 2005-2020 The Mumble Developers. All rights reserved.
// Use of this source code is governed by a BSD-style license
// that can be found in the LICENSE file at the root of the
// Mumble source tree or at <https://www.mumble.info/LICENSE>.
#include <QtCore>
#include <QtTest>
#if defined(USE_QSSLDIFFIEHELLMANPARAMETERS)
# include <QtNetwork/QSslDiffieHellmanParameters>
#endif
#include "FFDHE.h"
#include "SSL.h"
class TestFFDHE : public QObject {
Q_OBJECT
private slots:
void initTestCase();
void cleanupTestCase();
#if defined(USE_QSSLDIFFIEHELLMANPARAMETERS)
void exercise_data();
void exercise();
void namedGroupsMethod();
#endif
};
void TestFFDHE::initTestCase() {
MumbleSSL::initialize();
}
void TestFFDHE::cleanupTestCase() {
MumbleSSL::destroy();
}
#if defined(USE_QSSLDIFFIEHELLMANPARAMETERS)
void TestFFDHE::exercise_data() {
QTest::addColumn< QString >("name");
QTest::addColumn< bool >("expectedToWork");
QTest::newRow("ffdhe2048") << QString(QLatin1String("ffdhe2048")) << true;
QTest::newRow("ffdhe3072") << QString(QLatin1String("ffdhe3072")) << true;
QTest::newRow("ffdhe4096") << QString(QLatin1String("ffdhe4096")) << true;
QTest::newRow("ffdhe6144") << QString(QLatin1String("ffdhe6144")) << true;
QTest::newRow("ffdhe8192") << QString(QLatin1String("ffdhe8192")) << true;
QTest::newRow("ffdhe2048_upper") << QString(QLatin1String("FFDHE2048")) << true;
QTest::newRow("ffdhe2048_random") << QString(QLatin1String("fFdHe2048")) << true;
QTest::newRow("noname") << QString(QLatin1String("")) << false;
QTest::newRow("typo") << QString(QLatin1String("ffdhe2047")) << false;
QTest::newRow("trailingspace") << QString(QLatin1String("ffdhe2048 ")) << false;
}
static bool tryFFDHELookupByName(QString name) {
bool ok = true;
QByteArray pem = FFDHE::PEMForNamedGroup(name);
if (pem.isEmpty() || pem.isNull()) {
ok = false;
}
if (ok) {
QSslDiffieHellmanParameters dh = QSslDiffieHellmanParameters::fromEncoded(pem, QSsl::Pem);
ok = dh.isValid();
if (!ok) {
qWarning("QSslDiffieHellman error: %s", qPrintable(dh.errorString()));
}
}
return ok;
}
void TestFFDHE::exercise() {
QFETCH(QString, name);
QFETCH(bool, expectedToWork);
QCOMPARE(tryFFDHELookupByName(name), expectedToWork);
}
void TestFFDHE::namedGroupsMethod() {
foreach (QString name, FFDHE::NamedGroups()) { QCOMPARE(tryFFDHELookupByName(name), true); }
}
#endif
QTEST_MAIN(TestFFDHE)
#include "TestFFDHE.moc"
|