/*
* Copyright 2010, 2011, 2012 Christopher Pheby
*
* 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.jadira.usertype.dateandtime.legacyjdk;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import java.util.Calendar;
import java.util.Date;
import java.util.TimeZone;
import org.jadira.usertype.dateandtime.legacyjdk.testmodel.LegacyDateHolder;
import org.jadira.usertype.dateandtime.shared.dbunit.AbstractDatabaseTest;
import org.junit.Test;
public class TestPersistentDate extends AbstractDatabaseTest<LegacyDateHolder> {
private static final Calendar GMT_CAL = Calendar.getInstance(TimeZone.getTimeZone("GMT"));
private static final Date[] dateTimes = new Date[2];
static {
GMT_CAL.clear();
GMT_CAL.set(2004, 2 - 1, 25, 12, 11, 10);
dateTimes[0] = GMT_CAL.getTime();
GMT_CAL.clear();
GMT_CAL.set(1980, 3 - 1, 11, 13, 12, 11);
dateTimes[1] = GMT_CAL.getTime();
}
public TestPersistentDate() {
super(TestLegacyJdkSuite.getFactory());
}
@Test
public void testPersist() {
for (int i = 0; i < dateTimes.length; i++) {
LegacyDateHolder item = new LegacyDateHolder();
item.setId(i);
item.setName("test_" + i);
item.setDate(dateTimes[i]);
persist(item);
}
for (int i = 0; i < dateTimes.length; i++) {
LegacyDateHolder item = find(LegacyDateHolder.class, i);
assertNotNull(item);
assertEquals(i, item.getId());
assertEquals("test_" + i, item.getName());
if (dateTimes[i] == null) {
assertNull(item.getDate());
} else {
assertEquals(dateTimes[i].toString(), item.getDate().toString());
}
}
verifyDatabaseTable();
}
}