From 078f5eb6a8f1ea53ab5a5916c3aebf5d5d5644b8 Mon Sep 17 00:00:00 2001 From: Leo Jiang Date: Sun, 19 May 2019 22:14:09 +0800 Subject: [PATCH] 8219781: Localized names for Japanese era Reiwa in COMPAT provider Reviewed-by: naoto --- .../sun/text/resources/ext/FormatData_ar.java | 2 + .../sun/text/resources/ext/FormatData_ko.java | 1 + .../sun/text/resources/ext/FormatData_th.java | 2 + .../sun/text/resources/ext/FormatData_zh.java | 1 + .../ext/JavaTimeSupplementary_ar.java | 1 + .../ext/JavaTimeSupplementary_hi_IN.java | 2 + .../ext/JavaTimeSupplementary_hr.java | 2 + .../ext/JavaTimeSupplementary_in.java | 1 + .../ext/JavaTimeSupplementary_ko.java | 1 + .../ext/JavaTimeSupplementary_lt.java | 2 + .../ext/JavaTimeSupplementary_nl.java | 2 + .../ext/JavaTimeSupplementary_no.java | 2 + .../ext/JavaTimeSupplementary_ru.java | 2 + .../ext/JavaTimeSupplementary_sr.java | 2 + .../ext/JavaTimeSupplementary_sr_Latn.java | 2 + .../ext/JavaTimeSupplementary_sv.java | 2 + .../ext/JavaTimeSupplementary_th.java | 1 + .../ext/JavaTimeSupplementary_zh.java | 1 + .../ext/JavaTimeSupplementary_zh_TW.java | 1 + .../util/Calendar/JapanEraNameCompatTest.java | 144 ++++++++++++++++++ 20 files changed, 174 insertions(+) create mode 100644 test/jdk/java/util/Calendar/JapanEraNameCompatTest.java diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar.java index 5290a8ea76f..4ef9bd30769 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar.java @@ -212,6 +212,7 @@ public class FormatData_ar extends ParallelListResourceBundle { "\u062a\u064a\u0634\u0648", "\u0634\u0648\u0648\u0627", "\u0647\u064a\u0633\u064a", + "\u0631\u064a\u0648\u0627", } }, { "japanese.short.Eras", @@ -221,6 +222,7 @@ public class FormatData_ar extends ParallelListResourceBundle { "\u062a\u064a\u0634\u0648", "\u0634\u0648\u0648\u0627", "\u0647\u064a\u0633\u064a", + "\u0631\u064a\u0648\u0627", } }, { "buddhist.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ko.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ko.java index 045a3b2b307..e9d6a0e955d 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ko.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ko.java @@ -192,6 +192,7 @@ public class FormatData_ko extends ParallelListResourceBundle { "\ub2e4\uc774\uc1fc", "\uc1fc\uc640", "\ud5e4\uc774\uc138\uc774", + "\ub808\uc774\uc640", } }, { "AmPmMarkers", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_th.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_th.java index 617f26d902f..cdb9580d041 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_th.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_th.java @@ -245,6 +245,7 @@ public class FormatData_th extends ParallelListResourceBundle { "\u0e17\u0e30\u0e2d\u0e34\u0e42\u0e0a", "\u0e42\u0e0a\u0e27\u0e30", "\u0e40\u0e2e\u0e40\u0e0b", + "\u0e40\u0e23\u0e27\u0e30", } }, { "japanese.short.Eras", @@ -254,6 +255,7 @@ public class FormatData_th extends ParallelListResourceBundle { "\u0e17", "\u0e0a", "\u0e2e", + "R", } }, { "buddhist.TimePatterns", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_zh.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_zh.java index 491dd0cd2bf..7b05db6e955 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_zh.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_zh.java @@ -282,6 +282,7 @@ public class FormatData_zh extends ParallelListResourceBundle { "\u5927\u6b63", "\u662d\u548c", "\u5e73\u6210", + "\u4ee4\u548c", } }, { "TimePatterns", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar.java index a46891f4270..a26f3383c6d 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ar.java @@ -157,6 +157,7 @@ public class JavaTimeSupplementary_ar extends OpenListResourceBundle { "\u062a\u064a\u0634\u0648", "\u0634\u0648\u0648\u0627", "\u0647\u064a\u0633\u064a", + "\u0631\u064a\u0648\u0627", }; final String[] sharedShortEras = { diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hi_IN.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hi_IN.java index 65751775f72..5f5ad9e4af4 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hi_IN.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hi_IN.java @@ -241,6 +241,7 @@ public class JavaTimeSupplementary_hi_IN extends OpenListResourceBundle { "\u0924\u093e\u0908\u0936\u094b", "\u0936\u094b\u0935\u093e", "\u0939\u0947\u0908\u0938\u0947\u0908", + "\u0930\u0947\u0907\u0935\u093e", } }, { "java.time.japanese.short.Eras", @@ -250,6 +251,7 @@ public class JavaTimeSupplementary_hi_IN extends OpenListResourceBundle { "\u0924\u093e\u0908\u0936\u094b", "\u0936\u094b\u0935\u093e", "\u0939\u0947\u0908\u0938\u0947\u0908", + "\u0930\u0947\u0907\u0935\u093e", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hr.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hr.java index e73d296ddc7..c46e61ba816 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hr.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_hr.java @@ -231,6 +231,7 @@ public class JavaTimeSupplementary_hr extends OpenListResourceBundle { "Taish\u014d", "Sh\u014dwa", "Heisei", + "Reiwa", } }, { "java.time.japanese.short.Eras", @@ -240,6 +241,7 @@ public class JavaTimeSupplementary_hr extends OpenListResourceBundle { "Taish\u014d", "Sh\u014dwa", "Heisei", + "Reiwa", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_in.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_in.java index 4e62f071f15..067027554c6 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_in.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_in.java @@ -148,6 +148,7 @@ public class JavaTimeSupplementary_in extends OpenListResourceBundle { "Taish\u014d", "Sh\u014dwa", "Heisei", + "Reiwa", }; final String[] sharedEras = { diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ko.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ko.java index 0349aed4af4..dfe710f6551 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ko.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ko.java @@ -143,6 +143,7 @@ public class JavaTimeSupplementary_ko extends OpenListResourceBundle { "\ub2e4\uc774\uc1fc", "\uc1fc\uc640", "\ud5e4\uc774\uc138\uc774", + "\ub808\uc774\uc640", }; final String[] sharedJavaTimeShortEras2 = { diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lt.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lt.java index 735200db979..9d203eeb6e5 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lt.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_lt.java @@ -223,6 +223,7 @@ public class JavaTimeSupplementary_lt extends OpenListResourceBundle { "Tai\u0161o", "\u0160ova", "Heisei", + "Reiwa", } }, { "java.time.japanese.short.Eras", @@ -232,6 +233,7 @@ public class JavaTimeSupplementary_lt extends OpenListResourceBundle { "Tai\u0161o", "\u0160ova", "Heisei", + "Reiwa", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl.java index 38feb02141d..183b7721c2f 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_nl.java @@ -265,6 +265,7 @@ public class JavaTimeSupplementary_nl extends OpenListResourceBundle { "Taish\u014d", "Sh\u014dwa", "Heisei", + "Reiwa", } }, { "java.time.japanese.short.Eras", @@ -274,6 +275,7 @@ public class JavaTimeSupplementary_nl extends OpenListResourceBundle { "Taish\u014d", "Sh\u014dwa", "Heisei", + "Reiwa", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_no.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_no.java index f2b3b8ef1a3..60a30bce918 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_no.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_no.java @@ -283,6 +283,7 @@ public class JavaTimeSupplementary_no extends OpenListResourceBundle { "Taish\u014d", "Sh\u014dwa", "Heisei", + "Reiwa", } }, { "java.time.japanese.short.Eras", @@ -292,6 +293,7 @@ public class JavaTimeSupplementary_no extends OpenListResourceBundle { "T", "S", "H", + "R", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ru.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ru.java index b9e50a03acd..78648529e20 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ru.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_ru.java @@ -237,6 +237,7 @@ public class JavaTimeSupplementary_ru extends OpenListResourceBundle { "\u042d\u043f\u043e\u0445\u0430 \u0422\u0430\u0439\u0441\u044c\u043e", "\u0421\u044c\u043e\u0432\u0430", "\u042d\u043f\u043e\u0445\u0430 \u0425\u044d\u0439\u0441\u044d\u0439", + "\u0420\u044d\u0439\u0432\u0430", } }, { "java.time.japanese.short.Eras", @@ -246,6 +247,7 @@ public class JavaTimeSupplementary_ru extends OpenListResourceBundle { "\u042d\u043f\u043e\u0445\u0430 \u0422\u0430\u0439\u0441\u044c\u043e", "\u0421\u044c\u043e\u0432\u0430", "\u042d\u043f\u043e\u0445\u0430 \u0425\u044d\u0439\u0441\u044d\u0439", + "\u0420\u044d\u0439\u0432\u0430", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr.java index 5f127a00dcb..cc165b0070d 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr.java @@ -280,6 +280,7 @@ public class JavaTimeSupplementary_sr extends OpenListResourceBundle { "\u0422\u0430\u0438\u0448\u043e", "\u0428\u043e\u0432\u0430", "\u0425\u0430\u0438\u0441\u0435\u0438", + "\u0420\u0435\u0438\u0432\u0430", } }, { "java.time.japanese.short.Eras", @@ -289,6 +290,7 @@ public class JavaTimeSupplementary_sr extends OpenListResourceBundle { "\u0422\u0430\u0438\u0448\u043e", "\u0428\u043e\u0432\u0430", "\u0425\u0430\u0438\u0441\u0435\u0438", + "\u0420\u0435\u0438\u0432\u0430", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_Latn.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_Latn.java index 016c5c56690..5145df2c6e9 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_Latn.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sr_Latn.java @@ -225,6 +225,7 @@ public class JavaTimeSupplementary_sr_Latn extends OpenListResourceBundle { "Tai\u0161o", "\u0160ova", "Haisei", + "Reiva", } }, { "java.time.japanese.short.Eras", @@ -234,6 +235,7 @@ public class JavaTimeSupplementary_sr_Latn extends OpenListResourceBundle { "Tai\u0161o", "\u0160ova", "Haisei", + "Reiva", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sv.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sv.java index 160cfec9f38..346c88f0f76 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sv.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_sv.java @@ -249,6 +249,7 @@ public class JavaTimeSupplementary_sv extends OpenListResourceBundle { "Taish\u014d", "Sh\u014dwa", "Heisei", + "Reiwa", } }, { "java.time.japanese.short.Eras", @@ -258,6 +259,7 @@ public class JavaTimeSupplementary_sv extends OpenListResourceBundle { "Taish\u014d", "Sh\u014dwa", "Heisei", + "Reiwa", } }, { "java.time.long.Eras", diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_th.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_th.java index 8b7a08543d9..1ee3f9b7a8d 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_th.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_th.java @@ -137,6 +137,7 @@ public class JavaTimeSupplementary_th extends OpenListResourceBundle { "\u0e17\u0e30\u0e2d\u0e34\u0e42\u0e0a", "\u0e42\u0e0a\u0e27\u0e30", "\u0e40\u0e2e\u0e40\u0e0b", + "\u0e40\u0e23\u0e27\u0e30", }; final String[] sharedShortEras = { diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh.java index 147d2d8aa07..bb48d83b563 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh.java @@ -176,6 +176,7 @@ public class JavaTimeSupplementary_zh extends OpenListResourceBundle { "\u5927\u6b63", "\u662d\u548c", "\u5e73\u6210", + "\u4ee4\u548c", }; final String[] sharedJavaTimeShortEras2 = { diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_TW.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_TW.java index 3c8a83d0323..00bb73bf623 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_TW.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/JavaTimeSupplementary_zh_TW.java @@ -135,6 +135,7 @@ public class JavaTimeSupplementary_zh_TW extends OpenListResourceBundle { "\u5927\u6b63", "\u662d\u548c", "\u5e73\u6210", + "\u4ee4\u548c", }; final String[] sharedJavaTimeShortEras2 = { diff --git a/test/jdk/java/util/Calendar/JapanEraNameCompatTest.java b/test/jdk/java/util/Calendar/JapanEraNameCompatTest.java new file mode 100644 index 00000000000..8efed7d2243 --- /dev/null +++ b/test/jdk/java/util/Calendar/JapanEraNameCompatTest.java @@ -0,0 +1,144 @@ +/* + * Copyright (c) 2019, 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. + * + * 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. + */ + +/* + * @test + * @bug 8218781 + * @summary Test the localized names of Japanese era Reiwa from COMPAT provider. + * @modules jdk.localedata + * @run testng/othervm -Djava.locale.providers=COMPAT JapanEraNameCompatTest + */ + +import static java.util.Calendar.*; +import static java.util.Locale.*; + +import java.time.LocalDate; +import java.time.chrono.JapaneseChronology; +import java.time.chrono.JapaneseEra; +import java.time.format.DateTimeFormatter; +import java.time.format.DateTimeParseException; +import java.time.format.TextStyle; +import java.util.Calendar; +import java.util.Locale; + +import org.testng.annotations.DataProvider; +import org.testng.annotations.Test; +import static org.testng.Assert.assertEquals; + +@Test +public class JapanEraNameCompatTest { + static final Calendar c = new Calendar.Builder() + .setCalendarType("japanese") + .setFields(ERA, 5, YEAR, 1, MONTH, MAY, DAY_OF_MONTH, 1) + .build(); + static final String EngName = "Reiwa"; + static final String CJName = "\u4ee4\u548c"; + static final String KoreanName = "\ub808\uc774\uc640"; + static final String ArabicName = "\u0631\u064a\u0648\u0627"; + static final String ThaiName = "\u0e40\u0e23\u0e27\u0e30"; + static final String HindiName = "\u0930\u0947\u0907\u0935\u093e"; + static final String RussianName = "\u0420\u044d\u0439\u0432\u0430"; + static final String SerbianName = "\u0420\u0435\u0438\u0432\u0430"; + static final String SerbLatinName = "Reiva"; + + @DataProvider(name="UtilCalendar") + Object[][] dataUtilCalendar() { + return new Object[][] { + //locale, long, short + { JAPAN, CJName, "R" }, + { KOREAN, KoreanName, "R" }, + { CHINA, CJName, "R" }, + { TAIWAN, CJName, "R" }, // fallback to zh + { new Locale("ar"), ArabicName, ArabicName }, + { new Locale("th"), ThaiName, "R" }, + // hi_IN fallback to root + { new Locale("hi", "IN"), EngName, "R" } + }; + } + + @Test(dataProvider="UtilCalendar") + public void testCalendarEraDisplayName(Locale locale, + String longName, String shortName) { + assertEquals(c.getDisplayName(ERA, LONG, locale), longName); + assertEquals(c.getDisplayName(ERA, SHORT, locale), shortName); + } + + @DataProvider(name="JavaTime") + Object[][] dataJavaTime() { + return new Object[][] { + // locale, full, short + { JAPAN, CJName, CJName }, + { KOREAN, KoreanName, KoreanName }, + { CHINA, CJName, CJName }, + { TAIWAN, CJName, CJName }, + { new Locale("ar"), ArabicName, ArabicName }, + { new Locale("th"), ThaiName, ThaiName }, + { new Locale("hi", "IN"), HindiName, HindiName }, + { new Locale("ru"), RussianName, RussianName }, + { new Locale("sr"), SerbianName, SerbianName }, + { Locale.forLanguageTag("sr-Latn"), SerbLatinName, SerbLatinName }, + { new Locale("hr"), EngName, EngName }, + { new Locale("in"), EngName, EngName }, + { new Locale("lt"), EngName, EngName }, + { new Locale("nl"), EngName, EngName }, + { new Locale("no"), EngName, "R" }, + { new Locale("sv"), EngName, EngName }, + // el fallback to root + { new Locale("el"), EngName, EngName } + }; + } + + @Test(dataProvider="JavaTime") + public void testChronoJapanEraDisplayName(Locale locale, + String fullName, String shortName) { + + JapaneseEra era = JapaneseEra.valueOf("Reiwa"); + assertEquals(era.getDisplayName(TextStyle.FULL, locale), fullName); + assertEquals(era.getDisplayName(TextStyle.SHORT, locale), shortName); + assertEquals(era.getDisplayName(TextStyle.NARROW, locale), "R"); + } + + @Test + public void testFormatParseEraName() { + LocalDate date = LocalDate.of(2019, 5, 1); + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy MM dd GGGG"); + formatter = formatter.withChronology(JapaneseChronology.INSTANCE); + + int num = 0; + for (Locale locale : Calendar.getAvailableLocales()) { + formatter = formatter.withLocale(locale); + try { + LocalDate.parse(date.format(formatter), formatter); + } catch (DateTimeParseException e) { + // If an array is defined for Japanese eras in java.time resource, + // but an era entry is missing, format fallback to English name + // while parse throw DateTimeParseException. + num++; + System.out.println("Missing java.time resource data for locale: " + locale); + } + } + if (num > 0) { + throw new RuntimeException("Missing java.time data for " + num + " locales"); + } + } +}