diff options
author | Kent Hansen <kent.hansen@nokia.com> | 2011-10-10 14:33:56 +0200 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2011-10-19 10:25:31 +0200 |
commit | f8b89fa50725a8d25c76bbf96e622e061d3417a4 (patch) | |
tree | 83f7c673023454ae741b0871f54e4fa421eae6db /tests/benchmarks/corelib/kernel/qmetatype/tst_qmetatype.cpp | |
parent | 9e92ecde74d33eddd39de88472964fb20feaaebf (diff) |
Add benchmarks for QMetaType::construct()
Change-Id: Ia5883c5712e5d634b0e62189b639209eb3d5cd93
Reviewed-by: Jędrzej Nowacki <jedrzej.nowacki@nokia.com>
Diffstat (limited to 'tests/benchmarks/corelib/kernel/qmetatype/tst_qmetatype.cpp')
-rw-r--r-- | tests/benchmarks/corelib/kernel/qmetatype/tst_qmetatype.cpp | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/tests/benchmarks/corelib/kernel/qmetatype/tst_qmetatype.cpp b/tests/benchmarks/corelib/kernel/qmetatype/tst_qmetatype.cpp index 413feba2e2..f58365b9df 100644 --- a/tests/benchmarks/corelib/kernel/qmetatype/tst_qmetatype.cpp +++ b/tests/benchmarks/corelib/kernel/qmetatype/tst_qmetatype.cpp @@ -76,6 +76,11 @@ private slots: void constructCoreType(); void constructCoreTypeCopy_data(); void constructCoreTypeCopy(); + + void constructInPlace_data(); + void constructInPlace(); + void constructInPlaceCopy_data(); + void constructInPlaceCopy(); }; tst_QMetaType::tst_QMetaType() @@ -281,5 +286,49 @@ void tst_QMetaType::constructCoreTypeCopy() } } +void tst_QMetaType::constructInPlace_data() +{ + constructCoreType_data(); +} + +void tst_QMetaType::constructInPlace() +{ + QFETCH(int, typeId); + int size = QMetaType::sizeOf(typeId); + void *storage = qMallocAligned(size, 2 * sizeof(qlonglong)); + QCOMPARE(QMetaType::construct(typeId, storage, /*copy=*/0), storage); + QMetaType::destruct(typeId, storage); + QBENCHMARK { + for (int i = 0; i < 100000; ++i) { + QMetaType::construct(typeId, storage, /*copy=*/0); + QMetaType::destruct(typeId, storage); + } + } + qFreeAligned(storage); +} + +void tst_QMetaType::constructInPlaceCopy_data() +{ + constructCoreType_data(); +} + +void tst_QMetaType::constructInPlaceCopy() +{ + QFETCH(int, typeId); + int size = QMetaType::sizeOf(typeId); + void *storage = qMallocAligned(size, 2 * sizeof(qlonglong)); + void *other = QMetaType::create(typeId); + QCOMPARE(QMetaType::construct(typeId, storage, other), storage); + QMetaType::destruct(typeId, storage); + QBENCHMARK { + for (int i = 0; i < 100000; ++i) { + QMetaType::construct(typeId, storage, other); + QMetaType::destruct(typeId, storage); + } + } + QMetaType::destroy(typeId, other); + qFreeAligned(storage); +} + QTEST_MAIN(tst_QMetaType) #include "tst_qmetatype.moc" |