Print this page
rev 5696 : 6336885: RFE: Locale Data Deployment Enhancements
4609153: Provide locale data for Indic locales
5104387: Support for gl_ES locale (galician language)
6337471: desktop/system locale preferences support
7056139: (cal) SPI support for locale-dependent Calendar parameters
7058206: Provide CalendarData SPI for week params and display field value names
7073852: Support multiple scripts for digits and decimal symbols per locale
7079560: [Fmt-Da] Context dependent month names support in SimpleDateFormat
7171324: getAvailableLocales() of locale sensitive services should return the actual availability of locales
7151414: (cal) Support calendar type identification
7168528: LocaleServiceProvider needs to be aware of Locale extensions
7171372: (cal) locale's default Calendar should be created if unknown calendar is specified
Summary: JEP 127: Improve Locale Data Packaging and Adopt Unicode CLDR Data (part 1 w/o packaging changes. by Naoto Sato and Masayoshi Okutsu)
Split |
Close |
Expand all |
Collapse all |
--- old/test/java/util/PluggableLocale/CurrencyNameProviderTest.java
+++ new/test/java/util/PluggableLocale/CurrencyNameProviderTest.java
1 1 /*
2 - * Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved.
2 + * Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved.
3 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 4 *
5 5 * This code is free software; you can redistribute it and/or modify it
6 6 * under the terms of the GNU General Public License version 2 only, as
7 7 * published by the Free Software Foundation.
8 8 *
9 9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 12 * version 2 for more details (a copy is included in the LICENSE file that
13 13 * accompanied this code).
14 14 *
15 15 * You should have received a copy of the GNU General Public License version
16 16 * 2 along with this work; if not, write to the Free Software Foundation,
17 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 18 *
↓ open down ↓ |
6 lines elided |
↑ open up ↑ |
19 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 20 * or visit www.oracle.com if you need additional information or have any
21 21 * questions.
22 22 */
23 23 /*
24 24 *
25 25 */
26 26
27 27 import java.text.*;
28 28 import java.util.*;
29 -import sun.util.*;
29 +import sun.util.locale.provider.*;
30 30 import sun.util.resources.*;
31 31
32 32 public class CurrencyNameProviderTest extends ProviderTest {
33 33
34 34 public static void main(String[] s) {
35 35 Locale reservedLocale = Locale.getDefault();
36 36 try {
37 37 new CurrencyNameProviderTest();
38 38 } finally {
39 39 // restore the reserved locale
40 40 Locale.setDefault(reservedLocale);
41 41 }
42 42 }
43 43
44 44 CurrencyNameProviderTest() {
45 45 test1();
46 46 test2();
↓ open down ↓ |
7 lines elided |
↑ open up ↑ |
47 47 }
48 48
49 49 void test1() {
50 50 com.bar.CurrencyNameProviderImpl cnp = new com.bar.CurrencyNameProviderImpl();
51 51 Locale[] availloc = Locale.getAvailableLocales();
52 52 Locale[] testloc = availloc.clone();
53 53 List<Locale> providerloc = Arrays.asList(cnp.getAvailableLocales());
54 54
55 55 for (Locale target: availloc) {
56 56 // pure JRE implementation
57 - OpenListResourceBundle rb = (OpenListResourceBundle)LocaleData.getCurrencyNames(target);
57 + OpenListResourceBundle rb = (OpenListResourceBundle)LocaleProviderAdapter.forJRE().getLocaleData().getCurrencyNames(target);
58 58 boolean jreHasBundle = rb.getLocale().equals(target);
59 59
60 60 for (Locale test: testloc) {
61 61 // get a Currency instance
62 62 Currency c = null;
63 63 try {
64 64 c = Currency.getInstance(test);
65 65 } catch (IllegalArgumentException iae) {}
66 66
67 67 if (c == null) {
68 68 continue;
69 69 }
70 70
71 71 // the localized symbol for the target locale
72 72 String currencyresult = c.getSymbol(target);
73 73
74 74 // the localized name for the target locale
75 75 String nameresult = c.getDisplayName(target);
76 76
77 77 // provider's name (if any)
78 78 String providerscurrency = null;
79 79 String providersname = null;
80 80 if (providerloc.contains(target)) {
81 81 providerscurrency = cnp.getSymbol(c.getCurrencyCode(), target);
82 82 providersname = cnp.getDisplayName(c.getCurrencyCode(), target);
83 83 }
84 84
85 85 // JRE's name (if any)
86 86 String jrescurrency = null;
87 87 String jresname = null;
88 88 String key = c.getCurrencyCode();
89 89 String nameKey = key.toLowerCase(Locale.ROOT);
90 90 if (jreHasBundle) {
91 91 try {
92 92 jrescurrency = rb.getString(key);
93 93 } catch (MissingResourceException mre) {
94 94 // JRE does not have any resource, "jrescurrency" should remain null
95 95 }
96 96 try {
97 97 jresname = rb.getString(nameKey);
98 98 } catch (MissingResourceException mre) {
99 99 // JRE does not have any resource, "jresname" should remain null
100 100 }
101 101 }
102 102
103 103 checkValidity(target, jrescurrency, providerscurrency, currencyresult, jrescurrency!=null);
104 104 checkValidity(target, jresname, providersname, nameresult,
105 105 jreHasBundle && rb.handleGetKeys().contains(nameKey));
106 106 }
107 107 }
108 108 }
109 109
110 110
111 111 final String pattern = "###,###\u00A4";
112 112 final String YEN_IN_OSAKA = "100,000\u5186\u3084\u3002";
113 113 final String YEN_IN_KYOTO = "100,000\u5186\u3069\u3059\u3002";
114 114 final Locale OSAKA = new Locale("ja", "JP", "osaka");
115 115 final Locale KYOTO = new Locale("ja", "JP", "kyoto");
116 116 Integer i = new Integer(100000);
117 117 String formatted;
118 118 DecimalFormat df;
119 119
120 120 void test2() {
121 121 try {
122 122 df = new DecimalFormat(pattern, DecimalFormatSymbols.getInstance(OSAKA));
123 123 System.out.println(formatted = df.format(i));
124 124 if(!formatted.equals(YEN_IN_OSAKA)) {
125 125 throw new RuntimeException("formatted zone names mismatch. " +
126 126 "Should match with " + YEN_IN_OSAKA);
127 127 }
128 128
129 129 df.parse(YEN_IN_OSAKA);
130 130
131 131 Locale.setDefault(KYOTO);
132 132 df = new DecimalFormat(pattern, DecimalFormatSymbols.getInstance());
133 133 System.out.println(formatted = df.format(i));
134 134 if(!formatted.equals(YEN_IN_KYOTO)) {
135 135 throw new RuntimeException("formatted zone names mismatch. " +
136 136 "Should match with " + YEN_IN_KYOTO);
137 137 }
138 138
139 139 df.parse(YEN_IN_KYOTO);
140 140 } catch (ParseException pe) {
141 141 throw new RuntimeException("parse error occured" + pe);
142 142 }
143 143 }
144 144 }
↓ open down ↓ |
77 lines elided |
↑ open up ↑ |
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX