From b1edd537c70143026ebb9eb2c9eca0d7417a398d Mon Sep 17 00:00:00 2001 From: Joerg Schaible Date: Mon, 22 Nov 2010 09:47:55 +0000 Subject: [PATCH] CSVWriter.writeValue does not use value delimiter (SANDBOX-243). git-svn-id: https://svn.apache.org/repos/asf/commons/sandbox/csv/trunk@1037647 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/commons/csv/writer/CSVWriter.java | 9 +- .../commons/csv/writer/CSVWriterTest.java | 124 ++++++++++++++++-- 2 files changed, 120 insertions(+), 13 deletions(-) diff --git a/src/java/org/apache/commons/csv/writer/CSVWriter.java b/src/java/org/apache/commons/csv/writer/CSVWriter.java index 2d4c0873..5ab7dfc6 100644 --- a/src/java/org/apache/commons/csv/writer/CSVWriter.java +++ b/src/java/org/apache/commons/csv/writer/CSVWriter.java @@ -103,13 +103,14 @@ public class CSVWriter { // value to big.. value = value.substring(0, field.getSize()); } - if (!config.isValueDelimiterIgnored()) { - // add the value delimiter.. - value = config.getValueDelimiter()+value+config.getValueDelimiter(); - } + } + if (!config.isValueDelimiterIgnored()) { + // add the value delimiter.. + value = config.getValueDelimiter()+value+config.getValueDelimiter(); } return value; } + /** * @return the CVSConfig or null if not present */ diff --git a/src/test/org/apache/commons/csv/writer/CSVWriterTest.java b/src/test/org/apache/commons/csv/writer/CSVWriterTest.java index 38fca405..39b989b6 100644 --- a/src/test/org/apache/commons/csv/writer/CSVWriterTest.java +++ b/src/test/org/apache/commons/csv/writer/CSVWriterTest.java @@ -32,6 +32,16 @@ import junit.framework.TestCase; */ public class CSVWriterTest extends TestCase { + private Map map; + + protected void setUp() throws Exception { + super.setUp(); + + map = new HashMap(); + map.put("field1", "12345"); + map.put("field2", "1234"); + } + public void testCSVConfig() { CSVWriter writer = new CSVWriter(); assertEquals(null, writer.getConfig()); @@ -41,19 +51,115 @@ public class CSVWriterTest extends TestCase { writer = new CSVWriter(config); assertEquals(config, writer.getConfig()); } - - public void testWriter() { + + public void testWriterDefaults() throws Exception { CSVWriter writer = new CSVWriter(); - CSVConfig config = new CSVConfig(); - config.addField(new CSVField("field1", 5)); - config.addField(new CSVField("field2", 4)); + CSVConfig config = getConfig(); writer.setConfig(config); StringWriter sw = new StringWriter(); writer.setWriter(sw); - Map map = new HashMap(); - map.put("field1", "12345"); - map.put("field2", "1234"); writer.writeRecord(map); - assertEquals("12345,1234\n",sw.toString()); + assertEquals("12345,1234\n", sw.toString()); + } + + public void testWriterWithExplicitDelimiter() throws Exception { + CSVWriter writer = new CSVWriter(); + CSVConfig config = getConfig(); + config.setDelimiter(';'); + config.setIgnoreDelimiter(false); + writer.setConfig(config); + StringWriter sw = new StringWriter(); + writer.setWriter(sw); + writer.writeRecord(map); + assertEquals("12345;1234\n", sw.toString()); + } + + public void testWriterIgnoringDelimiter() throws Exception { + CSVWriter writer = new CSVWriter(); + CSVConfig config = getConfig(); + config.setDelimiter(';'); + config.setIgnoreDelimiter(true); + writer.setConfig(config); + StringWriter sw = new StringWriter(); + writer.setWriter(sw); + writer.writeRecord(map); + assertEquals("123451234\n", sw.toString()); + } + + public void testWriterWithExplicitValueDelimiter() throws Exception { + CSVWriter writer = new CSVWriter(); + CSVConfig config = getConfig(); + config.setValueDelimiter('"'); + config.setIgnoreValueDelimiter(false); + writer.setConfig(config); + StringWriter sw = new StringWriter(); + writer.setWriter(sw); + writer.writeRecord(map); + assertEquals("\"12345\",\"1234\"\n", sw.toString()); + } + + public void testWriterIgnoringValueDelimiter() throws Exception { + CSVWriter writer = new CSVWriter(); + CSVConfig config = getConfig(); + config.setValueDelimiter('"'); + config.setIgnoreValueDelimiter(true); + writer.setConfig(config); + StringWriter sw = new StringWriter(); + writer.setWriter(sw); + writer.writeRecord(map); + assertEquals("12345,1234\n", sw.toString()); + } + + public void testWriterWithoutHeader() throws Exception { + CSVWriter writer = new CSVWriter(); + CSVConfig config = getConfig(); + config.setFieldHeader(false); + writer.setConfig(config); + StringWriter sw = new StringWriter(); + writer.setWriter(sw); + writer.writeRecord(map); + assertEquals("12345,1234\n", sw.toString()); + } + + // TODO: SANDBOX-324 + public void todoTestWriterWithHeader() throws Exception { + CSVWriter writer = new CSVWriter(); + CSVConfig config = getConfig(); + config.setFieldHeader(true); + writer.setConfig(config); + StringWriter sw = new StringWriter(); + writer.setWriter(sw); + writer.writeRecord(map); + assertEquals("field1,field2\n12345,1234\n", sw.toString()); + } + + public void testWriterWithExplicitRowDelimiterLF() throws Exception { + CSVWriter writer = new CSVWriter(); + CSVConfig config = getConfig(); + config.setRowDelimiter("\n"); + writer.setConfig(config); + StringWriter sw = new StringWriter(); + writer.setWriter(sw); + writer.writeRecord(map); + assertEquals("12345,1234\n", sw.toString()); + } + + public void testWriterWithExplicitRowDelimiterCRLF() throws Exception { + CSVWriter writer = new CSVWriter(); + CSVConfig config = getConfig(); + config.setRowDelimiter("\r\n"); + writer.setConfig(config); + StringWriter sw = new StringWriter(); + writer.setWriter(sw); + writer.writeRecord(map); + assertEquals("12345,1234\r\n", sw.toString()); + } + + private CSVConfig getConfig() { + CSVConfig config = new CSVConfig(); + config.addField(new CSVField("field1", 5)); + config.addField(new CSVField("field2", 4)); + + return config; } }