/* * Copyright 2007 Kasper B. Graversen * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.supercsv.cellprocessor.joda; import static org.supercsv.cellprocessor.joda.SuperCsvTestUtils.ANONYMOUS_CSVCONTEXT; import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; import java.util.Arrays; import java.util.List; import org.joda.time.DateTime; import org.joda.time.DateTimeZone; import org.joda.time.format.DateTimeFormatter; import org.joda.time.format.ISODateTimeFormat; import org.junit.Before; import org.junit.Test; import org.supercsv.cellprocessor.ift.CellProcessor; import org.supercsv.cellprocessor.joda.mock.IdentityTransform; import org.supercsv.exception.SuperCsvCellProcessorException; /** * Tests the ParseDateTime cell processor. */ public class ParseDateTimeTest { private static final String DATE_TIME_STRING = "2013-10-25T01:02:03.000+10"; private static final DateTime DATE_TIME = new DateTime(2013, 10, 25, 1, 2, 3, 0, DateTimeZone.forOffsetHours(10)); private ParseDateTime processor1; private ParseDateTime processor2; private ParseDateTime processorChain1; private ParseDateTime processorChain2; private List<ParseDateTime> processors; private DateTimeFormatter formatter; @Before public void setUp() { formatter = ISODateTimeFormat.dateTime().withOffsetParsed(); processor1 = new ParseDateTime(); processor2 = new ParseDateTime(formatter); processorChain1 = new ParseDateTime(new IdentityTransform()); processorChain2 = new ParseDateTime(formatter, new IdentityTransform()); processors = Arrays.asList(processor1, processor2, processorChain1, processorChain2); } @Test public void testValidDateTime() { for (CellProcessor p : processors) { assertEquals(DATE_TIME, p.execute(DATE_TIME_STRING, ANONYMOUS_CSVCONTEXT)); } } @Test public void testNullInput() { for (CellProcessor p : processors) { try { p.execute(null, ANONYMOUS_CSVCONTEXT); fail("expecting SuperCsvCellProcessorException"); } catch (SuperCsvCellProcessorException e) { assertEquals( "this processor does not accept null input - " + "if the column is optional then chain an Optional() processor before this one", e.getMessage()); } } } @Test public void testNonStringInput() { for (CellProcessor p : processors) { try { p.execute(123, ANONYMOUS_CSVCONTEXT); fail("expecting SuperCsvCellProcessorException"); } catch (SuperCsvCellProcessorException e) { assertEquals( "the input value should be of type java.lang.String but is java.lang.Integer", e.getMessage()); } } } @Test public void testUnparsableString() { for (CellProcessor p : processors) { try { p.execute("not valid", ANONYMOUS_CSVCONTEXT); fail("expecting SuperCsvCellProcessorException"); } catch (SuperCsvCellProcessorException e) { assertEquals("Failed to parse value", e.getMessage()); } } } @Test(expected = NullPointerException.class) public void testConstructor2WithNullNext() { new ParseDateTime((CellProcessor) null); } @Test(expected = NullPointerException.class) public void testConstructor3WithNullFormatter() { new ParseDateTime((DateTimeFormatter) null); } @Test(expected = NullPointerException.class) public void testConstructor4WithNullFormatter() { new ParseDateTime((DateTimeFormatter) null, new IdentityTransform()); } @Test(expected = NullPointerException.class) public void testConstructor4WithNullNext() { new ParseDateTime(formatter, null); } }