/* * Copyright (C) 2011 Apple Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. */ #include "config.h" #include "MoveOnly.h" #include namespace TestWebKitAPI { TEST(WTF_Deque, Iterator) { Deque deque; deque.append(11); deque.prepend(10); deque.append(12); deque.append(13); Deque::iterator it = deque.begin(); Deque::iterator end = deque.end(); EXPECT_TRUE(end != it); EXPECT_EQ(10, *it); ++it; EXPECT_EQ(11, *it); ++it; EXPECT_EQ(12, *it); ++it; EXPECT_EQ(13, *it); ++it; EXPECT_TRUE(end == it); } TEST(WTF_Deque, InitializerList) { Deque deque = { 1, 2, 3, 4 }; EXPECT_EQ(4u, deque.size()); auto it = deque.begin(); auto end = deque.end(); EXPECT_TRUE(end != it); EXPECT_EQ(1, *it); ++it; EXPECT_EQ(2, *it); ++it; EXPECT_EQ(3, *it); ++it; EXPECT_EQ(4, *it); ++it; EXPECT_TRUE(end == it); } TEST(WTF, DequeReverseIterator) { Deque deque; deque.append(11); deque.prepend(10); deque.append(12); deque.append(13); Deque::reverse_iterator it = deque.rbegin(); Deque::reverse_iterator end = deque.rend(); EXPECT_TRUE(end != it); EXPECT_EQ(13, *it); ++it; EXPECT_EQ(12, *it); ++it; EXPECT_EQ(11, *it); ++it; EXPECT_EQ(10, *it); ++it; EXPECT_TRUE(end == it); } TEST(WTF_Deque, Remove) { Deque deque; deque.append(11); deque.prepend(10); deque.append(12); deque.append(13); EXPECT_EQ(10, deque.first()); EXPECT_EQ(13, deque.last()); deque.removeLast(); EXPECT_EQ(10, deque.first()); EXPECT_EQ(12, deque.last()); deque.removeFirst(); EXPECT_EQ(11, deque.first()); EXPECT_EQ(12, deque.last()); deque.removeFirst(); EXPECT_EQ(12, deque.first()); EXPECT_EQ(12, deque.last()); deque.removeLast(); EXPECT_TRUE(deque.isEmpty()); } TEST(WTF_Deque, MoveOnly) { Deque deque; deque.append(MoveOnly(1)); deque.prepend(MoveOnly(0)); EXPECT_EQ(0U, deque.first().value()); EXPECT_EQ(1U, deque.last().value()); auto first = deque.takeFirst(); EXPECT_EQ(0U, first.value()); auto last = deque.takeLast(); EXPECT_EQ(1U, last.value()); } TEST(WTF_Deque, MoveConstructor) { Deque deque; for (unsigned i = 0; i < 10; ++i) deque.append(MoveOnly(i)); EXPECT_EQ(10u, deque.size()); Deque deque2 = WTFMove(deque); EXPECT_EQ(10u, deque2.size()); unsigned i = 0; for (auto& element : deque2) { EXPECT_EQ(i, element.value()); ++i; } } TEST(WTF_Deque, MoveAssignmentOperator) { Deque deque1; for (unsigned i = 0; i < 10; ++i) deque1.append(MoveOnly(i)); EXPECT_EQ(10u, deque1.size()); Deque deque2; for (unsigned i = 0; i < 10; ++i) deque2.append(MoveOnly(i * 2)); deque1 = WTFMove(deque2); EXPECT_EQ(10u, deque2.size()); unsigned i = 0; for (auto& element : deque1) { EXPECT_EQ(i * 2, element.value()); ++i; } } } // namespace TestWebKitAPI