/**************************************************************************** ** ** Copyright (C) 2017 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 as published by the Free Software ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ****************************************************************************/ #include "qmlprofilertraceclient_test.h" #include #include namespace QmlProfiler { namespace Internal { QmlProfilerTraceClientTest::QmlProfilerTraceClientTest(QObject *parent) : QObject(parent), traceClient(nullptr, &modelManager, std::numeric_limits::max()) { } static void bufferCompressedFile(const QString &name, QBuffer &buffer) { QFile file(name); QVERIFY(file.open(QIODevice::ReadOnly)); buffer.setData(qUncompress(file.readAll())); file.close(); QVERIFY(buffer.open(QIODevice::ReadOnly)); } void QmlProfilerTraceClientTest::testMessageReceived() { QBuffer inBuffer; bufferCompressedFile(":/qmlprofiler/tests/traces.dat", inBuffer); QDataStream inStream(&inBuffer); inStream.setVersion(QDataStream::Qt_5_6); QBuffer checkBuffer; bufferCompressedFile(":/qmlprofiler/tests/check.dat", checkBuffer); QDataStream checkStream(&checkBuffer); checkStream.setVersion(QDataStream::Qt_5_6); while (!inStream.atEnd()) { QByteArray trace; inStream >> trace; traceClient.stateChanged(QmlDebug::QmlDebugClient::Enabled); QmlDebug::QPacket packet(QDataStream::Qt_4_7, trace); while (!packet.atEnd()) { QByteArray content; packet >> content; traceClient.messageReceived(content); } traceClient.stateChanged(QmlDebug::QmlDebugClient::NotConnected); QFutureInterface future; QString lastError; connect(&modelManager, &Timeline::TimelineTraceManager::error, this, [&](const QString &message) { lastError = message; }); modelManager.replayQmlEvents([&](const QmlEvent &event, const QmlEventType &type) { qint64 timestamp; qint32 message; qint32 rangeType; checkStream >> timestamp >> message >> rangeType; QCOMPARE(event.timestamp(), timestamp); QCOMPARE(type.message(), static_cast(message)); QCOMPARE(type.rangeType(), static_cast(rangeType)); }, nullptr, [this]() { modelManager.clearAll(); traceClient.clear(); }, [this, &lastError](const QString &message) { QVERIFY(!message.isEmpty()); if (lastError == QmlProfilerModelManager::tr("Read past end in temporary trace file")) { // Ignore read-past-end errors: Our test traces are somewhat dirty and don't end on // packet boundaries modelManager.clearAll(); traceClient.clear(); lastError.clear(); } else { QFAIL((message + " " + lastError).toUtf8().constData()); } }, future); } QVERIFY(checkStream.atEnd()); } } // namespace Internal } // namespace QmlProfiler