/**************************************************************************** ** ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). ** Contact: Nokia Corporation (qt-info@nokia.com) ** ** This file is part of the test suite of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** No Commercial Usage ** This file contains pre-release code and may not be distributed. ** You may use this file in accordance with the terms and conditions ** contained in the Technology Preview License Agreement accompanying ** this package. ** ** GNU Lesser General Public License Usage ** Alternatively, 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. ** ** In addition, as a special exception, Nokia gives you certain ** additional rights. These rights are described in the Nokia Qt LGPL ** Exception version 1.1, included in the file LGPL_EXCEPTION.txt in this ** package. ** ** If you have questions regarding the use of this file, please contact ** Nokia at qt-info@nokia.com. ** ** ** ** ** ** ** ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include #include #include class tst_qmetaobject: public QObject { Q_OBJECT private slots: void initTestCase(); void cleanupTestCase(); void indexOfProperty_data(); void indexOfProperty(); void indexOfMethod_data(); void indexOfMethod(); void indexOfSignal_data(); void indexOfSignal(); void indexOfSlot_data(); void indexOfSlot(); }; void tst_qmetaobject::initTestCase() { } void tst_qmetaobject::cleanupTestCase() { } void tst_qmetaobject::indexOfProperty_data() { QTest::addColumn("name"); const QMetaObject *mo = &QTreeView::staticMetaObject; for (int i = 0; i < mo->propertyCount(); ++i) { QMetaProperty prop = mo->property(i); QTest::newRow(prop.name()) << QByteArray(prop.name()); } } void tst_qmetaobject::indexOfProperty() { QFETCH(QByteArray, name); const char *p = name.constData(); const QMetaObject *mo = &QTreeView::staticMetaObject; QBENCHMARK { (void)mo->indexOfProperty(p); } } void tst_qmetaobject::indexOfMethod_data() { QTest::addColumn("method"); const QMetaObject *mo = &QTreeView::staticMetaObject; for (int i = 0; i < mo->methodCount(); ++i) { QMetaMethod method = mo->method(i); QByteArray sig = method.signature(); QTest::newRow(sig) << sig; } } void tst_qmetaobject::indexOfMethod() { QFETCH(QByteArray, method); const char *p = method.constData(); const QMetaObject *mo = &QTreeView::staticMetaObject; QBENCHMARK { (void)mo->indexOfMethod(p); } } void tst_qmetaobject::indexOfSignal_data() { QTest::addColumn("signal"); const QMetaObject *mo = &QTreeView::staticMetaObject; for (int i = 0; i < mo->methodCount(); ++i) { QMetaMethod method = mo->method(i); if (method.methodType() != QMetaMethod::Signal) continue; QByteArray sig = method.signature(); QTest::newRow(sig) << sig; } } void tst_qmetaobject::indexOfSignal() { QFETCH(QByteArray, signal); const char *p = signal.constData(); const QMetaObject *mo = &QTreeView::staticMetaObject; QBENCHMARK { (void)mo->indexOfSignal(p); } } void tst_qmetaobject::indexOfSlot_data() { QTest::addColumn("slot"); const QMetaObject *mo = &QTreeView::staticMetaObject; for (int i = 0; i < mo->methodCount(); ++i) { QMetaMethod method = mo->method(i); if (method.methodType() != QMetaMethod::Slot) continue; QByteArray sig = method.signature(); QTest::newRow(sig) << sig; } } void tst_qmetaobject::indexOfSlot() { QFETCH(QByteArray, slot); const char *p = slot.constData(); const QMetaObject *mo = &QTreeView::staticMetaObject; QBENCHMARK { (void)mo->indexOfSlot(p); } } QTEST_MAIN(tst_qmetaobject) #include "main.moc"