#include "tests/LinkedListTests.h" #include "data/LinkedList.h" #include "test/Test.h" struct LinkedListTester { int a; LinkedListTester(int a_) : a(a_) { } LinkedListTester(const LinkedListTester&) = delete; LinkedListTester(LinkedListTester&&) = delete; LinkedListTester& operator=(const LinkedListTester&) = delete; LinkedListTester& operator=(LinkedListTester&&) = delete; }; using IntList = Core::LinkedList; using String = Core::ArrayString<128>; template static String build(const T& t) { String s; CORE_TEST_FALSE(s.append(t)); return s; } static void testWithoutCopyOrMove() { Core::LinkedList list; CORE_TEST_NOT_NULL(list.add(3)); } static void testAdd() { IntList list; CORE_TEST_NOT_NULL(list.add(5)); auto iter = list.begin(); CORE_TEST_EQUAL(5, *iter); CORE_TEST_EQUAL(1, list.getLength()); } static void testMultipleAdd() { IntList list; CORE_TEST_NOT_NULL(list.add(4)); CORE_TEST_NOT_NULL(list.add(3)); CORE_TEST_NOT_NULL(list.add(2)); auto iter = list.begin(); CORE_TEST_EQUAL(4, *iter); CORE_TEST_EQUAL(3, *(++iter)); CORE_TEST_EQUAL(2, *(++iter)); CORE_TEST_EQUAL(3, list.getLength()); } static void testClear() { IntList list; CORE_TEST_NOT_NULL(list.add(5)); CORE_TEST_NOT_NULL(list.add(4)); list.clear(); CORE_TEST_EQUAL(0, list.getLength()); CORE_TEST_FALSE(list.begin() != list.end()); } static void testBigAdd() { IntList list; for(int i = 0; i < 100000; i++) { CORE_TEST_NOT_NULL(list.add(i)); } auto iter = list.begin(); for(int i = 0; i < list.getLength(); i++) { CORE_TEST_EQUAL(i, *iter); ++iter; } CORE_TEST_EQUAL(100000, list.getLength()); } static void testCopy() { IntList list; CORE_TEST_NOT_NULL(list.add(1)); CORE_TEST_NOT_NULL(list.add(2)); CORE_TEST_NOT_NULL(list.add(3)); IntList copy; CORE_TEST_FALSE(copy.copyFrom(list)); CORE_TEST_EQUAL(list.getLength(), copy.getLength()); auto iterA = list.begin(); auto iterB = copy.begin(); for(int i = 0; i < copy.getLength() && i < list.getLength(); i++) { CORE_TEST_EQUAL(*iterA, *iterB); ++iterA; ++iterB; } } static void testMove() { IntList list; CORE_TEST_NOT_NULL(list.add(1)); CORE_TEST_NOT_NULL(list.add(2)); CORE_TEST_NOT_NULL(list.add(3)); const IntList move(Core::move(list)); CORE_TEST_EQUAL(0, list.getLength()); CORE_TEST_EQUAL(3, move.getLength()); auto iter = move.begin(); CORE_TEST_EQUAL(1, *iter); CORE_TEST_EQUAL(2, *(++iter)); CORE_TEST_EQUAL(3, *(++iter)); } static void testMoveAssignment() { IntList list; CORE_TEST_NOT_NULL(list.add(1)); CORE_TEST_NOT_NULL(list.add(2)); CORE_TEST_NOT_NULL(list.add(3)); IntList move; move = Core::move(list); CORE_TEST_EQUAL(0, list.getLength()); CORE_TEST_EQUAL(3, move.getLength()); auto iter = move.begin(); CORE_TEST_EQUAL(1, *iter); CORE_TEST_EQUAL(2, *(++iter)); CORE_TEST_EQUAL(3, *(++iter)); } static void testToString1() { IntList list; CORE_TEST_NOT_NULL(list.add(1)); CORE_TEST_NOT_NULL(list.add(243)); CORE_TEST_NOT_NULL(list.add(-423)); CORE_TEST_EQUAL(build("[1, 243, -423]"), build(list)); } static void testToString2() { IntList list; CORE_TEST_NOT_NULL(list.add(1)); CORE_TEST_EQUAL(build("[1]"), build(list)); } static void testToString3() { IntList list; CORE_TEST_EQUAL(build("[]"), build(list)); } static void testRemove() { IntList list; IntList::Node* a = list.add(4); IntList::Node* b = list.add(3); IntList::Node* c = list.add(2); IntList::Node* d = list.add(1); CORE_TEST_NOT_NULL(a); CORE_TEST_NOT_NULL(b); CORE_TEST_NOT_NULL(c); CORE_TEST_NOT_NULL(c); list.remove(b); auto iter = list.begin(); CORE_TEST_EQUAL(4, *iter); CORE_TEST_EQUAL(2, *(++iter)); CORE_TEST_EQUAL(1, *(++iter)); CORE_TEST_EQUAL(3, list.getLength()); list.remove(a); iter = list.begin(); CORE_TEST_EQUAL(2, *iter); CORE_TEST_EQUAL(1, *(++iter)); CORE_TEST_EQUAL(2, list.getLength()); list.remove(d); iter = list.begin(); CORE_TEST_EQUAL(2, *iter); CORE_TEST_EQUAL(1, list.getLength()); list.remove(c); CORE_TEST_FALSE(list.begin() != list.end()); CORE_TEST_EQUAL(0, list.getLength()); CORE_TEST_NULL(a); CORE_TEST_NULL(b); CORE_TEST_NULL(c); CORE_TEST_NULL(c); } static void testRemoveFirst() { IntList list; CORE_TEST_NOT_NULL(list.add(4)); CORE_TEST_NOT_NULL(list.add(3)); CORE_TEST_NOT_NULL(list.add(2)); CORE_TEST_NOT_NULL(list.add(1)); list.removeFirst(); auto iter = list.begin(); CORE_TEST_EQUAL(3, *iter); CORE_TEST_EQUAL(2, *(++iter)); CORE_TEST_EQUAL(1, *(++iter)); CORE_TEST_EQUAL(3, list.getLength()); list.removeFirst(); iter = list.begin(); CORE_TEST_EQUAL(2, *iter); CORE_TEST_EQUAL(1, *(++iter)); CORE_TEST_EQUAL(2, list.getLength()); list.removeFirst(); iter = list.begin(); CORE_TEST_EQUAL(1, *iter); CORE_TEST_EQUAL(1, list.getLength()); list.removeFirst(); CORE_TEST_FALSE(list.begin() != list.end()); CORE_TEST_EQUAL(0, list.getLength()); list.removeFirst(); CORE_TEST_FALSE(list.begin() != list.end()); CORE_TEST_EQUAL(0, list.getLength()); } static void testRemoveLast() { IntList list; CORE_TEST_NOT_NULL(list.add(4)); CORE_TEST_NOT_NULL(list.add(3)); CORE_TEST_NOT_NULL(list.add(2)); CORE_TEST_NOT_NULL(list.add(1)); list.removeLast(); auto iter = list.begin(); CORE_TEST_EQUAL(4, *iter); CORE_TEST_EQUAL(3, *(++iter)); CORE_TEST_EQUAL(2, *(++iter)); CORE_TEST_EQUAL(3, list.getLength()); list.removeLast(); iter = list.begin(); CORE_TEST_EQUAL(4, *iter); CORE_TEST_EQUAL(3, *(++iter)); CORE_TEST_EQUAL(2, list.getLength()); list.removeLast(); iter = list.begin(); CORE_TEST_EQUAL(4, *iter); CORE_TEST_EQUAL(1, list.getLength()); list.removeLast(); CORE_TEST_FALSE(list.begin() != list.end()); CORE_TEST_EQUAL(0, list.getLength()); list.removeLast(); CORE_TEST_FALSE(list.begin() != list.end()); CORE_TEST_EQUAL(0, list.getLength()); } void Core::LinkedListTests::test() { testWithoutCopyOrMove(); testAdd(); testMultipleAdd(); testClear(); testBigAdd(); testCopy(); testMove(); testMoveAssignment(); testToString1(); testToString2(); testToString3(); testRemove(); testRemoveFirst(); testRemoveLast(); }