diff options
author | Tobias Hunger <tobias.hunger@qt.io> | 2018-03-15 13:00:05 +0100 |
---|---|---|
committer | Tobias Hunger <tobias.hunger@qt.io> | 2018-03-15 14:04:10 +0000 |
commit | 3ef6f35cf6d68fad241d744b7cfa2e3adec496f2 (patch) | |
tree | acf18c77eafc2909700f183a47d5f3e2bc0135b8 /tests/auto | |
parent | 805b28b8b76f3919e3b70218a4373fbaaede577c (diff) | |
download | qt-creator-3ef6f35cf6d68fad241d744b7cfa2e3adec496f2.tar.gz |
PointerAlgorithm: Fix take and takeDefault
Fix take unit tests to actually test the correct template instance,
add more unit tests for takeDefault.
Change-Id: I51f5b17b6478a8c1388a91840edfb9c702697b28
Reviewed-by: Eike Ziller <eike.ziller@qt.io>
Diffstat (limited to 'tests/auto')
-rw-r--r-- | tests/auto/pointeralgorithm/tst_pointeralgorithm.cpp | 48 |
1 files changed, 31 insertions, 17 deletions
diff --git a/tests/auto/pointeralgorithm/tst_pointeralgorithm.cpp b/tests/auto/pointeralgorithm/tst_pointeralgorithm.cpp index 807d598655..d160768c5f 100644 --- a/tests/auto/pointeralgorithm/tst_pointeralgorithm.cpp +++ b/tests/auto/pointeralgorithm/tst_pointeralgorithm.cpp @@ -50,6 +50,7 @@ private slots: void toRawPointer(); void toReferences(); void take(); + void takeOrDefault(); }; @@ -283,25 +284,38 @@ void tst_PointerAlgorithm::toReferences() void tst_PointerAlgorithm::take() { { - QList<Struct> v {1, 3, 5, 6, 7, 8, 9, 11, 13, 15, 13, 16, 17}; - Utils::optional<Struct> r1 = Utils::take(v, [](const Struct &s) { return s.member == 13; }); - QVERIFY(static_cast<bool>(r1)); - QCOMPARE(r1.value().member, 13); - Utils::optional<Struct> r2 = Utils::take(v, [](const Struct &s) { return s.member == 13; }); - QVERIFY(static_cast<bool>(r2)); - QCOMPARE(r2.value().member, 13); - Utils::optional<Struct> r3 = Utils::take(v, [](const Struct &s) { return s.member == 13; }); - QVERIFY(!static_cast<bool>(r3)); - - Utils::optional<Struct> r4 = Utils::take(v, &Struct::isEven); - QVERIFY(static_cast<bool>(r4)); - QCOMPARE(r4.value().member, 6); + std::vector<std::unique_ptr<int>> vector; + vector.emplace_back(std::make_unique<int>(5)); + vector.emplace_back(std::make_unique<int>(2)); + vector.emplace_back(std::make_unique<int>(6)); + vector.emplace_back(std::make_unique<int>(7)); + vector.emplace_back(std::unique_ptr<int>()); + std::vector<int *> ptrVector = Utils::toRawPointer(vector); + int foo = 42; + + QVERIFY(Utils::take(vector, ptrVector.at(0)).value().get() == ptrVector.at(0)); + QVERIFY(Utils::take(vector, ptrVector.at(0)) == Utils::nullopt); + QVERIFY(Utils::take(vector, &foo) == Utils::nullopt); + QVERIFY(Utils::take(vector, nullptr).value().get() == nullptr); } +} + +void tst_PointerAlgorithm::takeOrDefault() +{ { - QList<Struct> v {0, 0, 0, 0, 0, 0, 1, 2, 3}; - Utils::optional<Struct> r1 = Utils::take(v, &Struct::member); - QVERIFY(static_cast<bool>(r1)); - QCOMPARE(r1.value().member, 1); + std::vector<std::unique_ptr<int>> vector; + vector.emplace_back(std::make_unique<int>(5)); + vector.emplace_back(std::make_unique<int>(2)); + vector.emplace_back(std::make_unique<int>(6)); + vector.emplace_back(std::make_unique<int>(7)); + vector.emplace_back(std::unique_ptr<int>()); + std::vector<int *> ptrVector = Utils::toRawPointer(vector); + int foo = 42; + + QVERIFY(Utils::takeOrDefault(vector, ptrVector.at(0)).get() == ptrVector.at(0)); + QVERIFY(Utils::takeOrDefault(vector, ptrVector.at(0)).get() == nullptr); + QVERIFY(Utils::takeOrDefault(vector, &foo).get() == nullptr); + QVERIFY(Utils::takeOrDefault(vector, nullptr).get() == nullptr); } } |