From 2a262e05fae77dbd7dc37bf2d423278527a68605 Mon Sep 17 00:00:00 2001 From: Tatu Saloranta Date: Thu, 29 Apr 2021 21:23:45 -0700 Subject: [PATCH] Add CSV unit tests --- .../csv/deser/BasicCSVParserTest.java | 3 +- .../csv/deser/BlogPost2021AprilTest.java | 130 ++++++++++++++++++ 2 files changed, 132 insertions(+), 1 deletion(-) create mode 100644 csv/src/test/java/com/fasterxml/jackson/dataformat/csv/deser/BlogPost2021AprilTest.java diff --git a/csv/src/test/java/com/fasterxml/jackson/dataformat/csv/deser/BasicCSVParserTest.java b/csv/src/test/java/com/fasterxml/jackson/dataformat/csv/deser/BasicCSVParserTest.java index b5ea124f..1b2d36f8 100644 --- a/csv/src/test/java/com/fasterxml/jackson/dataformat/csv/deser/BasicCSVParserTest.java +++ b/csv/src/test/java/com/fasterxml/jackson/dataformat/csv/deser/BasicCSVParserTest.java @@ -14,7 +14,8 @@ import static org.junit.Assert.assertArrayEquals; -public class BasicCSVParserTest extends ModuleTestBase { +public class BasicCSVParserTest extends ModuleTestBase +{ @JsonPropertyOrder({"x", "y", "z"}) public static class Point { public int x; diff --git a/csv/src/test/java/com/fasterxml/jackson/dataformat/csv/deser/BlogPost2021AprilTest.java b/csv/src/test/java/com/fasterxml/jackson/dataformat/csv/deser/BlogPost2021AprilTest.java new file mode 100644 index 00000000..f17ded55 --- /dev/null +++ b/csv/src/test/java/com/fasterxml/jackson/dataformat/csv/deser/BlogPost2021AprilTest.java @@ -0,0 +1,130 @@ +package com.fasterxml.jackson.dataformat.csv.deser; + +import java.util.Arrays; +import java.util.List; +import java.util.Map; + +import com.fasterxml.jackson.annotation.JsonPropertyOrder; +import com.fasterxml.jackson.core.type.TypeReference; +import com.fasterxml.jackson.databind.MappingIterator; +import com.fasterxml.jackson.dataformat.csv.CsvMapper; +import com.fasterxml.jackson.dataformat.csv.CsvParser; +import com.fasterxml.jackson.dataformat.csv.CsvSchema; +import com.fasterxml.jackson.dataformat.csv.ModuleTestBase; + +// Tests written to support a blog post written about Jackson +// CSV module... +public class BlogPost2021AprilTest + extends ModuleTestBase +{ + @JsonPropertyOrder({ "x", "y", "visible" }) + static class Point { + public int x, y; + public boolean visible; + } + + private final String SIMPLE_CSV = "1,2,true\n" + +"2,9,false\n" + +"-13,0,true\n"; + + private final String HEADER_CSV = "x, y, visible\n" + + SIMPLE_CSV; + + private final CsvMapper MAPPER = new CsvMapper(); + + public void testAsListOfLists() throws Exception + { + List> all = MAPPER + .readerFor(new TypeReference>>() {} ) + .with(CsvParser.Feature.WRAP_AS_ARRAY) + .readValue(SIMPLE_CSV); + _assertListOfLists(all); + } + + public void testAsSequenceOfListsOfStrings() throws Exception + { + MappingIterator> it = MAPPER + .readerForListOf(String.class) + .with(CsvParser.Feature.WRAP_AS_ARRAY) + .readValues(SIMPLE_CSV); + List> all = it.readAll(); +/* while (it.hasNextValue()) { + List line = it.nextValue(); + System.out.println("Line: "+line); + } + */ + _assertListOfLists(all); + } + + private void _assertListOfLists(List> all) { + assertEquals(3, all.size()); + assertEquals(Arrays.asList("1", "2", "true"), all.get(0)); + assertEquals(Arrays.asList("2", "9", "false"), all.get(1)); + assertEquals(Arrays.asList("-13", "0", "true"), all.get(2)); + } + + public void testAsSequenceOfMaps() throws Exception + { + CsvSchema schema = CsvSchema.builder() + .addColumn("x") + .addColumn("y") + .addColumn("visible") + .build(); + try (MappingIterator> it = MAPPER + .readerForMapOf(String.class) + .with(schema) + .readValues(SIMPLE_CSV)) { + assertTrue(it.hasNextValue()); + Map map = it.nextValue(); + assertEquals(3, map.size()); + assertEquals("1", map.get("x")); + assertEquals("2", map.get("y")); + assertEquals("true", map.get("visible")); + + assertTrue(it.hasNextValue()); + map = it.nextValue(); + assertEquals(3, map.size()); + assertEquals("2", map.get("x")); + assertEquals("9", map.get("y")); + assertEquals("false", map.get("visible")); + + assertTrue(it.hasNextValue()); + map = it.nextValue(); + assertEquals(3, map.size()); + assertEquals("-13", map.get("x")); + assertEquals("0", map.get("y")); + assertEquals("true", map.get("visible")); + + assertFalse(it.hasNextValue()); + } + } + + public void testAsSequenceOfPOJOsWithHeader() throws Exception + { + CsvSchema schemaWithHeader = CsvSchema.emptySchema().withHeader(); + try (MappingIterator it = MAPPER + .readerFor(Point.class) + .with(schemaWithHeader) + .readValues(HEADER_CSV)) { + assertTrue(it.hasNextValue()); + Point p = it.nextValue(); + assertEquals(1, p.x); + assertEquals(2, p.y); + assertEquals(true, p.visible); + + assertTrue(it.hasNextValue()); + p = it.nextValue(); + assertEquals(2, p.x); + assertEquals(9, p.y); + assertEquals(false, p.visible); + + assertTrue(it.hasNextValue()); + p = it.nextValue(); + assertEquals(-13, p.x); + assertEquals(0, p.y); + assertEquals(true, p.visible); + + assertFalse(it.hasNextValue()); + } + } +}