katie/tests/benchmarks/network/kernel/qcryptographichash/main.cpp
Ivailo Monev fe5b630b28 drop all but the custom hash algorithm
don't need them

Signed-off-by: Ivailo Monev <xakepa10@gmail.com>
2023-11-05 00:18:07 +02:00

90 lines
2.8 KiB
C++

/****************************************************************************
**
** Copyright (C) 2019 Ivailo Monev
**
** This file is part of the test suite of the Katie Toolkit.
**
** $QT_BEGIN_LICENSE:LGPL$
**
** GNU Lesser General Public License Usage
** This file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** $QT_END_LICENSE$
**
****************************************************************************/
#include <qdebug.h>
#include <qcryptographichash.h>
#include <qtest.h>
QT_USE_NAMESPACE
static const QByteArray lorem = QByteArray("Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi.");
class tst_qcryptographichash : public QObject
{
Q_OBJECT
private slots:
void append_data();
void append();
void append_once();
void statichash();
};
void tst_qcryptographichash::append_data()
{
QTest::addColumn<int>("size");
QTest::newRow("10") << int(10);
QTest::newRow("100") << int(100);
QTest::newRow("250") << int(250);
QTest::newRow("500") << int(500);
}
void tst_qcryptographichash::append()
{
QFETCH(int, size);
const int chunksize = lorem.size() / size;
QVERIFY(chunksize > 0);
QList<QByteArray> chunks;
int chunkposition = 0;
for (int i = 0; i < chunksize; i++) {
chunks.append(lorem.mid(chunkposition, chunksize));
chunkposition += chunksize;
}
QBENCHMARK {
QCryptographicHash hash;
for (int i = 0; i < chunks.size(); i++) {
hash.addData(chunks.at(i));
}
QVERIFY(!hash.result().isEmpty());
}
}
void tst_qcryptographichash::append_once()
{
QBENCHMARK {
QCryptographicHash hash;
hash.addData(lorem);
QVERIFY(!hash.result().isEmpty());
}
}
void tst_qcryptographichash::statichash()
{
QBENCHMARK {
QByteArray hash = QCryptographicHash::hash(lorem);
QVERIFY(!hash.isEmpty());
}
}
QTEST_MAIN(tst_qcryptographichash)
#include "moc_main.cpp"