Formatting support for java.time.Year and java.time.Month
Issue: SPR-16437
This commit is contained in:
parent
89d2bd954a
commit
ef2e16912d
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2017 the original author or authors.
|
* Copyright 2002-2018 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -21,10 +21,12 @@ import java.time.Instant;
|
||||||
import java.time.LocalDate;
|
import java.time.LocalDate;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.time.LocalTime;
|
import java.time.LocalTime;
|
||||||
|
import java.time.Month;
|
||||||
import java.time.MonthDay;
|
import java.time.MonthDay;
|
||||||
import java.time.OffsetDateTime;
|
import java.time.OffsetDateTime;
|
||||||
import java.time.OffsetTime;
|
import java.time.OffsetTime;
|
||||||
import java.time.Period;
|
import java.time.Period;
|
||||||
|
import java.time.Year;
|
||||||
import java.time.YearMonth;
|
import java.time.YearMonth;
|
||||||
import java.time.ZonedDateTime;
|
import java.time.ZonedDateTime;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
|
@ -190,6 +192,8 @@ public class DateTimeFormatterRegistrar implements FormatterRegistrar {
|
||||||
registry.addFormatterForFieldType(Instant.class, new InstantFormatter());
|
registry.addFormatterForFieldType(Instant.class, new InstantFormatter());
|
||||||
registry.addFormatterForFieldType(Period.class, new PeriodFormatter());
|
registry.addFormatterForFieldType(Period.class, new PeriodFormatter());
|
||||||
registry.addFormatterForFieldType(Duration.class, new DurationFormatter());
|
registry.addFormatterForFieldType(Duration.class, new DurationFormatter());
|
||||||
|
registry.addFormatterForFieldType(Year.class, new YearFormatter());
|
||||||
|
registry.addFormatterForFieldType(Month.class, new MonthFormatter());
|
||||||
registry.addFormatterForFieldType(YearMonth.class, new YearMonthFormatter());
|
registry.addFormatterForFieldType(YearMonth.class, new YearMonthFormatter());
|
||||||
registry.addFormatterForFieldType(MonthDay.class, new MonthDayFormatter());
|
registry.addFormatterForFieldType(MonthDay.class, new MonthDayFormatter());
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,45 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2002-2018 the original author or authors.
|
||||||
|
*
|
||||||
|
* 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.springframework.format.datetime.standard;
|
||||||
|
|
||||||
|
import java.text.ParseException;
|
||||||
|
import java.time.Month;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
import org.springframework.format.Formatter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@link Formatter} implementation for a JSR-310 {@link Month},
|
||||||
|
* resolving a given String against the Month enum values (ignoring case).
|
||||||
|
*
|
||||||
|
* @author Juergen Hoeller
|
||||||
|
* @since 5.0.4
|
||||||
|
* @see Month#valueOf
|
||||||
|
*/
|
||||||
|
class MonthFormatter implements Formatter<Month> {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Month parse(String text, Locale locale) throws ParseException {
|
||||||
|
return Month.valueOf(text.toUpperCase());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String print(Month object, Locale locale) {
|
||||||
|
return object.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,45 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2002-2018 the original author or authors.
|
||||||
|
*
|
||||||
|
* 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.springframework.format.datetime.standard;
|
||||||
|
|
||||||
|
import java.text.ParseException;
|
||||||
|
import java.time.Year;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
import org.springframework.format.Formatter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@link Formatter} implementation for a JSR-310 {@link Year},
|
||||||
|
* following JSR-310's parsing rules for a Year.
|
||||||
|
*
|
||||||
|
* @author Juergen Hoeller
|
||||||
|
* @since 5.0.4
|
||||||
|
* @see Year#parse
|
||||||
|
*/
|
||||||
|
class YearFormatter implements Formatter<Year> {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Year parse(String text, Locale locale) throws ParseException {
|
||||||
|
return Year.parse(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String print(Year object, Locale locale) {
|
||||||
|
return object.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -21,8 +21,10 @@ import java.time.Instant;
|
||||||
import java.time.LocalDate;
|
import java.time.LocalDate;
|
||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.time.LocalTime;
|
import java.time.LocalTime;
|
||||||
|
import java.time.Month;
|
||||||
import java.time.MonthDay;
|
import java.time.MonthDay;
|
||||||
import java.time.Period;
|
import java.time.Period;
|
||||||
|
import java.time.Year;
|
||||||
import java.time.YearMonth;
|
import java.time.YearMonth;
|
||||||
import java.time.ZoneId;
|
import java.time.ZoneId;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
|
@ -60,12 +62,12 @@ public class DateTimeFormattingTests {
|
||||||
|
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setup() {
|
||||||
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
||||||
setUp(registrar);
|
setup(registrar);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setUp(DateTimeFormatterRegistrar registrar) {
|
private void setup(DateTimeFormatterRegistrar registrar) {
|
||||||
conversionService = new FormattingConversionService();
|
conversionService = new FormattingConversionService();
|
||||||
DefaultConversionService.addDefaultConverters(conversionService);
|
DefaultConversionService.addDefaultConverters(conversionService);
|
||||||
registrar.registerFormatters(conversionService);
|
registrar.registerFormatters(conversionService);
|
||||||
|
@ -82,7 +84,7 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
public void tearDown() {
|
public void cleanup() {
|
||||||
LocaleContextHolder.setLocale(null);
|
LocaleContextHolder.setLocale(null);
|
||||||
DateTimeContextHolder.setDateTimeContext(null);
|
DateTimeContextHolder.setDateTimeContext(null);
|
||||||
}
|
}
|
||||||
|
@ -98,10 +100,10 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindLocalDateWithSpecificStyle() throws Exception {
|
public void testBindLocalDateWithSpecificStyle() {
|
||||||
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
||||||
registrar.setDateStyle(FormatStyle.LONG);
|
registrar.setDateStyle(FormatStyle.LONG);
|
||||||
setUp(registrar);
|
setup(registrar);
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("localDate", "October 31, 2009");
|
propertyValues.add("localDate", "October 31, 2009");
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -110,10 +112,10 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindLocalDateWithSpecificFormatter() throws Exception {
|
public void testBindLocalDateWithSpecificFormatter() {
|
||||||
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
||||||
registrar.setDateFormatter(DateTimeFormatter.ofPattern("yyyyMMdd"));
|
registrar.setDateFormatter(DateTimeFormatter.ofPattern("yyyyMMdd"));
|
||||||
setUp(registrar);
|
setup(registrar);
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("localDate", "20091031");
|
propertyValues.add("localDate", "20091031");
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -177,7 +179,7 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindLocalDateFromJavaUtilCalendar() throws Exception {
|
public void testBindLocalDateFromJavaUtilCalendar() {
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("localDate", new GregorianCalendar(2009, 9, 31, 0, 0));
|
propertyValues.add("localDate", new GregorianCalendar(2009, 9, 31, 0, 0));
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -195,10 +197,10 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindLocalTimeWithSpecificStyle() throws Exception {
|
public void testBindLocalTimeWithSpecificStyle() {
|
||||||
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
||||||
registrar.setTimeStyle(FormatStyle.MEDIUM);
|
registrar.setTimeStyle(FormatStyle.MEDIUM);
|
||||||
setUp(registrar);
|
setup(registrar);
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("localTime", "12:00:00 PM");
|
propertyValues.add("localTime", "12:00:00 PM");
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -207,10 +209,10 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindLocalTimeWithSpecificFormatter() throws Exception {
|
public void testBindLocalTimeWithSpecificFormatter() {
|
||||||
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
||||||
registrar.setTimeFormatter(DateTimeFormatter.ofPattern("HHmmss"));
|
registrar.setTimeFormatter(DateTimeFormatter.ofPattern("HHmmss"));
|
||||||
setUp(registrar);
|
setup(registrar);
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("localTime", "130000");
|
propertyValues.add("localTime", "130000");
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -228,7 +230,7 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindLocalTimeFromJavaUtilCalendar() throws Exception {
|
public void testBindLocalTimeFromJavaUtilCalendar() {
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("localTime", new GregorianCalendar(1970, 0, 0, 12, 0));
|
propertyValues.add("localTime", new GregorianCalendar(1970, 0, 0, 12, 0));
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -259,7 +261,7 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindLocalDateTimeFromJavaUtilCalendar() throws Exception {
|
public void testBindLocalDateTimeFromJavaUtilCalendar() {
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("localDateTime", new GregorianCalendar(2009, 9, 31, 12, 0));
|
propertyValues.add("localDateTime", new GregorianCalendar(2009, 9, 31, 12, 0));
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -270,10 +272,10 @@ public class DateTimeFormattingTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindDateTimeWithSpecificStyle() throws Exception {
|
public void testBindDateTimeWithSpecificStyle() {
|
||||||
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
DateTimeFormatterRegistrar registrar = new DateTimeFormatterRegistrar();
|
||||||
registrar.setDateTimeStyle(FormatStyle.MEDIUM);
|
registrar.setDateTimeStyle(FormatStyle.MEDIUM);
|
||||||
setUp(registrar);
|
setup(registrar);
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("localDateTime", LocalDateTime.of(2009, 10, 31, 12, 0));
|
propertyValues.add("localDateTime", LocalDateTime.of(2009, 10, 31, 12, 0));
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -356,7 +358,7 @@ public class DateTimeFormattingTests {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@SuppressWarnings("deprecation")
|
@SuppressWarnings("deprecation")
|
||||||
public void testBindInstantFromJavaUtilDate() throws Exception {
|
public void testBindInstantFromJavaUtilDate() {
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
propertyValues.add("instant", new Date(109, 9, 31, 12, 0));
|
propertyValues.add("instant", new Date(109, 9, 31, 12, 0));
|
||||||
binder.bind(propertyValues);
|
binder.bind(propertyValues);
|
||||||
|
@ -382,6 +384,33 @@ public class DateTimeFormattingTests {
|
||||||
assertTrue(binder.getBindingResult().getFieldValue("duration").toString().equals("PT8H6M12.345S"));
|
assertTrue(binder.getBindingResult().getFieldValue("duration").toString().equals("PT8H6M12.345S"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testBindYear() {
|
||||||
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
|
propertyValues.add("year", "2007");
|
||||||
|
binder.bind(propertyValues);
|
||||||
|
assertEquals(0, binder.getBindingResult().getErrorCount());
|
||||||
|
assertTrue(binder.getBindingResult().getFieldValue("year").toString().equals("2007"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testBindMonth() {
|
||||||
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
|
propertyValues.add("month", "JULY");
|
||||||
|
binder.bind(propertyValues);
|
||||||
|
assertEquals(0, binder.getBindingResult().getErrorCount());
|
||||||
|
assertTrue(binder.getBindingResult().getFieldValue("month").toString().equals("JULY"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testBindMonthInAnyCase() {
|
||||||
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
|
propertyValues.add("month", "July");
|
||||||
|
binder.bind(propertyValues);
|
||||||
|
assertEquals(0, binder.getBindingResult().getErrorCount());
|
||||||
|
assertTrue(binder.getBindingResult().getFieldValue("month").toString().equals("JULY"));
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBindYearMonth() {
|
public void testBindYearMonth() {
|
||||||
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
MutablePropertyValues propertyValues = new MutablePropertyValues();
|
||||||
|
@ -436,6 +465,10 @@ public class DateTimeFormattingTests {
|
||||||
|
|
||||||
private Duration duration;
|
private Duration duration;
|
||||||
|
|
||||||
|
private Year year;
|
||||||
|
|
||||||
|
private Month month;
|
||||||
|
|
||||||
private YearMonth yearMonth;
|
private YearMonth yearMonth;
|
||||||
|
|
||||||
private MonthDay monthDay;
|
private MonthDay monthDay;
|
||||||
|
@ -546,6 +579,22 @@ public class DateTimeFormattingTests {
|
||||||
this.duration = duration;
|
this.duration = duration;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Year getYear() {
|
||||||
|
return year;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setYear(Year year) {
|
||||||
|
this.year = year;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Month getMonth() {
|
||||||
|
return month;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMonth(Month month) {
|
||||||
|
this.month = month;
|
||||||
|
}
|
||||||
|
|
||||||
public YearMonth getYearMonth() {
|
public YearMonth getYearMonth() {
|
||||||
return yearMonth;
|
return yearMonth;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue