1 /* 2 * Copyright (c) 2014, 2016 Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 20 * or visit www.oracle.com if you need additional information or have any 21 * questions. 22 */ 23 24 /* 25 * @test 26 * @bug 8038436 8158504 27 * @summary Test for changes in 8038436 28 * @modules java.base/sun.util.locale.provider 29 * java.base/sun.util.spi 30 * @compile -XDignore.symbol.file Bug8038436.java 31 * @run main/othervm -limitmods java.base Bug8038436 security 32 * @run main/othervm -Djava.locale.providers=COMPAT Bug8038436 availlocs 33 */ 34 35 import java.security.*; 36 import java.util.*; 37 import java.util.stream.*; 38 import sun.util.locale.provider.*; 39 40 public class Bug8038436 { 41 public static void main(String[] args) { 42 43 switch (args[0]) { 44 45 case "security": 46 securityTests(); 47 break; 48 case "availlocs": 49 availableLocalesTests(); 50 break; 51 default: 52 throw new RuntimeException("no test was specified."); 53 } 54 55 } 56 57 private static void securityTests() { 58 Policy.setPolicy(new MyPolicy()); 59 System.setSecurityManager(new SecurityManager()); 60 61 /* 62 * Test for AccessClassInPackage security exception. Confirms that 63 * exeption won't be thrown if an application sets a Permission that 64 * does not allow any RuntimePermission, on loading LocaleDataMetaInfo 65 * from jdk.localedata module. 66 */ 67 System.out.println(new Formatter(Locale.JAPAN).format("%1$tB %1$te, %1$tY", 68 new GregorianCalendar())); 69 70 /* 71 * Check only English/ROOT locales are returned if the jdk.localedata 72 * module is not loaded (implied by "-limitmods java.base"). 73 */ 74 List<Locale> nonEnglishLocales= (Arrays.stream(Locale.getAvailableLocales()) 75 .filter(l -> (l != Locale.ROOT && !(l.getLanguage() == "en" && (l.getCountry() == "US" || l.getCountry() == "" )))) 76 .collect(Collectors.toList())); 77 78 if (!nonEnglishLocales.isEmpty()) { 79 throw new RuntimeException("non English locale(s)" + nonEnglishLocales + " included in available locales"); 80 } 81 } 82 83 84 static class MyPolicy extends Policy { 85 final PermissionCollection perms = new Permissions(); 86 87 MyPolicy() { 88 // allows no RuntimePermission 89 } 90 91 public PermissionCollection getPermissions(ProtectionDomain domain) { 92 return perms; 93 } 94 95 public PermissionCollection getPermissions(CodeSource codesource) { 96 return perms; 97 } 98 99 public boolean implies(ProtectionDomain domain, Permission perm) { 100 return perms.implies(perm); 101 } 102 } 103 104 static final String[] bipLocs = ("ar, ar-JO, ar-LB, ar-SY, be, be-BY, bg, " + 105 "bg-BG, ca, ca-ES, cs, cs-CZ, da, da-DK, de, de-AT, de-CH, de-DE, " + 106 "de-LU, el, el-CY, el-GR, en, en-AU, en-CA, en-GB, en-IE, en-IN, " + 107 "en-MT, en-NZ, en-PH, en-SG, en-US, en-ZA, es, es-AR, es-BO, es-CL, " + 108 "es-CO, es-CR, es-DO, es-EC, es-ES, es-GT, es-HN, es-MX, es-NI, " + 109 "es-PA, es-PE, es-PR, es-PY, es-SV, es-US, es-UY, es-VE, et, et-EE, " + 110 "fi, fi-FI, fr, fr-BE, fr-CA, fr-CH, fr-FR, ga, ga-IE, he, he-IL, " + 111 "hi-IN, hr, hr-HR, hu, hu-HU, id, id-ID, is, is-IS, it, it-CH, it-IT, " + 112 "ja, ja-JP, ko, ko-KR, lt, lt-LT, lv, lv-LV, mk, mk-MK, ms, ms-MY, mt, " + 113 "mt-MT, nl, nl-BE, nl-NL, no, no-NO, no-NO, pl, pl-PL, pt, pt-BR, " + 114 "pt-PT, ro, ro-RO, ru, ru-RU, sk, sk-SK, sl, sl-SI, sq, sq-AL, sr, " + 115 "sr-BA, sr-CS, sr-Latn, sr-Latn-ME, sr-ME, sr-RS, sv, sv-SE, th, th-TH, " + 116 "tr, tr-TR, uk, uk-UA, und, vi, vi-VN, zh, zh-CN, zh-HK, zh-Hans-CN, " + 117 "zh-Hans-SG, zh-Hant-HK, zh-Hant-TW, zh-SG, zh-TW, ").split(",\\s*"); 118 static final String[] dfpLocs = bipLocs; 119 static final String[] datefspLocs = bipLocs; 120 static final String[] decimalfspLocs = bipLocs; 121 static final String[] calnpLocs = bipLocs; 122 static final String[] cpLocs = ("ar, be, bg, ca, cs, da, el, es, et, fi, " + 123 "fr, he, hi, hr, hu, is, ja, ko, lt, lv, mk, no, pl, ro, ru, sk, sl, " + 124 "sq, sr, sr-Latn, sv, th, tr, uk, und, vi, zh, zh-HK, zh-Hant-HK, " + 125 "zh-Hant-TW, zh-TW, ").split(",\\s*"); 126 static final String[] nfpLocs = ("ar, ar-AE, ar-BH, ar-DZ, ar-EG, ar-IQ, " + 127 "ar-JO, ar-KW, ar-LB, ar-LY, ar-MA, ar-OM, ar-QA, ar-SA, ar-SD, ar-SY, " + 128 "ar-TN, ar-YE, be, be-BY, bg, bg-BG, ca, ca-ES, cs, cs-CZ, da, da-DK, " + 129 "de, de-AT, de-CH, de-DE, de-GR, de-LU, el, el-CY, el-GR, en, en-AU, " + 130 "en-CA, en-GB, en-IE, en-IN, en-MT, en-NZ, en-PH, en-SG, en-US, en-ZA, " + 131 "es, es-AR, es-BO, es-CL, es-CO, es-CR, es-CU, es-DO, es-EC, es-ES, " + 132 "es-GT, es-HN, es-MX, es-NI, es-PA, es-PE, es-PR, es-PY, es-SV, es-US, " + 133 "es-UY, es-VE, et, et-EE, fi, fi-FI, fr, fr-BE, fr-CA, fr-CH, fr-FR, " + 134 "fr-LU, ga, ga-IE, he, he-IL, hi, hi-IN, hr, hr-HR, hu, hu-HU, id, " + 135 "id-ID, is, is-IS, it, it-CH, it-IT, ja, ja-JP, " + 136 "ja-JP-u-ca-japanese-x-lvariant-JP, ko, ko-KR, lt, lt-LT, lv, lv-LV, " + 137 "mk, mk-MK, ms, ms-MY, mt, mt-MT, nb-NO, nl, nl-BE, nl-NL, nn-NO, " + 138 "nn-NO, no, no-NO, pl, pl-PL, pt, pt-BR, pt-PT, ro, ro-RO, ru, ru-RU, " + 139 "sk, sk-SK, sl, sl-SI, sq, sq-AL, sr, sr-BA, sr-CS, sr-Latn, " + 140 "sr-Latn-BA, sr-Latn-ME, sr-Latn-RS, sr-ME, sr-RS, sv, sv-SE, th, " + 141 "th-TH, th-TH-u-nu-thai-x-lvariant-TH, tr, tr-TR, uk, uk-UA, und, vi, " + 142 "vi-VN, zh, zh-CN, zh-HK, zh-Hans-CN, zh-Hans-SG, zh-Hant-HK, " + 143 "zh-Hant-TW, zh-SG, zh-TW, ").split(",\\s*"); 144 static final String[] currencynpLocs = ("ar-AE, ar-BH, ar-DZ, ar-EG, ar-IQ, " + 145 "ar-JO, ar-KW, ar-LB, ar-LY, ar-MA, ar-OM, ar-QA, ar-SA, ar-SD, ar-SY, " + 146 "ar-TN, ar-YE, be-BY, bg-BG, ca-ES, cs-CZ, da-DK, de, de-AT, de-CH, " + 147 "de-DE, de-GR, de-LU, el-CY, el-GR, en-AU, en-CA, en-GB, en-IE, en-IN, " + 148 "en-MT, en-NZ, en-PH, en-SG, en-US, en-ZA, es, es-AR, es-BO, es-CL, " + 149 "es-CO, es-CR, es-CU, es-DO, es-EC, es-ES, es-GT, es-HN, es-MX, es-NI, " + 150 "es-PA, es-PE, es-PR, es-PY, es-SV, es-US, es-UY, es-VE, et-EE, fi-FI, " + 151 "fr, fr-BE, fr-CA, fr-CH, fr-FR, fr-LU, ga-IE, he-IL, hi-IN, hr-HR, " + 152 "hu-HU, id-ID, is-IS, it, it-CH, it-IT, ja, ja-JP, ko, ko-KR, lt-LT, " + 153 "lv-LV, mk-MK, ms-MY, mt-MT, nl-BE, nl-NL, no-NO, pl-PL, pt, pt-BR, " + 154 "pt-PT, ro-RO, ru-RU, sk-SK, sl-SI, sq-AL, sr-BA, sr-CS, sr-Latn-BA, " + 155 "sr-Latn-ME, sr-Latn-RS, sr-ME, sr-RS, sv, sv-SE, th-TH, tr-TR, uk-UA, " + 156 "und, vi-VN, zh-CN, zh-HK, zh-Hans-CN, zh-Hans-SG, zh-Hant-HK, " + 157 "zh-Hant-TW, zh-SG, zh-TW, ").split(",\\s*"); 158 static final String[] lnpLocs = ("ar, be, bg, ca, cs, da, de, el, el-CY, " + 159 "en, en-MT, en-PH, en-SG, es, es-US, et, fi, fr, ga, he, hi, hr, hu, " + 160 "id, is, it, ja, ko, lt, lv, mk, ms, mt, nl, no, no-NO, pl, pt, pt-BR, " + 161 "pt-PT, ro, ru, sk, sl, sq, sr, sr-Latn, sv, th, tr, uk, und, vi, zh, " + 162 "zh-HK, zh-Hans-SG, zh-Hant-HK, zh-Hant-TW, zh-SG, zh-TW, ").split(",\\s*"); 163 static final String[] tznpLocs = ("de, en, en-CA, en-GB, en-IE, es, fr, hi, " + 164 "it, ja, ko, pt-BR, sv, und, zh-CN, zh-HK, zh-Hans-CN, zh-Hant-HK, " + 165 "zh-Hant-TW, zh-TW, ").split(",\\s*"); 166 static final String[] caldpLocs = ("ar, be, bg, ca, cs, da, de, el, el-CY, " + 167 "en, en-GB, en-IE, en-MT, es, es-ES, es-US, et, fi, fr, fr-CA, he, hi, " + 168 "hr, hu, id-ID, is, it, ja, ko, lt, lv, mk, ms-MY, mt, mt-MT, nl, no, " + 169 "pl, pt, pt-BR, pt-PT, ro, ru, sk, sl, sq, sr, sr-Latn-BA, sr-Latn-ME, " + 170 "sr-Latn-RS, sv, th, tr, uk, und, vi, zh, ").split(",\\s*"); 171 static final String[] calpLocs = caldpLocs; 172 173 /* 174 * Validate whether JRE's *Providers return supported locales list based on 175 * their actual resource bundle exsistence. The above golden data 176 * are manually extracted, so they need to be updated if new locale 177 * data resource bundle were added. 178 */ 179 private static void availableLocalesTests() { 180 LocaleProviderAdapter jre = LocaleProviderAdapter.forJRE(); 181 182 checkAvailableLocales("BreakIteratorProvider", 183 jre.getBreakIteratorProvider().getAvailableLocales(), bipLocs); 184 checkAvailableLocales("CollatorProvider", 185 jre.getCollatorProvider().getAvailableLocales(), cpLocs); 186 checkAvailableLocales("DateFormatProvider", 187 jre.getDateFormatProvider().getAvailableLocales(), dfpLocs); 188 checkAvailableLocales("DateFormatSymbolsProvider", 189 jre.getDateFormatSymbolsProvider().getAvailableLocales(), datefspLocs); 190 checkAvailableLocales("DecimalFormatSymbolsProvider", 191 jre.getDecimalFormatSymbolsProvider().getAvailableLocales(), decimalfspLocs); 192 checkAvailableLocales("NumberFormatProvider", 193 jre.getNumberFormatProvider().getAvailableLocales(), nfpLocs); 194 checkAvailableLocales("CurrencyNameProvider", 195 jre.getCurrencyNameProvider().getAvailableLocales(), currencynpLocs); 196 checkAvailableLocales("LocaleNameProvider", 197 jre.getLocaleNameProvider().getAvailableLocales(), lnpLocs); 198 checkAvailableLocales("TimeZoneNameProvider", 199 jre.getTimeZoneNameProvider().getAvailableLocales(), tznpLocs); 200 checkAvailableLocales("CalendarDataProvider", 201 jre.getCalendarDataProvider().getAvailableLocales(), caldpLocs); 202 checkAvailableLocales("CalendarNameProvider", 203 jre.getCalendarNameProvider().getAvailableLocales(), calnpLocs); 204 checkAvailableLocales("CalendarProvider", 205 jre.getCalendarProvider().getAvailableLocales(), calpLocs); 206 } 207 208 private static void checkAvailableLocales(String testName, Locale[] got, String[] expected) { 209 System.out.println("Testing available locales for " + testName); 210 List<Locale> gotList = Arrays.asList(got).stream() 211 .map(Locale::toLanguageTag) 212 .sorted() 213 .map(Locale::forLanguageTag) 214 .collect(Collectors.toList()); 215 List<Locale> expectedList = Arrays.asList(expected).stream() 216 .map(Locale::forLanguageTag) 217 .collect(Collectors.toList()); 218 219 if (!gotList.equals(expectedList)) { 220 throw new RuntimeException("\n" + gotList.toString() + "\n is not equal to \n" + 221 expectedList.toString()); 222 } 223 } 224 }