blob: 0cd8eed5fed8275ace6157b2823a3f65c40ca0eb [file] [log] [blame]
/*
* Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* 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 tck.java.time.chrono;
import static org.testng.Assert.assertEquals;
import static org.testng.Assert.fail;
import java.time.DateTimeException;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.ZoneId;
import java.time.ZonedDateTime;
import java.time.chrono.Chronology;
import java.time.chrono.IsoChronology;
import java.time.format.ResolverStyle;
import java.time.temporal.ChronoField;
import java.time.temporal.TemporalAccessor;
import java.time.temporal.TemporalAdjusters;
import java.time.temporal.TemporalField;
import java.time.temporal.TemporalQueries;
import java.time.temporal.TemporalQuery;
import java.util.HashMap;
import java.util.Map;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
/**
* Test.
*/
@Test
public class TCKIsoChronology {
// Can only work with IsoChronology here
// others may be in separate module
@Test
public void factory_from_TemporalAccessor_dateWithChronlogy() {
assertEquals(Chronology.from(LocalDate.of(2012, 6, 30)), IsoChronology.INSTANCE);
}
@Test
public void factory_from_TemporalAccessor_chronology() {
assertEquals(Chronology.from(new TemporalAccessor() {
@Override
public boolean isSupported(TemporalField field) {
throw new UnsupportedOperationException();
}
@Override
public long getLong(TemporalField field) {
throw new UnsupportedOperationException();
}
@SuppressWarnings("unchecked")
@Override
public <R> R query(TemporalQuery<R> query) {
if (query == TemporalQueries.chronology()) {
return (R) IsoChronology.INSTANCE;
}
throw new UnsupportedOperationException();
}
}), IsoChronology.INSTANCE);
}
@Test
public void factory_from_TemporalAccessor_noChronology() {
assertEquals(Chronology.from(new TemporalAccessor() {
@Override
public boolean isSupported(TemporalField field) {
throw new UnsupportedOperationException();
}
@Override
public long getLong(TemporalField field) {
throw new UnsupportedOperationException();
}
@Override
public <R> R query(TemporalQuery<R> query) {
if (query == TemporalQueries.chronology()) {
return null;
}
throw new UnsupportedOperationException();
}
}), IsoChronology.INSTANCE);
}
@Test(expectedExceptions=NullPointerException.class)
public void factory_from_TemporalAccessor_null() {
Chronology.from(null);
}
//-----------------------------------------------------------------------
@Test
public void test_date_TemporalAccessor() {
assertEquals(IsoChronology.INSTANCE.date(new TemporalAccessor() {
@Override
public boolean isSupported(TemporalField field) {
if (field == ChronoField.EPOCH_DAY) {
return true;
}
throw new UnsupportedOperationException();
}
@Override
public long getLong(TemporalField field) {
if (field == ChronoField.EPOCH_DAY) {
return LocalDate.of(2012, 6, 30).toEpochDay();
}
throw new UnsupportedOperationException();
}
@SuppressWarnings("unchecked")
@Override
public <R> R query(TemporalQuery<R> query) {
if (query == TemporalQueries.localDate()) {
return (R) LocalDate.of(2012, 6, 30);
}
throw new UnsupportedOperationException();
}
}), LocalDate.of(2012, 6, 30));
}
@Test(expectedExceptions=NullPointerException.class)
public void test_date_TemporalAccessor_null() {
IsoChronology.INSTANCE.date(null);
}
//-----------------------------------------------------------------------
@Test
public void test_localDateTime_TemporalAccessor() {
assertEquals(IsoChronology.INSTANCE.localDateTime(new TemporalAccessor() {
@Override
public boolean isSupported(TemporalField field) {
if (field == ChronoField.EPOCH_DAY || field == ChronoField.NANO_OF_DAY) {
return true;
}
throw new UnsupportedOperationException();
}
@Override
public long getLong(TemporalField field) {
if (field == ChronoField.EPOCH_DAY) {
return LocalDate.of(2012, 6, 30).toEpochDay();
}
if (field == ChronoField.NANO_OF_DAY) {
return LocalTime.of(12, 30, 40).toNanoOfDay();
}
throw new UnsupportedOperationException();
}
@SuppressWarnings("unchecked")
@Override
public <R> R query(TemporalQuery<R> query) {
if (query == TemporalQueries.localDate()) {
return (R) LocalDate.of(2012, 6, 30);
}
if (query == TemporalQueries.localTime()) {
return (R) LocalTime.of(12, 30, 40);
}
throw new UnsupportedOperationException();
}
}), LocalDateTime.of(2012, 6, 30, 12, 30, 40));
}
@Test(expectedExceptions=NullPointerException.class)
public void test_localDateTime_TemporalAccessor_null() {
IsoChronology.INSTANCE.localDateTime(null);
}
//-----------------------------------------------------------------------
@Test
public void test_zonedDateTime_TemporalAccessor() {
assertEquals(IsoChronology.INSTANCE.zonedDateTime(new TemporalAccessor() {
@Override
public boolean isSupported(TemporalField field) {
if (field == ChronoField.EPOCH_DAY || field == ChronoField.NANO_OF_DAY ||
field == ChronoField.INSTANT_SECONDS || field == ChronoField.NANO_OF_SECOND) {
return true;
}
throw new UnsupportedOperationException();
}
@Override
public long getLong(TemporalField field) {
if (field == ChronoField.INSTANT_SECONDS) {
return ZonedDateTime.of(2012, 6, 30, 12, 30, 40, 0, ZoneId.of("Europe/London")).toEpochSecond();
}
if (field == ChronoField.NANO_OF_SECOND) {
return 0;
}
if (field == ChronoField.EPOCH_DAY) {
return LocalDate.of(2012, 6, 30).toEpochDay();
}
if (field == ChronoField.NANO_OF_DAY) {
return LocalTime.of(12, 30, 40).toNanoOfDay();
}
throw new UnsupportedOperationException();
}
@SuppressWarnings("unchecked")
@Override
public <R> R query(TemporalQuery<R> query) {
if (query == TemporalQueries.localDate()) {
return (R) LocalDate.of(2012, 6, 30);
}
if (query == TemporalQueries.localTime()) {
return (R) LocalTime.of(12, 30, 40);
}
if (query == TemporalQueries.zoneId() || query == TemporalQueries.zone()) {
return (R) ZoneId.of("Europe/London");
}
throw new UnsupportedOperationException();
}
}), ZonedDateTime.of(2012, 6, 30, 12, 30, 40, 0, ZoneId.of("Europe/London")));
}
@Test(expectedExceptions=NullPointerException.class)
public void test_zonedDateTime_TemporalAccessor_null() {
IsoChronology.INSTANCE.zonedDateTime(null);
}
//-----------------------------------------------------------------------
//-----------------------------------------------------------------------
@DataProvider(name = "resolve_yearOfEra")
Object[][] data_resolve_yearOfEra() {
return new Object[][] {
// era only
{ResolverStyle.STRICT, -1, null, null, null, null},
{ResolverStyle.SMART, -1, null, null, null, null},
{ResolverStyle.LENIENT, -1, null, null, null, null},
{ResolverStyle.STRICT, 0, null, null, ChronoField.ERA, 0},
{ResolverStyle.SMART, 0, null, null, ChronoField.ERA, 0},
{ResolverStyle.LENIENT, 0, null, null, ChronoField.ERA, 0},
{ResolverStyle.STRICT, 1, null, null, ChronoField.ERA, 1},
{ResolverStyle.SMART, 1, null, null, ChronoField.ERA, 1},
{ResolverStyle.LENIENT, 1, null, null, ChronoField.ERA, 1},
{ResolverStyle.STRICT, 2, null, null, null, null},
{ResolverStyle.SMART, 2, null, null, null, null},
{ResolverStyle.LENIENT, 2, null, null, null, null},
// era and year-of-era
{ResolverStyle.STRICT, -1, 2012, null, null, null},
{ResolverStyle.SMART, -1, 2012, null, null, null},
{ResolverStyle.LENIENT, -1, 2012, null, null, null},
{ResolverStyle.STRICT, 0, 2012, null, ChronoField.YEAR, -2011},
{ResolverStyle.SMART, 0, 2012, null, ChronoField.YEAR, -2011},
{ResolverStyle.LENIENT, 0, 2012, null, ChronoField.YEAR, -2011},
{ResolverStyle.STRICT, 1, 2012, null, ChronoField.YEAR, 2012},
{ResolverStyle.SMART, 1, 2012, null, ChronoField.YEAR, 2012},
{ResolverStyle.LENIENT, 1, 2012, null, ChronoField.YEAR, 2012},
{ResolverStyle.STRICT, 2, 2012, null, null, null},
{ResolverStyle.SMART, 2, 2012, null, null, null},
{ResolverStyle.LENIENT, 2, 2012, null, null, null},
// year-of-era only
{ResolverStyle.STRICT, null, 2012, null, ChronoField.YEAR_OF_ERA, 2012},
{ResolverStyle.SMART, null, 2012, null, ChronoField.YEAR, 2012},
{ResolverStyle.LENIENT, null, 2012, null, ChronoField.YEAR, 2012},
{ResolverStyle.STRICT, null, Integer.MAX_VALUE, null, null, null},
{ResolverStyle.SMART, null, Integer.MAX_VALUE, null, null, null},
{ResolverStyle.LENIENT, null, Integer.MAX_VALUE, null, ChronoField.YEAR, Integer.MAX_VALUE},
// year-of-era and year
{ResolverStyle.STRICT, null, 2012, 2012, ChronoField.YEAR, 2012},
{ResolverStyle.SMART, null, 2012, 2012, ChronoField.YEAR, 2012},
{ResolverStyle.LENIENT, null, 2012, 2012, ChronoField.YEAR, 2012},
{ResolverStyle.STRICT, null, 2012, -2011, ChronoField.YEAR, -2011},
{ResolverStyle.SMART, null, 2012, -2011, ChronoField.YEAR, -2011},
{ResolverStyle.LENIENT, null, 2012, -2011, ChronoField.YEAR, -2011},
{ResolverStyle.STRICT, null, 2012, 2013, null, null},
{ResolverStyle.SMART, null, 2012, 2013, null, null},
{ResolverStyle.LENIENT, null, 2012, 2013, null, null},
{ResolverStyle.STRICT, null, 2012, -2013, null, null},
{ResolverStyle.SMART, null, 2012, -2013, null, null},
{ResolverStyle.LENIENT, null, 2012, -2013, null, null},
};
}
@Test(dataProvider = "resolve_yearOfEra")
public void test_resolve_yearOfEra(ResolverStyle style, Integer e, Integer yoe, Integer y, ChronoField field, Integer expected) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
if (e != null) {
fieldValues.put(ChronoField.ERA, (long) e);
}
if (yoe != null) {
fieldValues.put(ChronoField.YEAR_OF_ERA, (long) yoe);
}
if (y != null) {
fieldValues.put(ChronoField.YEAR, (long) y);
}
if (field != null) {
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, style);
assertEquals(date, null);
assertEquals(fieldValues.get(field), (Long) expected.longValue());
assertEquals(fieldValues.size(), 1);
} else {
try {
IsoChronology.INSTANCE.resolveDate(fieldValues, style);
fail("Should have failed");
} catch (DateTimeException ex) {
// expected
}
}
}
//-----------------------------------------------------------------------
//-----------------------------------------------------------------------
@DataProvider(name = "resolve_ymd")
Object[][] data_resolve_ymd() {
return new Object[][] {
{2012, 1, -365, date(2010, 12, 31), false, false},
{2012, 1, -364, date(2011, 1, 1), false, false},
{2012, 1, -31, date(2011, 11, 30), false, false},
{2012, 1, -30, date(2011, 12, 1), false, false},
{2012, 1, -12, date(2011, 12, 19), false, false},
{2012, 1, 1, date(2012, 1, 1), true, true},
{2012, 1, 27, date(2012, 1, 27), true, true},
{2012, 1, 28, date(2012, 1, 28), true, true},
{2012, 1, 29, date(2012, 1, 29), true, true},
{2012, 1, 30, date(2012, 1, 30), true, true},
{2012, 1, 31, date(2012, 1, 31), true, true},
{2012, 1, 59, date(2012, 2, 28), false, false},
{2012, 1, 60, date(2012, 2, 29), false, false},
{2012, 1, 61, date(2012, 3, 1), false, false},
{2012, 1, 365, date(2012, 12, 30), false, false},
{2012, 1, 366, date(2012, 12, 31), false, false},
{2012, 1, 367, date(2013, 1, 1), false, false},
{2012, 1, 367 + 364, date(2013, 12, 31), false, false},
{2012, 1, 367 + 365, date(2014, 1, 1), false, false},
{2012, 2, 1, date(2012, 2, 1), true, true},
{2012, 2, 28, date(2012, 2, 28), true, true},
{2012, 2, 29, date(2012, 2, 29), true, true},
{2012, 2, 30, date(2012, 3, 1), date(2012, 2, 29), false},
{2012, 2, 31, date(2012, 3, 2), date(2012, 2, 29), false},
{2012, 2, 32, date(2012, 3, 3), false, false},
{2012, -12, 1, date(2010, 12, 1), false, false},
{2012, -11, 1, date(2011, 1, 1), false, false},
{2012, -1, 1, date(2011, 11, 1), false, false},
{2012, 0, 1, date(2011, 12, 1), false, false},
{2012, 1, 1, date(2012, 1, 1), true, true},
{2012, 12, 1, date(2012, 12, 1), true, true},
{2012, 13, 1, date(2013, 1, 1), false, false},
{2012, 24, 1, date(2013, 12, 1), false, false},
{2012, 25, 1, date(2014, 1, 1), false, false},
{2012, 6, -31, date(2012, 4, 30), false, false},
{2012, 6, -30, date(2012, 5, 1), false, false},
{2012, 6, -1, date(2012, 5, 30), false, false},
{2012, 6, 0, date(2012, 5, 31), false, false},
{2012, 6, 1, date(2012, 6, 1), true, true},
{2012, 6, 30, date(2012, 6, 30), true, true},
{2012, 6, 31, date(2012, 7, 1), date(2012, 6, 30), false},
{2012, 6, 61, date(2012, 7, 31), false, false},
{2012, 6, 62, date(2012, 8, 1), false, false},
{2011, 2, 1, date(2011, 2, 1), true, true},
{2011, 2, 28, date(2011, 2, 28), true, true},
{2011, 2, 29, date(2011, 3, 1), date(2011, 2, 28), false},
{2011, 2, 30, date(2011, 3, 2), date(2011, 2, 28), false},
{2011, 2, 31, date(2011, 3, 3), date(2011, 2, 28), false},
{2011, 2, 32, date(2011, 3, 4), false, false},
};
}
@Test(dataProvider = "resolve_ymd")
public void test_resolve_ymd_lenient(int y, int m, int d, LocalDate expected, Object smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.MONTH_OF_YEAR, (long) m);
fieldValues.put(ChronoField.DAY_OF_MONTH, (long) d);
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.LENIENT);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
}
@Test(dataProvider = "resolve_ymd")
public void test_resolve_ymd_smart(int y, int m, int d, LocalDate expected, Object smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.MONTH_OF_YEAR, (long) m);
fieldValues.put(ChronoField.DAY_OF_MONTH, (long) d);
if (Boolean.TRUE.equals(smart)) {
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.SMART);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
} else if (smart instanceof LocalDate) {
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.SMART);
assertEquals(date, smart);
} else {
try {
IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.SMART);
fail("Should have failed");
} catch (DateTimeException ex) {
// expected
}
}
}
@Test(dataProvider = "resolve_ymd")
public void test_resolve_ymd_strict(int y, int m, int d, LocalDate expected, Object smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.MONTH_OF_YEAR, (long) m);
fieldValues.put(ChronoField.DAY_OF_MONTH, (long) d);
if (strict) {
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.STRICT);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
} else {
try {
IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.STRICT);
fail("Should have failed");
} catch (DateTimeException ex) {
// expected
}
}
}
//-----------------------------------------------------------------------
//-----------------------------------------------------------------------
@DataProvider(name = "resolve_yd")
Object[][] data_resolve_yd() {
return new Object[][] {
{2012, -365, date(2010, 12, 31), false, false},
{2012, -364, date(2011, 1, 1), false, false},
{2012, -31, date(2011, 11, 30), false, false},
{2012, -30, date(2011, 12, 1), false, false},
{2012, -12, date(2011, 12, 19), false, false},
{2012, -1, date(2011, 12, 30), false, false},
{2012, 0, date(2011, 12, 31), false, false},
{2012, 1, date(2012, 1, 1), true, true},
{2012, 2, date(2012, 1, 2), true, true},
{2012, 31, date(2012, 1, 31), true, true},
{2012, 32, date(2012, 2, 1), true, true},
{2012, 59, date(2012, 2, 28), true, true},
{2012, 60, date(2012, 2, 29), true, true},
{2012, 61, date(2012, 3, 1), true, true},
{2012, 365, date(2012, 12, 30), true, true},
{2012, 366, date(2012, 12, 31), true, true},
{2012, 367, date(2013, 1, 1), false, false},
{2012, 367 + 364, date(2013, 12, 31), false, false},
{2012, 367 + 365, date(2014, 1, 1), false, false},
{2011, 59, date(2011, 2, 28), true, true},
{2011, 60, date(2011, 3, 1), true, true},
};
}
@Test(dataProvider = "resolve_yd")
public void test_resolve_yd_lenient(int y, int d, LocalDate expected, boolean smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.DAY_OF_YEAR, (long) d);
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.LENIENT);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
}
@Test(dataProvider = "resolve_yd")
public void test_resolve_yd_smart(int y, int d, LocalDate expected, boolean smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.DAY_OF_YEAR, (long) d);
if (smart) {
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.SMART);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
} else {
try {
IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.SMART);
fail("Should have failed");
} catch (DateTimeException ex) {
// expected
}
}
}
@Test(dataProvider = "resolve_yd")
public void test_resolve_yd_strict(int y, int d, LocalDate expected, boolean smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.DAY_OF_YEAR, (long) d);
if (strict) {
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.STRICT);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
} else {
try {
IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.STRICT);
fail("Should have failed");
} catch (DateTimeException ex) {
// expected
}
}
}
//-----------------------------------------------------------------------
//-----------------------------------------------------------------------
@DataProvider(name = "resolve_ymaa")
Object[][] data_resolve_ymaa() {
return new Object[][] {
{2012, 1, 1, -365, date(2010, 12, 31), false, false},
{2012, 1, 1, -364, date(2011, 1, 1), false, false},
{2012, 1, 1, -31, date(2011, 11, 30), false, false},
{2012, 1, 1, -30, date(2011, 12, 1), false, false},
{2012, 1, 1, -12, date(2011, 12, 19), false, false},
{2012, 1, 1, 1, date(2012, 1, 1), true, true},
{2012, 1, 1, 59, date(2012, 2, 28), false, false},
{2012, 1, 1, 60, date(2012, 2, 29), false, false},
{2012, 1, 1, 61, date(2012, 3, 1), false, false},
{2012, 1, 1, 365, date(2012, 12, 30), false, false},
{2012, 1, 1, 366, date(2012, 12, 31), false, false},
{2012, 1, 1, 367, date(2013, 1, 1), false, false},
{2012, 1, 1, 367 + 364, date(2013, 12, 31), false, false},
{2012, 1, 1, 367 + 365, date(2014, 1, 1), false, false},
{2012, 2, 0, 1, date(2012, 1, 25), false, false},
{2012, 2, 0, 7, date(2012, 1, 31), false, false},
{2012, 2, 1, 1, date(2012, 2, 1), true, true},
{2012, 2, 1, 7, date(2012, 2, 7), true, true},
{2012, 2, 2, 1, date(2012, 2, 8), true, true},
{2012, 2, 2, 7, date(2012, 2, 14), true, true},
{2012, 2, 3, 1, date(2012, 2, 15), true, true},
{2012, 2, 3, 7, date(2012, 2, 21), true, true},
{2012, 2, 4, 1, date(2012, 2, 22), true, true},
{2012, 2, 4, 7, date(2012, 2, 28), true, true},
{2012, 2, 5, 1, date(2012, 2, 29), true, true},
{2012, 2, 5, 2, date(2012, 3, 1), true, false},
{2012, 2, 5, 7, date(2012, 3, 6), true, false},
{2012, 2, 6, 1, date(2012, 3, 7), false, false},
{2012, 2, 6, 7, date(2012, 3, 13), false, false},
{2012, 12, 1, 1, date(2012, 12, 1), true, true},
{2012, 12, 5, 1, date(2012, 12, 29), true, true},
{2012, 12, 5, 2, date(2012, 12, 30), true, true},
{2012, 12, 5, 3, date(2012, 12, 31), true, true},
{2012, 12, 5, 4, date(2013, 1, 1), true, false},
{2012, 12, 5, 7, date(2013, 1, 4), true, false},
{2012, -12, 1, 1, date(2010, 12, 1), false, false},
{2012, -11, 1, 1, date(2011, 1, 1), false, false},
{2012, -1, 1, 1, date(2011, 11, 1), false, false},
{2012, 0, 1, 1, date(2011, 12, 1), false, false},
{2012, 1, 1, 1, date(2012, 1, 1), true, true},
{2012, 12, 1, 1, date(2012, 12, 1), true, true},
{2012, 13, 1, 1, date(2013, 1, 1), false, false},
{2012, 24, 1, 1, date(2013, 12, 1), false, false},
{2012, 25, 1, 1, date(2014, 1, 1), false, false},
{2011, 2, 1, 1, date(2011, 2, 1), true, true},
{2011, 2, 4, 7, date(2011, 2, 28), true, true},
{2011, 2, 5, 1, date(2011, 3, 1), true, false},
};
}
@Test(dataProvider = "resolve_ymaa")
public void test_resolve_ymaa_lenient(int y, int m, int w, int d, LocalDate expected, boolean smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.MONTH_OF_YEAR, (long) m);
fieldValues.put(ChronoField.ALIGNED_WEEK_OF_MONTH, (long) w);
fieldValues.put(ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH, (long) d);
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.LENIENT);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
}
@Test(dataProvider = "resolve_ymaa")
public void test_resolve_ymaa_smart(int y, int m, int w, int d, LocalDate expected, boolean smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.MONTH_OF_YEAR, (long) m);
fieldValues.put(ChronoField.ALIGNED_WEEK_OF_MONTH, (long) w);
fieldValues.put(ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH, (long) d);
if (smart) {
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.SMART);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
} else {
try {
IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.SMART);
fail("Should have failed");
} catch (DateTimeException ex) {
// expected
}
}
}
@Test(dataProvider = "resolve_ymaa")
public void test_resolve_ymaa_strict(int y, int m, int w, int d, LocalDate expected, boolean smart, boolean strict) {
Map<TemporalField, Long> fieldValues = new HashMap<>();
fieldValues.put(ChronoField.YEAR, (long) y);
fieldValues.put(ChronoField.MONTH_OF_YEAR, (long) m);
fieldValues.put(ChronoField.ALIGNED_WEEK_OF_MONTH, (long) w);
fieldValues.put(ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH, (long) d);
if (strict) {
LocalDate date = IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.STRICT);
assertEquals(date, expected);
assertEquals(fieldValues.size(), 0);
} else {
try {
IsoChronology.INSTANCE.resolveDate(fieldValues, ResolverStyle.STRICT);
fail("Should have failed");
} catch (DateTimeException ex) {
// expected
}
}
}
//-----------------------------------------------------------------------
private static LocalDate date(int y, int m, int d) {
return LocalDate.of(y, m, d);
}
}