// Copyright (C) 2016 and later: Unicode, Inc. and others.
// License & terms of use: http://www.unicode.org/copyright.html
// Copyright (c) 2007-2015 International Business Machines
// Corporation and others. All Rights Reserved.
format:table(nofallback) {
Info {
Description { "These are the data driven format tests" }
LongDescription { "Data for data driven format tests." }
}
TestData {
TestDateFormatBasic {
Info {
Description { "Test data for format and parse :" }
}
Settings {
// options: 'format', or 'parse'. One can be omitted if this is a 1 way test.
{
Type { "date_format" }
},
{
Type { "date_parse" }
},
}
Headers { "locale", "zone", "spec", "date", "str"}
// locale: locale including calendar type
// zone: time zone name, or "" to not explicitly set zone
// spec: either 'PATTERN=y mm h' etc, or 'DATE=SHORT,TIME=LONG'
// date: either 'MILLIS=####' where #### is millis,
// or a calendar spec ERA=0,YEAR=1, etc.. applied to the calendar type specified by the locale
// or RELATIVE_MILLIS=### where ### is a signed value which is added to the current millis
// or RELATIVE_ADD:DATE=1 which means that the field "DATE" will be added by +1 relative to current time,
// and any other fields present will be set explicitly.
// str: the expected unicode string
Cases {
{
"en_US@calendar=gregorian",
"",
"DATE=SHORT,TIME=SHORT",
"ERA=1,YEAR=2007,MONTH=AUGUST,DATE=8,HOUR_OF_DAY=18,MINUTE=54,SECOND=0",
"8/8/07, 6:54 PM"
},
{
"zh_TW@calendar=roc",
"",
"DATE=LONG",
"ERA=1,YEAR=98,MONTH=0,DATE=24",
"民國98年1月24日",
},
{
//民國前2年1月24日 -> 1910-1-24
"zh_TW@calendar=roc",
"",
"DATE=LONG",
"ERA=0,YEAR=2,MONTH=0,DATE=24",
"民國前2年1月24日",
},
}
}
TestFormatRelative {
Info {
Description { "relative format :" }
}
Settings {
{
Type { "date_format" }
},
}
Headers { "locale", "zone", "spec", "date", "str"}
Cases {
{
"en_US@calendar=gregorian",
"",
"DATE=RELATIVE_SHORT",
"RELATIVE_ADD:DATE=1", // one day from now
"tomorrow"
},
{
"en_US@calendar=gregorian",
"",
"DATE=RELATIVE_SHORT",
"RELATIVE_MILLIS=0", // today
"today"
},
{
"en_US@calendar=gregorian",
"",
"DATE=RELATIVE_SHORT",
"RELATIVE_ADD:DATE=-1", // one day before now
"yesterday"
},
// date only, out of relative range
{
"en_US@calendar=gregorian",
"GMT",
"DATE=RELATIVE_FULL",
"ERA=1,YEAR=2012,MONTH=OCTOBER,DATE=8,HOUR_OF_DAY=23,MINUTE=59,SECOND=0",
"Monday, October 8, 2012"
},
// time only
{
"en_US@calendar=gregorian",
"GMT",
"TIME=LONG",
"ERA=1,YEAR=2012,MONTH=OCTOBER,DATE=8,HOUR_OF_DAY=23,MINUTE=59,SECOND=0",
"11:59:00 PM GMT"
},
{
"en_US@calendar=gregorian",
"GMT",
"TIME=LONG",
"RELATIVE_ADD:DATE=-1,HOUR_OF_DAY=17,MINUTE=0,SECOND=0", // one day before now at specified time
"5:00:00 PM GMT"
},
// normal formats, combined using 'at'
{
"en_US@calendar=gregorian",
"GMT",
"DATE=RELATIVE_FULL,TIME=LONG",
"ERA=1,YEAR=2012,MONTH=OCTOBER,DATE=8,HOUR_OF_DAY=23,MINUTE=59,SECOND=0",
"Monday, October 8, 2012 at 11:59:00 PM GMT"
},
// normal formats, combined using ", "
{
"en_US@calendar=gregorian",
"GMT",
"DATE=RELATIVE_MEDIUM,TIME=SHORT",
"ERA=1,YEAR=2012,MONTH=OCTOBER,DATE=8,HOUR_OF_DAY=23,MINUTE=59,SECOND=0",
"Oct 8, 2012, 11:59 PM"
},
// formats with relative day, combined using 'at'
{
"en_US@calendar=gregorian",
"GMT",
"DATE=RELATIVE_FULL,TIME=LONG",
"RELATIVE_ADD:DATE=-1,HOUR_OF_DAY=17,MINUTE=0,SECOND=0", // one day before now at specified time
"yesterday at 5:00:00 PM GMT"
},
// formats with relative day, combined using ", "
{
"en_US@calendar=gregorian",
"GMT",
"DATE=RELATIVE_MEDIUM,TIME=SHORT",
"RELATIVE_ADD:DATE=-1,HOUR_OF_DAY=17,MINUTE=0,SECOND=0", // one day before now at specified time
"yesterday, 5:00 PM"
},
// normal formats that have quoted literals, combined
{
"pt@calendar=gregorian",
"GMT",
"DATE=RELATIVE_FULL,TIME=LONG",
"ERA=1,YEAR=2012,MONTH=OCTOBER,DATE=8,HOUR_OF_DAY=23,MINUTE=59,SECOND=0",
"segunda-feira, 8 de outubro de 2012 23:59:00 GMT"
},
// vi combined formats have time first
{
"vi@calendar=gregorian",
"GMT",
"DATE=RELATIVE_LONG,TIME=MEDIUM",
"ERA=1,YEAR=2012,MONTH=OCTOBER,DATE=8,HOUR_OF_DAY=23,MINUTE=59,SECOND=0",
"23:59:00 8 tháng 10, 2012"
},
{
"vi@calendar=gregorian",
"GMT",
"DATE=RELATIVE_LONG,TIME=MEDIUM",
"RELATIVE_ADD:DATE=-1,HOUR_OF_DAY=17,MINUTE=0,SECOND=0", // one day before now at specified time
"17:00:00 Hôm qua"
},
// el combines formats using hyphen
{
"el@calendar=gregorian",
"GMT",
"DATE=RELATIVE_LONG,TIME=MEDIUM",
"ERA=1,YEAR=2012,MONTH=OCTOBER,DATE=8,HOUR_OF_DAY=23,MINUTE=59,SECOND=0",
"8 Οκτωβρίου 2012 - 11:59:00 μ.μ."
},
{
"el@calendar=gregorian",
"GMT",
"DATE=RELATIVE_LONG,TIME=MEDIUM",
"RELATIVE_ADD:DATE=-1,HOUR_OF_DAY=17,MINUTE=0,SECOND=0", // one day before now at specified time
"χθες - 5:00:00 μ.μ."
},
// other tests
{
"mt_MT@calendar=gregorian",
"",
"DATE=RELATIVE_SHORT",
"RELATIVE_ADD:DATE=1", // one day from now
"għada"
},
{
"mt_MT@calendar=gregorian",
"",
"DATE=RELATIVE_SHORT",
"RELATIVE_MILLIS=0", // today
"illum"
},
{
"mt_MT@calendar=gregorian",
"",
"DATE=RELATIVE_SHORT",
"RELATIVE_ADD:DATE=-1", // one day before now
"lbieraħ"
},
{
"ru",
"",
"DATE=RELATIVE_SHORT",
"RELATIVE_ADD:DATE=-2", // 2 days ago
"позавчера"
},
}
}
TestYearLengths {
Info {
Description { "Test data for multiple year lengths, y yy yyy yyyy yyyyy:" }
}
Settings {
// options: 'format', or 'parse'. One can be omitted if this is a 1 way test.
{
Type { "date_format" }
},
// These are not round trippable, so do not parse.
// {
// Type { "date_parse" }
// },
}
Headers { "locale", "zone", "spec", "date", "str"}
// locale: locale including calendar type
// zone: time zone name, or "" to not explicitly set zone
// spec: either 'PATTERN=y mm h' etc, or 'DATE=SHORT,TIME=LONG'
// date: either 'MILLIS=####' where #### is millis,
// or a calendar spec ERA=0,YEAR=1, etc.. applied to the calendar type specified by the locale
// or RELATIVE_MILLIS=### where ### is a signed value which is added to the current millis
// or RELATIVE_ADD:DATE=1 which means that the field "DATE" will be added by +1 relative to current time,
// and any other fields present will be set explicitly.
// str: the expected unicode string
// from CLDR UTS 35:
//Year y yy yyy yyyy yyyyy
Cases {
//AD 1 1 01 001 0001 00001
{
"en_US@calendar=gregorian",
"",
"PATTERN=G y",
"YEAR=1",
"AD 1"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yy",
"YEAR=1",
"AD 01"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyy",
"YEAR=1",
"AD 001"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyy",
"YEAR=1",
"AD 0001"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyyy",
"YEAR=1",
"AD 00001"
},
//AD 12 12 12 012 0012 00012
{
"en_US@calendar=gregorian",
"",
"PATTERN=G y",
"YEAR=12",
"AD 12"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yy",
"YEAR=12",
"AD 12"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyy",
"YEAR=12",
"AD 012"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyy",
"YEAR=12",
"AD 0012"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyyy",
"YEAR=12",
"AD 00012"
},
//AD 123 123 23 123 0123 00123
{
"en_US@calendar=gregorian",
"",
"PATTERN=G y",
"YEAR=123",
"AD 123"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yy",
"YEAR=123",
"AD 23"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyy",
"YEAR=123",
"AD 123"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyy",
"YEAR=123",
"AD 0123"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyyy",
"YEAR=123",
"AD 00123"
},
//AD 1234 1234 34 1234 1234 01234
{
"en_US@calendar=gregorian",
"",
"PATTERN=G y",
"YEAR=1234",
"AD 1234"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yy",
"YEAR=1234",
"AD 34"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyy",
"YEAR=1234",
"AD 1234"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyy",
"YEAR=1234",
"AD 1234"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyyy",
"YEAR=1234",
"AD 01234"
},
//AD 12345 12345 45 12345 12345 12345
{
"en_US@calendar=gregorian",
"",
"PATTERN=G y",
"YEAR=12345",
"AD 12345"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yy",
"YEAR=12345",
"AD 45"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyy",
"YEAR=12345",
"AD 12345"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyy",
"YEAR=12345",
"AD 12345"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyyy",
"YEAR=12345",
"AD 12345"
},
}
}
TestConsistentPivot {
Info {
Description { "Test consistent pivot (parse/format) for multiple year lengths, y yy yyy yyyy yyyyy:" }
}
Settings {
// options: 'format', or 'parse'. One can be omitted if this is a 1 way test.
{
Type { "date_format" }
},
{
Type { "date_parse" }
},
}
Headers { "locale", "zone", "spec", "date", "str"}
// locale: locale including calendar type
// zone: time zone name, or "" to not explicitly set zone
// spec: either 'PATTERN=y mm h' etc, or 'DATE=SHORT,TIME=LONG'
// date: either 'MILLIS=####' where #### is millis,
// or a calendar spec ERA=0,YEAR=1, etc.. applied to the calendar type specified by the locale
// or RELATIVE_MILLIS=### where ### is a signed value which is added to the current millis
// or RELATIVE_ADD:DATE=1 which means that the field "DATE" will be added by +1 relative to current time,
// and any other fields present will be set explicitly.
// str: the expected unicode string
// from CLDR UTS 35:
//Year y yy yyy yyyy yyyyy
Cases {
//AD 1 1 01 001 0001 00001
{
"en_US@calendar=gregorian",
"",
"PATTERN=G y",
"YEAR=2008",
"AD 2008"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yy",
"YEAR=2008",
"AD 08"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyy",
"YEAR=2008",
"AD 2008"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyy",
"YEAR=2008",
"AD 2008"
},
{
"en_US@calendar=gregorian",
"",
"PATTERN=G yyyyy",
"YEAR=2008",
"AD 02008"
},
// The following test case is commented out as the current era
// depends on the current time when the test is run.
// // Japanese
// {
// "en_US@calendar=japanese",
// "",
// "PATTERN=G y",
// "YEAR=8",
// "Reiwa 8"
// },
// {
// "en_US@calendar=japanese",
// "",
// "PATTERN=G yy",
// "YEAR=8",
// "Reiwa 08"
// },
// {
// "en_US@calendar=japanese",
// "",
// "PATTERN=G yyy",
// "YEAR=8",
// "Reiwa 008"
// },
// {
// "en_US@calendar=japanese",
// "",
// "PATTERN=G yyyy",
// "YEAR=8",
// "Reiwa 0008"
// },
// {
// "en_US@calendar=japanese",
// "",
// "PATTERN=G yyyyy",
// "YEAR=8",
// "Reiwa 00008"
// },
}
}
TestHebrew{
Info {
Description { "Test Hebrew calendar:" }
}
Settings {
// options: 'format', or 'parse'. One can be omitted if this is a 1 way test.
{
Type { "date_format" }
},
}
Headers { "locale", "zone", "spec", "date", "str"}
// locale: locale including calendar type
// zone: time zone name, or "" to not explicitly set zone
// spec: either 'PATTERN=y mm h' etc, or 'DATE=SHORT,TIME=LONG'
// date: either 'MILLIS=####' where #### is millis,
// or a calendar spec ERA=0,YEAR=1, etc.. applied to the calendar type specified by the locale
// or RELATIVE_MILLIS=### where ### is a signed value which is added to the current millis
// or RELATIVE_ADD:DATE=1 which means that the field "DATE" will be added by +1 relative to current time,
// and any other fields present will be set explicitly.
// str: the expected unicode string
Cases {
{
"en_US@calendar=hebrew",
"",
"DATE=FULL,TIME=FULL",
"MILLIS=3076424179200000",
"Friday, 3 Heshvan 103217 at 12:00:00 AM GMT-08:00"
},
}
}
TestMoreDateParse {
Info {
Description { "Additional date parse tests (may not
round/trip to format.)" }
}
Settings {
// options: 'format', or 'parse'. One can be omitted if this is a 1 way test.
{
Type { "date_parse" }
},
}
Headers { "locale", "zone", "spec", "date", "str"}
// locale: locale including calendar type
// zone: time zone name, or "" to not explicitly set zone
// spec: either 'PATTERN=y mm h' etc, or 'DATE=SHORT,TIME=LONG'
// date: either 'MILLIS=####' where #### is millis,
// or a calendar spec ERA=0,YEAR=1, etc.. applied to the calendar type specified by the locale
// or RELATIVE_MILLIS=### where ### is a signed value which is added to the current millis
// or RELATIVE_ADD:DATE=1 which means that the field "DATE" will be added by +1 relative to current time,
// and any other fields present will be set explicitly.
// str: the expected unicode string
Cases {
{
"en_US@calendar=gregorian",
"",
"PATTERN=YYYYHHmmssEEEww",
"YEAR=1999,HOUR_OF_DAY=4,MINUTE=5,SECOND=6,DAY_OF_WEEK=2,WEEK_OF_YEAR=4",
// won't roundtrip.
"1998040506MON56"
}
}
}
}
}