From c7a398170fe3bc8b0a9c0014d8e8183e392eda83 Mon Sep 17 00:00:00 2001 From: Ben Culkin Date: Mon, 14 Dec 2020 18:24:47 -0500 Subject: Implement NestList NestList is a recursive list structure, inspired by the way lists work in Rakudo (formerly Perl 6). --- src/test/java/bjc/esodata/NestListTest.java | 119 ++++++++++++++++++++++++++++ 1 file changed, 119 insertions(+) create mode 100644 src/test/java/bjc/esodata/NestListTest.java (limited to 'src/test/java/bjc/esodata') diff --git a/src/test/java/bjc/esodata/NestListTest.java b/src/test/java/bjc/esodata/NestListTest.java new file mode 100644 index 0000000..ff3723e --- /dev/null +++ b/src/test/java/bjc/esodata/NestListTest.java @@ -0,0 +1,119 @@ +package bjc.esodata; + +import static org.junit.Assert.*; + +import java.util.*; + +import org.junit.*; + +import bjc.*; + +@SuppressWarnings("javadoc") +public class NestListTest +{ + + @Test + public void testAddItemElement() { + NestList nl = new NestList<>(); + + assertEquals("NestLists are created empty", 0, nl.size()); + + nl.addItems("hello", "there"); + + assertEquals("Adding two items to an empty NestList makes it size 2", + 2, nl.size()); + } + + @Test + public void testAddItemNestListOfElement() { + NestList nl = new NestList<>(); + + NestList nl2 = new NestList<>(); + + nl2.addItem("friend"); + + nl.addItems("hello", "there"); + nl.addItem(nl2); + + assertEquals("Adding a sublist increases the size of NestList by 1", + 3, nl.size()); + } + + @Test + public void testAddSublist() { + NestList nl = new NestList<>(); + + nl.addSublist("here", "is", "a"); + nl.addItem("thing"); + + assertEquals("addSublist increases size of NestList by 1", 2, nl.size()); + } + + @Test + public void testFlatIterator() { + NestList nl1 = new NestList<>(); + NestList nl2 = new NestList<>(); + NestList nl3 = new NestList<>(); + + nl1.addItems("of", "means"); + + nl2.addItem(nl1); + + nl3.addItem("Hello"); + nl3.addSublist("my", "unfortunate"); + nl3.addItem("friend"); + nl3.addItem(nl2); + + TestUtils.assertIteratorEquals(nl3.flatIterator(), + "Hello", "my", "unfortunate", "friend", "of", "means"); + } + + @Test + public void testFlatten() { + NestList nl1A = new NestList<>(); + NestList nl2A = new NestList<>(); + NestList nl3A = new NestList<>(); + + nl1A.addItems("of", "means"); + + nl2A.addItem(nl1A); + + nl3A.addItem("Hello"); + nl3A.addSublist("my", "unfortunate"); + nl3A.addItem("friend"); + nl3A.addItem(nl2A); + + NestList nl1B = new NestList<>(); + NestList nl2B = new NestList<>(); + + nl1B.addItems("of", "means"); + + nl2B.addItems("Hello", "my", "unfortunate", "friend"); + nl2B.addItem(nl1B); + + assertEquals("Flatten removes one level of nesting", + nl2B, nl3A.flatten()); + } + + @Test + public void testDeepFlatten() { + NestList nl1 = new NestList<>(); + NestList nl2 = new NestList<>(); + NestList nl3 = new NestList<>(); + + nl1.addItems("of", "means"); + + nl2.addItem(nl1); + + nl3.addItem("Hello"); + nl3.addSublist("my", "unfortunate"); + nl3.addItem("friend"); + nl3.addItem(nl2); + + List testList = Arrays.asList( + "Hello", "my", "unfortunate", "friend", "of", "means"); + + assertEquals("deepFlatten flattens out all sublists", + testList, nl3.deepFlatten()); + } +} -- cgit v1.2.3