/*
* $Id: DateTimeTest.java,v 1.4 2005/12/12 11:17:27 fortuna Exp $
*
* Created on 30/06/2005
*
* Copyright (c) 2005, Ben Fortuna
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* o Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* o Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* o Neither the name of Ben Fortuna nor the names of any other contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.fortuna.ical4j.model;
import java.text.ParseException;
import java.util.Calendar;
import java.util.TimeZone;
import net.fortuna.ical4j.util.TimeZones;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import junit.framework.TestCase;
/**
* @author Ben Fortuna
*
*/
public class DateTimeTest extends TestCase {
private static Log log = LogFactory.getLog(DateTimeTest.class);
/*
* Class under test for void DateTime(long)
*/
public void testDateTimelong() {
DateTime dt = new DateTime(0);
// dt.setTimeZone(TimeZoneRegistryFactory.getInstance().createRegistry().getTimeZone(TimeZones.GMT_ID));
// assertEquals("19700101T000000", dt.toString());
dt.setUtc(true);
assertEquals("19700101T000000Z", dt.toString());
}
/*
* Class under test for void DateTime(Date)
*/
public void testDateTimeDate() {
Calendar cal = Calendar.getInstance(); //TimeZone.getTimeZone("GMT"));
cal.set(Calendar.YEAR, 1984);
// months are zero-based..
cal.set(Calendar.MONTH, 3);
cal.set(Calendar.DAY_OF_MONTH, 17);
cal.set(Calendar.HOUR_OF_DAY, 3);
cal.set(Calendar.MINUTE, 15);
cal.set(Calendar.SECOND, 34);
assertEquals("19840417T031534", new DateTime(cal.getTime()).toString());
}
/*
* Class under test for void DateTime(String)
*/
public void testDateTimeString() throws Exception {
try {
new DateTime("20050630");
fail("Should throw ParseException");
}
catch (ParseException pe) {
log.error("Exception occurred", pe);
}
assertEquals("20050630T093000", new DateTime("20050630T093000").toString());
assertEquals("20050630T093000Z", new DateTime("20050630T093000Z").toString());
}
/**
* Test equality of DateTime instances created using different constructors.
* @throws ParseException
*/
public void testDateTimeEquals() throws ParseException {
DateTime date1 = new DateTime("20050101T093000");
Calendar calendar = Calendar.getInstance(); //TimeZone.getTimeZone("Etc/UTC"));
calendar.clear();
calendar.set(2005, 0, 1, 9, 30, 00);
calendar.set(Calendar.MILLISECOND, 1);
DateTime date2 = new DateTime(calendar.getTime());
assertEquals(date1.toString(), date2.toString());
assertEquals(date1, date2);
}
}