/*
* Copyright (c) 2008-2012, Stephen Colebourne & Michael Nascimento Santos
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* * 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.
*
* * Neither the name of JSR-310 nor the names of its 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 javax.time.chrono.global;
import static org.testng.Assert.assertEquals;
import static org.testng.Assert.assertFalse;
import static org.testng.Assert.assertTrue;
import java.time.DateTimeException;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.Month;
import java.time.ZoneOffset;
import java.time.calendrical.ChronoUnit;
import java.time.calendrical.DateTimeAdjusters;
import java.time.chrono.Chrono;
import java.time.chrono.ChronoLocalDate;
import java.time.chrono.ChronoLocalDateTime;
import java.time.chrono.ChronoZonedDateTime;
import java.time.chrono.ISOChrono;
import java.time.chrono.global.MinguoChrono;
import org.testng.Assert;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
/**
* Test.
*/
@Test
public class TestMinguoChrono {
// -----------------------------------------------------------------------
// Chrono.ofName("Minguo") Lookup by name
// -----------------------------------------------------------------------
@Test(groups = { "tck" })
public void test_chrono_byName() {
Chrono<MinguoChrono> c = MinguoChrono.INSTANCE;
Chrono<?> test = Chrono.of("Minguo");
Assert.assertNotNull(test, "The Minguo calendar could not be found byName");
Assert.assertEquals(test.getId(), "Minguo", "ID mismatch");
Assert.assertEquals(test.getCalendarType(), "roc", "Type mismatch");
Assert.assertEquals(test, c);
}
// -----------------------------------------------------------------------
// creation, toLocalDate()
// -----------------------------------------------------------------------
@DataProvider(name = "samples")
Object[][] data_samples() {
return new Object[][] { { MinguoChrono.INSTANCE.date(1, 1, 1), LocalDate.of(1912, 1, 1) },
{ MinguoChrono.INSTANCE.date(1, 1, 2), LocalDate.of(1912, 1, 2) },
{ MinguoChrono.INSTANCE.date(1, 1, 3), LocalDate.of(1912, 1, 3) },
{ MinguoChrono.INSTANCE.date(2, 1, 1), LocalDate.of(1913, 1, 1) },
{ MinguoChrono.INSTANCE.date(3, 1, 1), LocalDate.of(1914, 1, 1) },
{ MinguoChrono.INSTANCE.date(3, 12, 6), LocalDate.of(1914, 12, 6) },
{ MinguoChrono.INSTANCE.date(4, 1, 1), LocalDate.of(1915, 1, 1) },
{ MinguoChrono.INSTANCE.date(4, 7, 3), LocalDate.of(1915, 7, 3) },
{ MinguoChrono.INSTANCE.date(4, 7, 4), LocalDate.of(1915, 7, 4) },
{ MinguoChrono.INSTANCE.date(5, 1, 1), LocalDate.of(1916, 1, 1) },
{ MinguoChrono.INSTANCE.date(100, 3, 3), LocalDate.of(2011, 3, 3) },
{ MinguoChrono.INSTANCE.date(101, 10, 28), LocalDate.of(2012, 10, 28) },
{ MinguoChrono.INSTANCE.date(101, 10, 29), LocalDate.of(2012, 10, 29) }, };
}
@Test(dataProvider = "samples", groups = { "tck" })
public void test_toLocalDate(ChronoLocalDate<MinguoChrono> minguo, LocalDate iso) {
assertEquals(LocalDate.from(minguo), iso);
}
@Test(dataProvider = "samples", groups = { "tck" })
public void test_fromCalendrical(ChronoLocalDate<MinguoChrono> minguo, LocalDate iso) {
assertEquals(MinguoChrono.INSTANCE.date(iso), minguo);
}
@SuppressWarnings("unused")
@Test(dataProvider = "samples", groups = { "implementation" })
public void test_MinguoDate(ChronoLocalDate<MinguoChrono> minguoDate, LocalDate iso) {
ChronoLocalDate<MinguoChrono> hd = minguoDate;
ChronoLocalDateTime<MinguoChrono> hdt = hd.atTime(LocalTime.NOON);
ZoneOffset zo = ZoneOffset.ofHours(1);
ChronoZonedDateTime<MinguoChrono> hzdt = hdt.atZone(zo);
hdt = hdt.plus(1, ChronoUnit.YEARS);
hdt = hdt.plus(1, ChronoUnit.MONTHS);
hdt = hdt.plus(1, ChronoUnit.DAYS);
hdt = hdt.plus(1, ChronoUnit.HOURS);
hdt = hdt.plus(1, ChronoUnit.MINUTES);
hdt = hdt.plus(1, ChronoUnit.SECONDS);
hdt = hdt.plus(1, ChronoUnit.NANOS);
ChronoLocalDateTime<MinguoChrono> a2 = hzdt.getDateTime();
ChronoLocalDate<MinguoChrono> a3 = a2.getDate();
ChronoLocalDate<MinguoChrono> a5 = hzdt.getDate();
// System.out.printf(" d: %s, dt: %s; odt: %s; zodt: %s; a4: %s%n", date, hdt, hodt, hzdt, a5);
}
@Test()
public void test_MinguoChrono() {
ChronoLocalDate<MinguoChrono> h1 = MinguoChrono.ERA_ROC.date(1, 2, 3);
ChronoLocalDate<MinguoChrono> h2 = h1;
ChronoLocalDateTime<MinguoChrono> h3 = h2.atTime(LocalTime.NOON);
@SuppressWarnings("unused")
ChronoZonedDateTime<MinguoChrono> h4 = h3.atZone(ZoneOffset.UTC);
}
@DataProvider(name = "badDates")
Object[][] data_badDates() {
return new Object[][] { { 1912, 0, 0 },
{ 1912, -1, 1 }, { 1912, 0, 1 }, { 1912, 14, 1 }, { 1912, 15, 1 },
{ 1912, 1, -1 }, { 1912, 1, 0 }, { 1912, 1, 32 }, { 1912, 2, 29 }, { 1912, 2, 30 },
{ 1912, 12, -1 }, { 1912, 12, 0 }, { 1912, 12, 32 }, };
}
@Test(dataProvider = "badDates", groups = { "tck" }, expectedExceptions = DateTimeException.class)
public void test_badDates(int year, int month, int dom) {
MinguoChrono.INSTANCE.date(year, month, dom);
}
// -----------------------------------------------------------------------
// with(DateTimeAdjuster)
// -----------------------------------------------------------------------
@Test(groups = { "tck" })
public void test_adjust1() {
ChronoLocalDate<MinguoChrono> base = MinguoChrono.INSTANCE.date(2012, 10, 29);
ChronoLocalDate<MinguoChrono> test = base.with(DateTimeAdjusters.lastDayOfMonth());
assertEquals(test, MinguoChrono.INSTANCE.date(2012, 10, 31));
}
@Test(groups = { "tck" })
public void test_adjust2() {
ChronoLocalDate<MinguoChrono> base = MinguoChrono.INSTANCE.date(1728, 12, 2);
ChronoLocalDate<MinguoChrono> test = base.with(DateTimeAdjusters.lastDayOfMonth());
assertEquals(test, MinguoChrono.INSTANCE.date(1728, 12, 31));
}
// -----------------------------------------------------------------------
// MinguoDate.with(Local*)
// -----------------------------------------------------------------------
@Test(groups = { "tck" })
public void test_adjust_toLocalDate() {
ChronoLocalDate<MinguoChrono> minguo = MinguoChrono.INSTANCE.date(99, 1, 4);
ChronoLocalDate<MinguoChrono> test = minguo.with(LocalDate.of(2012, 7, 6));
assertEquals(test, MinguoChrono.INSTANCE.date(101, 7, 6));
}
@Test(groups = { "tck" }, expectedExceptions = DateTimeException.class)
public void test_adjust_toMonth() {
ChronoLocalDate<MinguoChrono> minguo = MinguoChrono.INSTANCE.date(1726, 1, 4);
minguo.with(Month.APRIL);
}
// -----------------------------------------------------------------------
// LocalDate.with(MinguoDate)
// -----------------------------------------------------------------------
@Test(groups = { "tck" })
public void test_LocalDate_adjustToMinguoDate() {
ChronoLocalDate<MinguoChrono> minguo = MinguoChrono.INSTANCE.date(101, 10, 29);
LocalDate test = LocalDate.MIN_DATE.with(minguo);
assertEquals(test, LocalDate.of(2012, 10, 29));
}
@Test(groups = { "tck" })
public void test_LocalDateTime_adjustToMinguoDate() {
ChronoLocalDate<MinguoChrono> minguo = MinguoChrono.INSTANCE.date(101, 10, 29);
LocalDateTime test = LocalDateTime.MIN_DATE_TIME.with(minguo);
assertEquals(test, LocalDateTime.of(2012, 10, 29, 0, 0));
}
// -----------------------------------------------------------------------
// toString()
// -----------------------------------------------------------------------
@DataProvider(name = "toString")
Object[][] data_toString() {
return new Object[][] { { MinguoChrono.INSTANCE.date(1, 1, 1), "Minguo ROC 1-01-01" },
{ MinguoChrono.INSTANCE.date(1728, 10, 28), "Minguo ROC 1728-10-28" },
{ MinguoChrono.INSTANCE.date(1728, 10, 29), "Minguo ROC 1728-10-29" },
{ MinguoChrono.INSTANCE.date(1727, 12, 5), "Minguo ROC 1727-12-05" },
{ MinguoChrono.INSTANCE.date(1727, 12, 6), "Minguo ROC 1727-12-06" }, };
}
@Test(dataProvider = "toString", groups = { "tck" })
public void test_toString(ChronoLocalDate<MinguoChrono> minguo, String expected) {
assertEquals(minguo.toString(), expected);
}
// -----------------------------------------------------------------------
// equals()
// -----------------------------------------------------------------------
@Test(groups = "tck")
public void test_equals_true() {
assertTrue(MinguoChrono.INSTANCE.equals(MinguoChrono.INSTANCE));
}
@Test(groups = "tck")
public void test_equals_false() {
assertFalse(MinguoChrono.INSTANCE.equals(ISOChrono.INSTANCE));
}
}