Convert new test into a proper JUnit test
This commit is contained in:
parent
4224a3289c
commit
70c9418e71
|
@ -50,12 +50,17 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.NoSuchElementException;
|
import java.util.NoSuchElementException;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
import org.apache.commons.io.input.BOMInputStream;
|
import org.apache.commons.io.input.BOMInputStream;
|
||||||
import org.apache.commons.io.input.BrokenInputStream;
|
import org.apache.commons.io.input.BrokenInputStream;
|
||||||
|
import org.apache.commons.lang3.stream.Streams.FailableStream;
|
||||||
import org.junit.jupiter.api.Assertions;
|
import org.junit.jupiter.api.Assertions;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.junit.jupiter.params.ParameterizedTest;
|
||||||
|
import org.junit.jupiter.params.provider.EnumSource;
|
||||||
|
import org.junit.jupiter.params.provider.ValueSource;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* CSVParserTest
|
* CSVParserTest
|
||||||
|
@ -1380,36 +1385,19 @@ public class CSVParserTest {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@ParameterizedTest
|
||||||
public void testParsingPrintedEmptyFirstColumn() throws Exception {
|
@EnumSource(CSVFormat.Predefined.class)
|
||||||
|
public void testParsingPrintedEmptyFirstColumn(final CSVFormat.Predefined format) throws Exception {
|
||||||
final String[][] lines = { { "a", "b" }, { "", "x" } };
|
final String[][] lines = { { "a", "b" }, { "", "x" } };
|
||||||
Exception firstException = null;
|
final StringWriter buf = new StringWriter();
|
||||||
for (final CSVFormat.Predefined format : CSVFormat.Predefined.values()) {
|
try (CSVPrinter printer = new CSVPrinter(buf, format.getFormat())) {
|
||||||
try {
|
printer.printRecords(Stream.of(lines));
|
||||||
final StringWriter buf = new StringWriter();
|
|
||||||
try (CSVPrinter printer = new CSVPrinter(buf, format.getFormat())) {
|
|
||||||
for (final String[] line : lines) {
|
|
||||||
printer.printRecord((Object[]) line);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
try (CSVParser csvRecords = new CSVParser(new StringReader(buf.toString()), format.getFormat())) {
|
|
||||||
for (final String[] line : lines) {
|
|
||||||
assertArrayEquals(line, csvRecords.nextRecord().values());
|
|
||||||
}
|
|
||||||
assertNull(csvRecords.nextRecord());
|
|
||||||
}
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
final Exception detailedException = new RuntimeException("format: " + format, e);
|
|
||||||
if (firstException == null) {
|
|
||||||
firstException = detailedException;
|
|
||||||
} else {
|
|
||||||
firstException.addSuppressed(detailedException);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
try (CSVParser parser = new CSVParser(new StringReader(buf.toString()), format.getFormat())) {
|
||||||
if (firstException != null) {
|
for (final String[] line : lines) {
|
||||||
throw firstException;
|
assertArrayEquals(line, parser.nextRecord().values());
|
||||||
|
}
|
||||||
|
assertNull(parser.nextRecord());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue