summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorPaul Lemire <paul.lemire@kdab.com>2018-08-28 15:12:54 +0200
committerPaul Lemire <paul.lemire@kdab.com>2018-10-10 06:03:03 +0000
commitb45d56eb116395387f619837d440d5771e9edd4b (patch)
tree09c2bb568de172c3f07d0c82f100b9e20918ce4a /tests
parentd45f0bed894665596bffa63c13f8ba5147a15b9d (diff)
Introduce QSetFence/QWaitFence to synchronize with 3rd party engines
Change-Id: Id0a3db229a33b3ee9dc01bf1b01ddd3af27cb34f Reviewed-by: Kevin Ottens <kevin.ottens@kdab.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/auto/render/qsetfence/qsetfence.pro12
-rw-r--r--tests/auto/render/qsetfence/tst_qsetfence.cpp190
-rw-r--r--tests/auto/render/qwaitfence/qwaitfence.pro12
-rw-r--r--tests/auto/render/qwaitfence/tst_qwaitfence.cpp349
-rw-r--r--tests/auto/render/render.pro4
5 files changed, 566 insertions, 1 deletions
diff --git a/tests/auto/render/qsetfence/qsetfence.pro b/tests/auto/render/qsetfence/qsetfence.pro
new file mode 100644
index 000000000..4e70559c9
--- /dev/null
+++ b/tests/auto/render/qsetfence/qsetfence.pro
@@ -0,0 +1,12 @@
+TEMPLATE = app
+
+TARGET = tst_qsetfence
+
+QT += 3dcore 3dcore-private 3drender 3drender-private testlib
+
+CONFIG += testcase
+
+SOURCES += tst_qsetfence.cpp
+
+include(../../core/common/common.pri)
+include(../commons/commons.pri)
diff --git a/tests/auto/render/qsetfence/tst_qsetfence.cpp b/tests/auto/render/qsetfence/tst_qsetfence.cpp
new file mode 100644
index 000000000..c602e6f5c
--- /dev/null
+++ b/tests/auto/render/qsetfence/tst_qsetfence.cpp
@@ -0,0 +1,190 @@
+/****************************************************************************
+**
+** Copyright (C) 2018 Klaralvdalens Datakonsult AB (KDAB).
+** Contact: https://www.qt.io/licensing/
+**
+** This file is part of the Qt3D module of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** 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 Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 3 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL3 included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 3 requirements
+** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 2.0 or (at your option) the GNU General
+** Public license version 3 or any later version approved by the KDE Free
+** Qt Foundation. The licenses are as published by the Free Software
+** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
+** 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-2.0.html and
+** https://www.gnu.org/licenses/gpl-3.0.html.
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+#include <QtTest/QTest>
+#include <Qt3DRender/qsetfence.h>
+#include <Qt3DRender/private/qsetfence_p.h>
+#include <QObject>
+#include <QSignalSpy>
+#include <Qt3DCore/qpropertyupdatedchange.h>
+#include <Qt3DCore/private/qnodecreatedchangegenerator_p.h>
+#include <Qt3DCore/qnodecreatedchange.h>
+#include <Qt3DCore/private/qscene_p.h>
+#include "testpostmanarbiter.h"
+
+class MySetFence : public Qt3DRender::QSetFence
+{
+public:
+ using Qt3DRender::QSetFence::sceneChangeEvent;
+};
+
+class tst_QSetFence : public QObject
+{
+ Q_OBJECT
+
+private Q_SLOTS:
+
+ void initTestCase()
+ {
+ qRegisterMetaType<Qt3DRender::QSetFence::HandleType>("HandleType");
+ }
+
+ void checkDefaultConstruction()
+ {
+ // GIVEN
+ Qt3DRender::QSetFence setFence;
+
+ // THEN
+ QCOMPARE(setFence.handleType(), Qt3DRender::QSetFence::NoHandle);
+ QCOMPARE(setFence.handle(), QVariant());
+ }
+
+ void checkPropertyChanges()
+ {
+ // GIVEN
+ Qt3DCore::QScene scene;
+ MySetFence setFence;
+
+ Qt3DCore::QNodePrivate::get(&setFence)->setScene(&scene);
+
+ {
+ // WHEN
+ QSignalSpy spy(&setFence, SIGNAL(handleTypeChanged(HandleType)));
+
+ // THEN
+ QVERIFY(spy.isValid());
+
+ // THEN
+ Qt3DCore::QPropertyUpdatedChangePtr valueChange(new Qt3DCore::QPropertyUpdatedChange(Qt3DCore::QNodeId()));
+ valueChange->setPropertyName("handleType");
+ valueChange->setValue(QVariant::fromValue(Qt3DRender::QSetFence::OpenGLFenceId));
+ setFence.sceneChangeEvent(valueChange);
+
+ // THEN
+ QCOMPARE(setFence.handleType(), Qt3DRender::QSetFence::OpenGLFenceId);
+ QCOMPARE(spy.count(), 1);
+
+ // WHEN
+ spy.clear();
+ setFence.sceneChangeEvent(valueChange);
+
+ // THEN
+ QCOMPARE(spy.count(), 0);
+ }
+
+ {
+ // WHEN
+ QSignalSpy spy(&setFence, SIGNAL(handleChanged(QVariant)));
+
+ // THEN
+ QVERIFY(spy.isValid());
+
+ // WHEN
+ Qt3DCore::QPropertyUpdatedChangePtr valueChange(new Qt3DCore::QPropertyUpdatedChange(Qt3DCore::QNodeId()));
+ valueChange->setPropertyName("handle");
+ valueChange->setValue(QVariant(984));
+ setFence.sceneChangeEvent(valueChange);
+
+ // THEN
+ QCOMPARE(setFence.handle(),QVariant(984));
+ QCOMPARE(spy.count(), 1);
+
+ // WHEN
+ spy.clear();
+ setFence.sceneChangeEvent(valueChange);
+
+ // THEN
+ QCOMPARE(spy.count(), 0);
+ }
+ }
+
+ void checkCreationData()
+ {
+ // GIVEN
+ Qt3DRender::QSetFence setFence;
+
+
+ // WHEN
+ QVector<Qt3DCore::QNodeCreatedChangeBasePtr> creationChanges;
+
+ {
+ Qt3DCore::QNodeCreatedChangeGenerator creationChangeGenerator(&setFence);
+ creationChanges = creationChangeGenerator.creationChanges();
+ }
+
+ // THEN
+ {
+ QCOMPARE(creationChanges.size(), 1);
+
+ const auto creationChangeData = qSharedPointerCast<Qt3DCore::QNodeCreatedChange<Qt3DRender::QSetFenceData>>(creationChanges.first());
+ const Qt3DRender::QSetFenceData cloneData = creationChangeData->data;
+
+ QCOMPARE(setFence.id(), creationChangeData->subjectId());
+ QCOMPARE(setFence.isEnabled(), true);
+ QCOMPARE(setFence.isEnabled(), creationChangeData->isNodeEnabled());
+ QCOMPARE(setFence.metaObject(), creationChangeData->metaObject());
+ }
+
+ // WHEN
+ setFence.setEnabled(false);
+
+ {
+ Qt3DCore::QNodeCreatedChangeGenerator creationChangeGenerator(&setFence);
+ creationChanges = creationChangeGenerator.creationChanges();
+ }
+
+ // THEN
+ {
+ QCOMPARE(creationChanges.size(), 1);
+
+ const auto creationChangeData = qSharedPointerCast<Qt3DCore::QNodeCreatedChange<Qt3DRender::QSetFenceData>>(creationChanges.first());
+ const Qt3DRender::QSetFenceData cloneData = creationChangeData->data;
+
+ QCOMPARE(setFence.id(), creationChangeData->subjectId());
+ QCOMPARE(setFence.isEnabled(), false);
+ QCOMPARE(setFence.isEnabled(), creationChangeData->isNodeEnabled());
+ QCOMPARE(setFence.metaObject(), creationChangeData->metaObject());
+ }
+ }
+
+};
+
+QTEST_MAIN(tst_QSetFence)
+
+#include "tst_qsetfence.moc"
diff --git a/tests/auto/render/qwaitfence/qwaitfence.pro b/tests/auto/render/qwaitfence/qwaitfence.pro
new file mode 100644
index 000000000..18ac21088
--- /dev/null
+++ b/tests/auto/render/qwaitfence/qwaitfence.pro
@@ -0,0 +1,12 @@
+TEMPLATE = app
+
+TARGET = tst_qwaitfence
+
+QT += 3dcore 3dcore-private 3drender 3drender-private testlib
+
+CONFIG += testcase
+
+SOURCES += tst_qwaitfence.cpp
+
+include(../../core/common/common.pri)
+include(../commons/commons.pri)
diff --git a/tests/auto/render/qwaitfence/tst_qwaitfence.cpp b/tests/auto/render/qwaitfence/tst_qwaitfence.cpp
new file mode 100644
index 000000000..ab3ae9b4d
--- /dev/null
+++ b/tests/auto/render/qwaitfence/tst_qwaitfence.cpp
@@ -0,0 +1,349 @@
+/****************************************************************************
+**
+** Copyright (C) 2018 Klaralvdalens Datakonsult AB (KDAB).
+** Contact: https://www.qt.io/licensing/
+**
+** This file is part of the Qt3D module of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** 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 Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 3 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL3 included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 3 requirements
+** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 2.0 or (at your option) the GNU General
+** Public license version 3 or any later version approved by the KDE Free
+** Qt Foundation. The licenses are as published by the Free Software
+** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
+** 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-2.0.html and
+** https://www.gnu.org/licenses/gpl-3.0.html.
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+
+#include <QtTest/QTest>
+#include <Qt3DRender/qwaitfence.h>
+#include <Qt3DRender/private/qwaitfence_p.h>
+#include <QObject>
+#include <QSignalSpy>
+#include <Qt3DCore/qpropertyupdatedchange.h>
+#include <Qt3DCore/private/qnodecreatedchangegenerator_p.h>
+#include <Qt3DCore/qnodecreatedchange.h>
+#include "testpostmanarbiter.h"
+
+class tst_QWaitFence : public QObject
+{
+ Q_OBJECT
+
+private Q_SLOTS:
+
+ void initTestCase()
+ {
+ qRegisterMetaType<Qt3DRender::QWaitFence::HandleType>("HandleType");
+ }
+
+ void checkDefaultConstruction()
+ {
+ // GIVEN
+ Qt3DRender::QWaitFence waitFence;
+
+ // THEN
+ QCOMPARE(waitFence.handleType(), Qt3DRender::QWaitFence::NoHandle);
+ QCOMPARE(waitFence.handle(), QVariant());
+ QCOMPARE(waitFence.waitOnCPU(), false);
+ QCOMPARE(waitFence.timeout(), quint64(-1));
+ }
+
+ void checkPropertyChanges()
+ {
+ // GIVEN
+ Qt3DRender::QWaitFence waitFence;
+
+ {
+ // WHEN
+ QSignalSpy spy(&waitFence, SIGNAL(handleTypeChanged(HandleType)));
+ const Qt3DRender::QWaitFence::HandleType newValue = Qt3DRender::QWaitFence::OpenGLFenceId;
+ waitFence.setHandleType(newValue);
+
+ // THEN
+ QVERIFY(spy.isValid());
+ QCOMPARE(waitFence.handleType(), newValue);
+ QCOMPARE(spy.count(), 1);
+
+ // WHEN
+ spy.clear();
+ waitFence.setHandleType(newValue);
+
+ // THEN
+ QCOMPARE(waitFence.handleType(), newValue);
+ QCOMPARE(spy.count(), 0);
+ }
+ {
+ // WHEN
+ QSignalSpy spy(&waitFence, SIGNAL(handleChanged(QVariant)));
+ const QVariant newValue(883);
+ waitFence.setHandle(newValue);
+
+ // THEN
+ QVERIFY(spy.isValid());
+ QCOMPARE(waitFence.handle(), newValue);
+ QCOMPARE(spy.count(), 1);
+
+ // WHEN
+ spy.clear();
+ waitFence.setHandle(newValue);
+
+ // THEN
+ QCOMPARE(waitFence.handle(), newValue);
+ QCOMPARE(spy.count(), 0);
+ }
+ {
+ // WHEN
+ QSignalSpy spy(&waitFence, SIGNAL(waitOnCPUChanged(bool)));
+ const bool newValue = true;
+ waitFence.setWaitOnCPU(newValue);
+
+ // THEN
+ QVERIFY(spy.isValid());
+ QCOMPARE(waitFence.waitOnCPU(), newValue);
+ QCOMPARE(spy.count(), 1);
+
+ // WHEN
+ spy.clear();
+ waitFence.setWaitOnCPU(newValue);
+
+ // THEN
+ QCOMPARE(waitFence.waitOnCPU(), newValue);
+ QCOMPARE(spy.count(), 0);
+ }
+ {
+ // WHEN
+ QSignalSpy spy(&waitFence, SIGNAL(timeoutChanged(quint64)));
+ const quint64 newValue = 984;
+ waitFence.setTimeout(newValue);
+
+ // THEN
+ QVERIFY(spy.isValid());
+ QCOMPARE(waitFence.timeout(), newValue);
+ QCOMPARE(spy.count(), 1);
+
+ // WHEN
+ spy.clear();
+ waitFence.setTimeout(newValue);
+
+ // THEN
+ QCOMPARE(waitFence.timeout(), newValue);
+ QCOMPARE(spy.count(), 0);
+ }
+ }
+
+ void checkCreationData()
+ {
+ // GIVEN
+ Qt3DRender::QWaitFence waitFence;
+
+ waitFence.setHandleType(Qt3DRender::QWaitFence::OpenGLFenceId);
+ waitFence.setHandle(QVariant(1200));
+ waitFence.setWaitOnCPU(true);
+ waitFence.setTimeout(1584);
+
+ // WHEN
+ QVector<Qt3DCore::QNodeCreatedChangeBasePtr> creationChanges;
+
+ {
+ Qt3DCore::QNodeCreatedChangeGenerator creationChangeGenerator(&waitFence);
+ creationChanges = creationChangeGenerator.creationChanges();
+ }
+
+ // THEN
+ {
+ QCOMPARE(creationChanges.size(), 1);
+
+ const auto creationChangeData = qSharedPointerCast<Qt3DCore::QNodeCreatedChange<Qt3DRender::QWaitFenceData>>(creationChanges.first());
+ const Qt3DRender::QWaitFenceData cloneData = creationChangeData->data;
+
+ QCOMPARE(waitFence.handleType(), cloneData.handleType);
+ QCOMPARE(waitFence.handle(), cloneData.handle);
+ QCOMPARE(waitFence.waitOnCPU(), cloneData.waitOnCPU);
+ QCOMPARE(waitFence.timeout(), cloneData.timeout);
+ QCOMPARE(waitFence.id(), creationChangeData->subjectId());
+ QCOMPARE(waitFence.isEnabled(), true);
+ QCOMPARE(waitFence.isEnabled(), creationChangeData->isNodeEnabled());
+ QCOMPARE(waitFence.metaObject(), creationChangeData->metaObject());
+ }
+
+ // WHEN
+ waitFence.setEnabled(false);
+
+ {
+ Qt3DCore::QNodeCreatedChangeGenerator creationChangeGenerator(&waitFence);
+ creationChanges = creationChangeGenerator.creationChanges();
+ }
+
+ // THEN
+ {
+ QCOMPARE(creationChanges.size(), 1);
+
+ const auto creationChangeData = qSharedPointerCast<Qt3DCore::QNodeCreatedChange<Qt3DRender::QWaitFenceData>>(creationChanges.first());
+ const Qt3DRender::QWaitFenceData cloneData = creationChangeData->data;
+
+ QCOMPARE(waitFence.handleType(), cloneData.handleType);
+ QCOMPARE(waitFence.handle(), cloneData.handle);
+ QCOMPARE(waitFence.waitOnCPU(), cloneData.waitOnCPU);
+ QCOMPARE(waitFence.timeout(), cloneData.timeout);
+ QCOMPARE(waitFence.id(), creationChangeData->subjectId());
+ QCOMPARE(waitFence.isEnabled(), false);
+ QCOMPARE(waitFence.isEnabled(), creationChangeData->isNodeEnabled());
+ QCOMPARE(waitFence.metaObject(), creationChangeData->metaObject());
+ }
+ }
+
+ void checkHandleTypeUpdate()
+ {
+ // GIVEN
+ TestArbiter arbiter;
+ Qt3DRender::QWaitFence waitFence;
+ arbiter.setArbiterOnNode(&waitFence);
+
+ {
+ // WHEN
+ waitFence.setHandleType(Qt3DRender::QWaitFence::OpenGLFenceId);
+ QCoreApplication::processEvents();
+
+ // THEN
+ QCOMPARE(arbiter.events.size(), 1);
+ auto change = arbiter.events.first().staticCast<Qt3DCore::QPropertyUpdatedChange>();
+ QCOMPARE(change->propertyName(), "handleType");
+ QCOMPARE(change->value().value<Qt3DRender::QWaitFence::HandleType>(), waitFence.handleType());
+ QCOMPARE(change->type(), Qt3DCore::PropertyUpdated);
+
+ arbiter.events.clear();
+ }
+
+ {
+ // WHEN
+ waitFence.setHandleType(Qt3DRender::QWaitFence::OpenGLFenceId);
+ QCoreApplication::processEvents();
+
+ // THEN
+ QCOMPARE(arbiter.events.size(), 0);
+ }
+ }
+
+ void checkHandleUpdate()
+ {
+ // GIVEN
+ TestArbiter arbiter;
+ Qt3DRender::QWaitFence waitFence;
+ arbiter.setArbiterOnNode(&waitFence);
+
+ {
+ // WHEN
+ waitFence.setHandle(QVariant(883));
+ QCoreApplication::processEvents();
+
+ // THEN
+ QCOMPARE(arbiter.events.size(), 1);
+ auto change = arbiter.events.first().staticCast<Qt3DCore::QPropertyUpdatedChange>();
+ QCOMPARE(change->propertyName(), "handle");
+ QCOMPARE(change->value().value<QVariant>(), waitFence.handle());
+ QCOMPARE(change->type(), Qt3DCore::PropertyUpdated);
+
+ arbiter.events.clear();
+ }
+
+ {
+ // WHEN
+ waitFence.setHandle(QVariant(883));
+ QCoreApplication::processEvents();
+
+ // THEN
+ QCOMPARE(arbiter.events.size(), 0);
+ }
+ }
+
+ void checkWaitOnCPUUpdate()
+ {
+ // GIVEN
+ TestArbiter arbiter;
+ Qt3DRender::QWaitFence waitFence;
+ arbiter.setArbiterOnNode(&waitFence);
+
+ {
+ // WHEN
+ waitFence.setWaitOnCPU(true);
+ QCoreApplication::processEvents();
+
+ // THEN
+ QCOMPARE(arbiter.events.size(), 1);
+ auto change = arbiter.events.first().staticCast<Qt3DCore::QPropertyUpdatedChange>();
+ QCOMPARE(change->propertyName(), "waitOnCPU");
+ QCOMPARE(change->value().value<bool>(), waitFence.waitOnCPU());
+ QCOMPARE(change->type(), Qt3DCore::PropertyUpdated);
+
+ arbiter.events.clear();
+ }
+
+ {
+ // WHEN
+ waitFence.setWaitOnCPU(true);
+ QCoreApplication::processEvents();
+
+ // THEN
+ QCOMPARE(arbiter.events.size(), 0);
+ }
+ }
+
+ void checkTimeoutUpdate()
+ {
+ // GIVEN
+ TestArbiter arbiter;
+ Qt3DRender::QWaitFence waitFence;
+ arbiter.setArbiterOnNode(&waitFence);
+
+ {
+ // WHEN
+ waitFence.setTimeout(quint64(600));
+ QCoreApplication::processEvents();
+
+ // THEN
+ QCOMPARE(arbiter.events.size(), 1);
+ auto change = arbiter.events.first().staticCast<Qt3DCore::QPropertyUpdatedChange>();
+ QCOMPARE(change->propertyName(), "timeout");
+ QCOMPARE(change->value().value<quint64>(), waitFence.timeout());
+ QCOMPARE(change->type(), Qt3DCore::PropertyUpdated);
+
+ arbiter.events.clear();
+ }
+
+ {
+ // WHEN
+ waitFence.setTimeout(quint64(600));
+ QCoreApplication::processEvents();
+
+ // THEN
+ QCOMPARE(arbiter.events.size(), 0);
+ }
+ }
+};
+
+QTEST_MAIN(tst_QWaitFence)
+
+#include "tst_qwaitfence.moc"
diff --git a/tests/auto/render/render.pro b/tests/auto/render/render.pro
index 9d0cfa3ed..1d4ec803b 100644
--- a/tests/auto/render/render.pro
+++ b/tests/auto/render/render.pro
@@ -99,7 +99,9 @@ qtConfig(private_tests) {
raycaster \
qscreenraycaster \
raycastingjob \
- qcamera
+ qcamera \
+ qsetfence \
+ qwaitfence
QT_FOR_CONFIG = 3dcore-private
# TO DO: These could be restored to be executed in all cases