blob: 32f80d82c7123620b2d50a7fcc741fcb6a8e4a14 (
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
86
87
88
89
90
91
92
93
|
// Copyright (C) 2015 Klaralvdalens Datakonsult AB (KDAB).
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
#include <QtTest/QTest>
#include <Qt3DCore/private/qnode_p.h>
#include <Qt3DCore/private/qscene_p.h>
#include <Qt3DInput/QAction>
#include <Qt3DInput/QActionInput>
#include <Qt3DInput/private/qaction_p.h>
#include <Qt3DInput/private/qactioninput_p.h>
#include <testarbiter.h>
// We need to call QNode::clone which is protected
// We need to call QAction::sceneChangeEvent which is protected
// So we sublcass QNode instead of QObject
class tst_QAction: public Qt3DInput::QAction
{
Q_OBJECT
public:
tst_QAction()
{
}
private Q_SLOTS:
void checkPropertyUpdates()
{
// GIVEN
TestArbiter arbiter;
QScopedPointer<Qt3DInput::QAction> action(new Qt3DInput::QAction());
arbiter.setArbiterOnNode(action.data());
// WHEN
Qt3DInput::QActionInput *input = new Qt3DInput::QActionInput();
action->addInput(input);
QCoreApplication::processEvents();
// THEN
QCOMPARE(arbiter.dirtyNodes().size(), 1);
QCOMPARE(arbiter.dirtyNodes().front(), action.data());
arbiter.clear();
// WHEN
action->removeInput(input);
QCoreApplication::processEvents();
// THEN
QCOMPARE(arbiter.dirtyNodes().size(), 1);
QCOMPARE(arbiter.dirtyNodes().front(), action.data());
}
void checkActionInputBookkeeping()
{
// GIVEN
QScopedPointer<Qt3DInput::QAction> action(new Qt3DInput::QAction);
{
// WHEN
Qt3DInput::QActionInput input;
action->addInput(&input);
// THEN
QCOMPARE(input.parent(), action.data());
QCOMPARE(action->inputs().size(), 1);
}
// THEN (Should not crash and parameter be unset)
QVERIFY(action->inputs().empty());
{
// WHEN
Qt3DInput::QAction someOtherAction;
QScopedPointer<Qt3DInput::QActionInput> input(new Qt3DInput::QActionInput(&someOtherAction));
action->addInput(input.data());
// THEN
QCOMPARE(input->parent(), &someOtherAction);
QCOMPARE(action->inputs().size(), 1);
// WHEN
action.reset();
input.reset();
// THEN Should not crash when the input is destroyed (tests for failed removal of destruction helper)
}
}
};
QTEST_MAIN(tst_QAction)
#include "tst_qaction.moc"
|