1/****************************************************************************
2**
3** Copyright (C) 2016 The Qt Company Ltd.
4** Contact: https://www.qt.io/licensing/
5**
6** This file is part of the QtTest module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial License Usage
10** Licensees holding valid commercial Qt licenses may use this file in
11** accordance with the commercial license agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and The Qt Company. For licensing terms
14** and conditions see https://www.qt.io/terms-conditions. For further
15** information use the contact form at https://www.qt.io/contact-us.
16**
17** GNU Lesser General Public License Usage
18** Alternatively, this file may be used under the terms of the GNU Lesser
19** General Public License version 3 as published by the Free Software
20** Foundation and appearing in the file LICENSE.LGPL3 included in the
21** packaging of this file. Please review the following information to
22** ensure the GNU Lesser General Public License version 3 requirements
23** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
24**
25** GNU General Public License Usage
26** Alternatively, this file may be used under the terms of the GNU
27** General Public License version 2.0 or (at your option) the GNU General
28** Public license version 3 or any later version approved by the KDE Free
29** Qt Foundation. The licenses are as published by the Free Software
30** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
31** included in the packaging of this file. Please review the following
32** information to ensure the GNU General Public License requirements will
33** be met: https://www.gnu.org/licenses/gpl-2.0.html and
34** https://www.gnu.org/licenses/gpl-3.0.html.
35**
36** $QT_END_LICENSE$
37**
38****************************************************************************/
39
40#include <QtCore/qmetaobject.h>
41
42#include <QtTest/qtestassert.h>
43#include <QtTest/qtestdata.h>
44#include <QtTest/private/qtesttable_p.h>
45
46#include <string.h>
47#include <stdlib.h>
48
49QT_BEGIN_NAMESPACE
50
51class QTestDataPrivate
52{
53public:
54 char *tag = nullptr;
55 QTestTable *parent = nullptr;
56 void **data = nullptr;
57 int dataCount = 0;
58};
59
60QTestData::QTestData(const char *tag, QTestTable *parent)
61{
62 QTEST_ASSERT(tag);
63 QTEST_ASSERT(parent);
64 d = new QTestDataPrivate;
65 d->tag = qstrdup(tag);
66 d->parent = parent;
67 d->data = new void *[parent->elementCount()];
68 memset(d->data, 0, parent->elementCount() * sizeof(void*));
69}
70
71QTestData::~QTestData()
72{
73 for (int i = 0; i < d->dataCount; ++i) {
74 if (d->data[i])
75 QMetaType(d->parent->elementTypeId(i)).destroy(d->data[i]);
76 }
77 delete [] d->data;
78 delete [] d->tag;
79 delete d;
80}
81
82void QTestData::append(int type, const void *data)
83{
84 QTEST_ASSERT(d->dataCount < d->parent->elementCount());
85 int expectedType = d->parent->elementTypeId(d->dataCount);
86 int dd = 0;
87 if constexpr (sizeof(qsizetype) == 8) {
88 // Compatibility with Qt 5. Passing a qsizetype to a test function expecting
89 // an int will work. This is required, as methods returning a qsizetype in Qt 6
90 // used to return an int in Qt 5.
91 if (type == QMetaType::LongLong && expectedType == QMetaType::Int) {
92 qlonglong d = *static_cast<const qlonglong *>(data);
93 if (d >= std::numeric_limits<int>::min() && d <= std::numeric_limits<int>::max()) {
94 dd = d;
95 data = &dd;
96 type = QMetaType::Int;
97 }
98 }
99 }
100 if (expectedType != type) {
101 qDebug("expected data of type '%s', got '%s' for element %d of data with tag '%s'",
102 QMetaType(expectedType).name(),
103 QMetaType(type).name(),
104 d->dataCount, d->tag);
105 QTEST_ASSERT(false);
106 }
107 d->data[d->dataCount] = QMetaType(type).create(data);
108 ++d->dataCount;
109}
110
111void *QTestData::data(int index) const
112{
113 QTEST_ASSERT(index >= 0);
114 QTEST_ASSERT(index < d->parent->elementCount());
115 return d->data[index];
116}
117
118QTestTable *QTestData::parent() const
119{
120 return d->parent;
121}
122
123const char *QTestData::dataTag() const
124{
125 return d->tag;
126}
127
128int QTestData::dataCount() const
129{
130 return d->dataCount;
131}
132
133QT_END_NAMESPACE
134