From 11ab995e6cbbf2c167a6a0df912769a130b1f88d Mon Sep 17 00:00:00 2001 From: Naoto Sato Date: Fri, 26 Jul 2019 13:32:59 -0700 Subject: [PATCH] 8228465: HOST locale provider holds wrong era name for GregorianCalendar in US locale Reviewed-by: lancea --- .../share/classes/java/util/Calendar.java | 3 +- .../jdk/java/util/Locale/LocaleProviders.java | 32 ++++++++++++++++--- .../java/util/Locale/LocaleProvidersRun.java | 4 ++- 3 files changed, 32 insertions(+), 7 deletions(-) diff --git a/src/java.base/share/classes/java/util/Calendar.java b/src/java.base/share/classes/java/util/Calendar.java index 784a53be324..99adf7ca446 100644 --- a/src/java.base/share/classes/java/util/Calendar.java +++ b/src/java.base/share/classes/java/util/Calendar.java @@ -2205,7 +2205,8 @@ public abstract class Calendar implements Serializable, Cloneable, Comparable map; map = CalendarDataUtility.retrieveFieldValueNames(calendarType, field, style, locale); diff --git a/test/jdk/java/util/Locale/LocaleProviders.java b/test/jdk/java/util/Locale/LocaleProviders.java index 342ea91fd1d..6e580d2d25c 100644 --- a/test/jdk/java/util/Locale/LocaleProviders.java +++ b/test/jdk/java/util/Locale/LocaleProviders.java @@ -28,6 +28,8 @@ import sun.util.locale.provider.LocaleProviderAdapter; public class LocaleProviders { + private static final boolean IS_WINDOWS = System.getProperty("os.name").startsWith("Windows"); + public static void main(String[] args) { String methodName = args[0]; @@ -76,6 +78,10 @@ public class LocaleProviders { bug8220227Test(); break; + case "bug8228465Test": + bug8228465Test(); + break; + default: throw new RuntimeException("Test method '"+methodName+"' not found."); } @@ -106,7 +112,7 @@ public class LocaleProviders { static void bug7198834Test() { LocaleProviderAdapter lda = LocaleProviderAdapter.getAdapter(DateFormatProvider.class, Locale.US); LocaleProviderAdapter.Type type = lda.getAdapterType(); - if (type == LocaleProviderAdapter.Type.HOST && System.getProperty("os.name").startsWith("Windows")) { + if (type == LocaleProviderAdapter.Type.HOST && IS_WINDOWS) { DateFormat df = DateFormat.getDateInstance(DateFormat.FULL, Locale.US); String date = df.format(new Date()); if (date.charAt(date.length()-1) == ' ') { @@ -133,7 +139,7 @@ public class LocaleProviders { // This test assumes Windows localized language/country display names. static void bug8010666Test() { - if (System.getProperty("os.name").startsWith("Windows")) { + if (IS_WINDOWS) { NumberFormat nf = NumberFormat.getInstance(Locale.US); try { double ver = nf.parse(System.getProperty("os.version")) @@ -215,7 +221,7 @@ public class LocaleProviders { } static void bug8013903Test() { - if (System.getProperty("os.name").startsWith("Windows")) { + if (IS_WINDOWS) { Date sampleDate = new Date(0x10000000000L); String hostResult = "\u5e73\u6210 16.11.03 (Wed) AM 11:53:47"; String jreResult = "\u5e73\u6210 16.11.03 (\u6c34) \u5348\u524d 11:53:47"; @@ -241,7 +247,7 @@ public class LocaleProviders { } static void bug8027289Test(String expectedCodePoint) { - if (System.getProperty("os.name").startsWith("Windows")) { + if (IS_WINDOWS) { char[] expectedSymbol = Character.toChars(Integer.valueOf(expectedCodePoint, 16)); NumberFormat nf = NumberFormat.getCurrencyInstance(Locale.CHINA); char formatted = nf.format(7000).charAt(0); @@ -255,7 +261,7 @@ public class LocaleProviders { } static void bug8220227Test() { - if (System.getProperty("os.name").startsWith("Windows")) { + if (IS_WINDOWS) { Locale l = new Locale("xx","XX"); String country = l.getDisplayCountry(); if (country.endsWith("(XX)")) { @@ -264,4 +270,20 @@ public class LocaleProviders { } } } + + static void bug8228465Test() { + LocaleProviderAdapter lda = LocaleProviderAdapter.getAdapter(CalendarNameProvider.class, Locale.US); + LocaleProviderAdapter.Type type = lda.getAdapterType(); + if (type == LocaleProviderAdapter.Type.HOST && IS_WINDOWS) { + var names = new GregorianCalendar() + .getDisplayNames(Calendar.ERA, Calendar.SHORT_FORMAT, Locale.US); + if (!names.keySet().contains("AD") || + names.get("AD").intValue() != 1) { + throw new RuntimeException( + "Short Era name for 'AD' is missing or incorrect"); + } else { + System.out.println("bug8228465Test succeeded."); + } + } + } } diff --git a/test/jdk/java/util/Locale/LocaleProvidersRun.java b/test/jdk/java/util/Locale/LocaleProvidersRun.java index 4f3d3d0f53f..0a50096e459 100644 --- a/test/jdk/java/util/Locale/LocaleProvidersRun.java +++ b/test/jdk/java/util/Locale/LocaleProvidersRun.java @@ -25,7 +25,7 @@ * @test * @bug 6336885 7196799 7197573 7198834 8000245 8000615 8001440 8008577 * 8010666 8013086 8013233 8013903 8015960 8028771 8054482 8062006 - * 8150432 8215913 8220227 + * 8150432 8215913 8220227 8228465 * @summary tests for "java.locale.providers" system property * @library /test/lib * @build LocaleProviders @@ -154,6 +154,8 @@ public class LocaleProvidersRun { testRun("HOST", "bug8220227Test", "", "", ""); } + //testing 8228465 fix. (Windows only) + testRun("HOST", "bug8228465Test", "", "", ""); } private static void testRun(String prefList, String methodName,