mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-10 08:54:11 -08:00
Adds tests for several fields in SimpleDateFormat
This commit is contained in:
parent
9e292eb7e5
commit
9c8d137e90
|
@ -144,7 +144,7 @@ public class CLDRReader {
|
||||||
private void readEras(String localeCode, CLDRLocale locale, JsonObject root) {
|
private void readEras(String localeCode, CLDRLocale locale, JsonObject root) {
|
||||||
JsonObject erasJson = root.get("main").getAsJsonObject().get(localeCode).getAsJsonObject()
|
JsonObject erasJson = root.get("main").getAsJsonObject().get(localeCode).getAsJsonObject()
|
||||||
.get("dates").getAsJsonObject().get("calendars").getAsJsonObject()
|
.get("dates").getAsJsonObject().get("calendars").getAsJsonObject()
|
||||||
.get("gregorian").getAsJsonObject().get("eras").getAsJsonObject().get("eraNames").getAsJsonObject();
|
.get("gregorian").getAsJsonObject().get("eras").getAsJsonObject().get("eraAbbr").getAsJsonObject();
|
||||||
String bc = erasJson.get("0").getAsString();
|
String bc = erasJson.get("0").getAsString();
|
||||||
String ac = erasJson.get("1").getAsString();
|
String ac = erasJson.get("1").getAsString();
|
||||||
locale.eras = new String[] { bc, ac };
|
locale.eras = new String[] { bc, ac };
|
||||||
|
|
|
@ -29,6 +29,7 @@ public class TSimpleDateFormat extends TDateFormat {
|
||||||
private TDateFormatSymbols dateFormatSymbols;
|
private TDateFormatSymbols dateFormatSymbols;
|
||||||
private TDateFormatElement[] elements;
|
private TDateFormatElement[] elements;
|
||||||
private String pattern;
|
private String pattern;
|
||||||
|
private TLocale locale;
|
||||||
|
|
||||||
public TSimpleDateFormat() {
|
public TSimpleDateFormat() {
|
||||||
this(getDefaultPattern());
|
this(getDefaultPattern());
|
||||||
|
@ -45,16 +46,18 @@ public class TSimpleDateFormat extends TDateFormat {
|
||||||
|
|
||||||
public TSimpleDateFormat(String pattern, TLocale locale) {
|
public TSimpleDateFormat(String pattern, TLocale locale) {
|
||||||
this(pattern, new TDateFormatSymbols(locale));
|
this(pattern, new TDateFormatSymbols(locale));
|
||||||
|
this.locale = locale;
|
||||||
}
|
}
|
||||||
|
|
||||||
public TSimpleDateFormat(String pattern, TDateFormatSymbols dateFormatSymbols) {
|
public TSimpleDateFormat(String pattern, TDateFormatSymbols dateFormatSymbols) {
|
||||||
dateFormatSymbols = (TDateFormatSymbols)dateFormatSymbols.clone();
|
this.dateFormatSymbols = (TDateFormatSymbols)dateFormatSymbols.clone();
|
||||||
|
locale = TLocale.getDefault();
|
||||||
applyPattern(pattern);
|
applyPattern(pattern);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public StringBuffer format(TDate date, StringBuffer buffer, TFieldPosition field) {
|
public StringBuffer format(TDate date, StringBuffer buffer, TFieldPosition field) {
|
||||||
TCalendar calendar = new TGregorianCalendar();
|
TCalendar calendar = new TGregorianCalendar(locale);
|
||||||
calendar.setTime(date);
|
calendar.setTime(date);
|
||||||
for (TDateFormatElement element : elements) {
|
for (TDateFormatElement element : elements) {
|
||||||
element.format(calendar, buffer);
|
element.format(calendar, buffer);
|
||||||
|
@ -75,8 +78,9 @@ public class TSimpleDateFormat extends TDateFormat {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TDate parse(String string, TParsePosition position) {
|
public TDate parse(String string, TParsePosition position) {
|
||||||
TCalendar calendar = new TGregorianCalendar();
|
TCalendar calendar = new TGregorianCalendar(locale);
|
||||||
calendar.set(0, 0, 0, 0, 0, 0);
|
calendar.set(0, 0, 0, 0, 0, 0);
|
||||||
|
calendar.set(TCalendar.MILLISECOND, 0);
|
||||||
for (TDateFormatElement element : elements) {
|
for (TDateFormatElement element : elements) {
|
||||||
if (position.getIndex() > string.length()) {
|
if (position.getIndex() > string.length()) {
|
||||||
position.setErrorIndex(position.getErrorIndex());
|
position.setErrorIndex(position.getErrorIndex());
|
||||||
|
|
|
@ -303,7 +303,7 @@ public class TGregorianCalendar extends TCalendar {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int getTimeZoneOffset(double time) {
|
private static int getTimeZoneOffset(double time) {
|
||||||
return TDate.getTimezoneOffset(time);
|
return -TDate.getTimezoneOffset(time) * 1000 * 60;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -517,7 +517,7 @@ public class TGregorianCalendar extends TCalendar {
|
||||||
}
|
}
|
||||||
if (isSet[WEEK_OF_MONTH] && lastDateFieldSet != DAY_OF_WEEK_IN_MONTH) {
|
if (isSet[WEEK_OF_MONTH] && lastDateFieldSet != DAY_OF_WEEK_IN_MONTH) {
|
||||||
int skew = mod7(days - 3 - (getFirstDayOfWeek() - 1));
|
int skew = mod7(days - 3 - (getFirstDayOfWeek() - 1));
|
||||||
days += (fields[WEEK_OF_MONTH] - 1) * 7 + mod7(skew + dayOfWeek - (days - 3)) - skew;
|
days += (fields[WEEK_OF_MONTH] - 1) * 7 + mod7(skew + dayOfWeek - (days - 2)) - skew;
|
||||||
} else if (isSet[DAY_OF_WEEK_IN_MONTH]) {
|
} else if (isSet[DAY_OF_WEEK_IN_MONTH]) {
|
||||||
if (fields[DAY_OF_WEEK_IN_MONTH] >= 0) {
|
if (fields[DAY_OF_WEEK_IN_MONTH] >= 0) {
|
||||||
days += mod7(dayOfWeek - (days - 3)) + (fields[DAY_OF_WEEK_IN_MONTH] - 1) * 7;
|
days += mod7(dayOfWeek - (days - 3)) + (fields[DAY_OF_WEEK_IN_MONTH] - 1) * 7;
|
||||||
|
@ -567,12 +567,7 @@ public class TGregorianCalendar extends TCalendar {
|
||||||
timeVal -= julianError() * 86400000L;
|
timeVal -= julianError() * 86400000L;
|
||||||
}
|
}
|
||||||
|
|
||||||
long timeValWithoutDST = timeVal - getTimeZoneOffset(timeVal);
|
this.time = timeVal - getTimeZoneOffset(timeVal);
|
||||||
this.time = timeVal;
|
|
||||||
if (timeValWithoutDST != timeVal) {
|
|
||||||
computeFields();
|
|
||||||
areFieldsSet = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private int computeYearAndDay(long dayCount, long localTime) {
|
private int computeYearAndDay(long dayCount, long localTime) {
|
||||||
|
|
|
@ -15,9 +15,13 @@
|
||||||
*/
|
*/
|
||||||
package org.teavm.classlib.java.text;
|
package org.teavm.classlib.java.text;
|
||||||
|
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import java.text.ParseException;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.GregorianCalendar;
|
||||||
|
import java.util.Locale;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -25,9 +29,67 @@ import org.junit.Test;
|
||||||
* @author Alexey Andreev
|
* @author Alexey Andreev
|
||||||
*/
|
*/
|
||||||
public class SimpleDateTimeFormatTest {
|
public class SimpleDateTimeFormatTest {
|
||||||
|
@Test
|
||||||
|
public void firstDayOfWeekMatches() {
|
||||||
|
assertEquals(Calendar.SUNDAY, new GregorianCalendar(Locale.ENGLISH).getFirstDayOfWeek());
|
||||||
|
assertEquals(1, new GregorianCalendar(Locale.ENGLISH).getMinimalDaysInFirstWeek());
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void fieldsFormatted() {
|
public void fieldsFormatted() {
|
||||||
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
|
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.ENGLISH);
|
||||||
assertEquals("2014-06-24 17:33:49", format.format(new Date(1403616829504L)));
|
assertEquals("2014-06-24 17:33:49", format.format(getDateWithZoneOffset(1403602429504L)));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void fieldsParsed() throws ParseException {
|
||||||
|
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.ENGLISH);
|
||||||
|
assertEquals(1403602429000L, getTimeWithoutZoneOffset(format.parse("2014-06-24 17:33:49")));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void eraHandled() throws ParseException {
|
||||||
|
SimpleDateFormat format = new SimpleDateFormat("G yyyy-MM-dd HH:mm:ss", Locale.ENGLISH);
|
||||||
|
assertEquals("AD 2014-06-24 17:33:49", format.format(getDateWithZoneOffset(1403602429504L)));
|
||||||
|
assertEquals(1403602429000L, getTimeWithoutZoneOffset(format.parse("AD 2014-06-24 17:33:49")));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shortYearHandled() throws ParseException {
|
||||||
|
SimpleDateFormat format = new SimpleDateFormat("yy-MM-dd HH:mm:ss", Locale.ENGLISH);
|
||||||
|
assertEquals("14-06-24 17:33:49", format.format(getDateWithZoneOffset(1403602429504L)));
|
||||||
|
assertEquals(1403602429000L, getTimeWithoutZoneOffset(format.parse("14-06-24 17:33:49")));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void weekInYearHandled() throws ParseException {
|
||||||
|
long day = 24 * 3600 * 1000;
|
||||||
|
SimpleDateFormat format = new SimpleDateFormat("yy-MM-dd HH:mm:ss www", Locale.ENGLISH);
|
||||||
|
assertEquals("14-06-24 17:33:49 026", format.format(getDateWithZoneOffset(1403602429504L)));
|
||||||
|
assertEquals("14-06-28 17:33:49 026", format.format(getDateWithZoneOffset(1403602429504L + day * 4)));
|
||||||
|
assertEquals("14-06-29 17:33:49 027", format.format(getDateWithZoneOffset(1403602429504L + day * 5)));
|
||||||
|
assertEquals(1403602429000L, getTimeWithoutZoneOffset(format.parse("14-06-24 17:33:49 026")));
|
||||||
|
assertEquals(1403602429000L + day * 4, getTimeWithoutZoneOffset(format.parse("14-06-28 17:33:49 026")));
|
||||||
|
assertEquals(1403602429000L + day * 5, getTimeWithoutZoneOffset(format.parse("14-06-29 17:33:49 027")));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void weekInMonthHandled() throws ParseException {
|
||||||
|
SimpleDateFormat format = new SimpleDateFormat("yy-MM-dd HH:mm:ss WW", Locale.ENGLISH);
|
||||||
|
assertEquals("14-06-24 17:33:49 04", format.format(getDateWithZoneOffset(1403602429504L)));
|
||||||
|
assertEquals(1403602429000L, getTimeWithoutZoneOffset(format.parse("14-06-24 17:33:49 04")));
|
||||||
|
}
|
||||||
|
|
||||||
|
private Date getDateWithZoneOffset(long milliseconds) {
|
||||||
|
Calendar calendar = new GregorianCalendar(Locale.ENGLISH);
|
||||||
|
calendar.setTimeInMillis(milliseconds);
|
||||||
|
milliseconds += calendar.get(Calendar.ZONE_OFFSET);
|
||||||
|
return new Date(milliseconds);
|
||||||
|
}
|
||||||
|
|
||||||
|
private long getTimeWithoutZoneOffset(Date date) {
|
||||||
|
Calendar calendar = new GregorianCalendar(Locale.ENGLISH);
|
||||||
|
calendar.setTime(date);
|
||||||
|
return calendar.getTimeInMillis() - calendar.get(Calendar.ZONE_OFFSET);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user