3789983e89
Reviewed-by: darcy, ihse
246 lines
12 KiB
Java
246 lines
12 KiB
Java
/*
|
|
* Copyright (c) 2007, 2010, 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.
|
|
*/
|
|
/*
|
|
*
|
|
*
|
|
* (C) Copyright IBM Corp. 1998 - All Rights Reserved
|
|
*
|
|
* Portions copyright (c) 2007 Sun Microsystems, Inc.
|
|
* All Rights Reserved.
|
|
*
|
|
* The original version of this source code and documentation
|
|
* is copyrighted and owned by Taligent, Inc., a wholly-owned
|
|
* subsidiary of IBM. These materials are provided under terms
|
|
* of a License Agreement between Taligent and Sun. This technology
|
|
* is protected by multiple US and International patents.
|
|
*
|
|
* This notice and attribution to Taligent may not be removed.
|
|
* Taligent is a registered trademark of Taligent, Inc.
|
|
*
|
|
* Permission to use, copy, modify, and distribute this software
|
|
* and its documentation for NON-COMMERCIAL purposes and without
|
|
* fee is hereby granted provided that this copyright notice
|
|
* appears in all copies. Please refer to the file "copyright.html"
|
|
* for further important copyright and licensing information.
|
|
*
|
|
* SUN MAKES NO REPRESENTATIONS OR WARRANTIES ABOUT THE SUITABILITY OF
|
|
* THE SOFTWARE, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
|
|
* TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
|
|
* PARTICULAR PURPOSE, OR NON-INFRINGEMENT. SUN SHALL NOT BE LIABLE FOR
|
|
* ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
|
|
* DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES.
|
|
*
|
|
*/
|
|
/*
|
|
@bug 4123370 4091969 4118731 4182108 4778440
|
|
|
|
The "at-test" tag was removed from this file, because there's no way to
|
|
run this test in an automated test harness. It depends on having various
|
|
different locales installed on the machine, and on Windows it depends
|
|
on the user going to the "Regional Settings" control panel and changing
|
|
the settings before running the test for each bug. We can run this test
|
|
manually from time to time to ensure that there has been no regression,
|
|
but it's not automated. -- lwerner, 7/6/98
|
|
|
|
INSTRUCTIONS FOR RUNNING THIS TEST
|
|
==================================
|
|
This test is designed to check for problems in the JVM code that initializes the
|
|
default Java locale (the locale returned by Locale.getDefault()) from the system
|
|
locale settings (or from command-line arguments). Since detecting a regression
|
|
usually requires setting the environment up in some way prior to running the test,
|
|
this is a manual test.
|
|
|
|
The test simply prints out the internal ID and display name of the default Java locale,
|
|
and the name of the default Java character encoding. It passes if these are what
|
|
you expect them to be, and fails if they're not.
|
|
|
|
Bug #4091969:
|
|
To test for bug #4091969, run this test on a Korean-localized version of
|
|
Windows, with the default locale set to Korean. You should get "ko_KR"
|
|
as the default locale.
|
|
|
|
Bug #4123370:
|
|
One part of bug #4123370 duplicates bug #4091969, which is covered by the
|
|
instructions above.
|
|
|
|
To test the unique part of bug #4123370, use the "Regional Settings" control
|
|
panel to set the currect locale to each of the different Spanish-language locales.
|
|
Run this test once for each Spanish-language locale. You should see the appropriate
|
|
locale ID and name for each locale. Both "Spanish - Traditional Sort" and
|
|
"Spanish - Modern Sort" should produce "es_ES" and "Spanish (Spain)".
|
|
|
|
Bug #4118731:
|
|
The basic issue here was that we had changed so that calling getDisplayName()
|
|
on a locale that didn't include a country code no longer included a country
|
|
name (instead of picking a default country name, as before), which is the
|
|
right answer. The problem is we weren't always getting back a system default
|
|
locale from Solaris that includes a country code, even though we should.
|
|
|
|
To test this, set the system default locale to a locale that doesn't include
|
|
a country code, such as "fr" or "de", using (in the C shell) "setenv LC_ALL fr"
|
|
(or whatever the locale ID you want is). Running PrintDefaultLocale should
|
|
still produce a locale ID, and a locale display name, that include a country
|
|
code (and country name). [Remember to make sure the locale is actually installed
|
|
first.]
|
|
|
|
To test the specific complaint in the bug, use "setenv LC_ALL ja". Also pay
|
|
special attention to Solaris locale IDs that don't match the corresponding java
|
|
locales, such as "su" (which should turn into "fi_FI"), "cz" (which should turn
|
|
into "cs_CZ"), and "en_UK" (which should turn into "en_GB").
|
|
|
|
Bug #4079167:
|
|
Test this bug the same way you test bug #4118731. Set the locale to each of
|
|
the specified locale IDs (e.g., "setenv LC_ALL japanese"), and then run
|
|
PrintDefaultLocale. You should get the following results:
|
|
Solaris ID Java ID Java display name Encoding
|
|
========== ======= ==================== ========
|
|
japanese ja_JP Japanese (Japan) --
|
|
korean ko_KR Korean (South Korea) --
|
|
tchinese zh_TW Chinese (Taiwan) --
|
|
big5 zh_TW Chinese (Taiwan) Big5
|
|
(Where "--" is marked for "encoding," the result isn't important-- it's the
|
|
default encoding for that locale, which we don't test. It should be something
|
|
plausible. Also note that this test presupposed you actually have locales
|
|
with these names installed on your system.)
|
|
|
|
Bug #4154559, 4778440:
|
|
Set the locale to Norwegian (Bokmal) and Norwegian (Nynorsk) using the
|
|
Regional Settings control panel on Windows. For each setting, run this program.
|
|
You should see no_NO and no_NO_NY, respectively.
|
|
|
|
Bug #4182108:
|
|
Test this bug the same way you test bug #4118731. Set the locale to
|
|
each of the specified locale IDs (e.g., "setenv LC_ALL japanese"), and
|
|
then run PrintDefaultLocale. You should get the following results:
|
|
|
|
Solaris ID Java ID Encoding
|
|
========== ======= ========
|
|
cz cs_CZ --
|
|
su fi_FI --
|
|
fr.ISO8859-15 fr_FR ISO8859-15
|
|
fr.ISO8859-15@euro fr_FR ISO8859-15
|
|
|
|
Where "--" is marked for "encoding," the result isn't important-- it's
|
|
the default encoding for that locale, which we don't test. It should be
|
|
something plausible. Also note that this test presupposed you actually
|
|
have locales with these names installed on your system.
|
|
|
|
As of this writing, there is a bug in Solaris or in the 8859-15/euro
|
|
patch for 2.6 (Solaris patch 106842-01) which causes nl_langinfo() to
|
|
return the wrong value for 8859-15 locales. As a result, the encoding
|
|
returned by this test is currency ISO8859-1 for 8859-15 locales.
|
|
|
|
Bug #4778440, 5005601, 5074060, 5107154:
|
|
Run the "deflocale" tool found in "data" directory (deflocale.sh on Unix,
|
|
deflocale.exe on Windows), and check the following:
|
|
|
|
4778440: Check that iw_IL is the default locale if the OS's locale is
|
|
Hebrew, and in_ID for Indonesian.
|
|
5005601: For Norwegian locales, no_NO is selected for Bokmal, and no_NO_NY
|
|
is selected for Nynorsk.
|
|
5074060, 5107154: On Windows XP ServicePack 2, check the default locales for the
|
|
following Windows locales. Compare with the golden data (deflocale.win):
|
|
Bengali - India
|
|
Croatian - Bosnia and Herzegovina
|
|
Bosnian - Bosnia and Herzegovina
|
|
Serbian (Latin) - Bosnia and Herzegovina
|
|
Serbian (Cyrillic) - Bosnia and Herzegovina
|
|
Welsh - United Kingdom
|
|
Maori - New Zealand
|
|
Malayalam - India
|
|
Maltese - Malta
|
|
Quechua - Bolivia
|
|
Quechua - Ecuador
|
|
Quechua - Peru
|
|
Setswana (Tswana) - South Africa
|
|
isiXhosa (Xhosa) - South Africa
|
|
isiZulu ( Zulu) - South Africa
|
|
Sesotho sa Leboa (Northern Sotho) - South Africa
|
|
Sami, Northern - Norway
|
|
Sami, Northern - Sweden
|
|
Sami, Northern - Finland
|
|
Sami, Lule - Norway
|
|
Sami, Lule - Sweden
|
|
Sami, Southern - Norway
|
|
Sami, Southern - Sweden
|
|
Sami, Skolt - Finland
|
|
Sami, Inari - Finland
|
|
|
|
Bug # 6409997:
|
|
Run the "deflocale.exe" tool found in "data" directory on Windows Vista.
|
|
It contains the following new locales:
|
|
Tajik (Cyrillic) (Tajikistan) - 1251
|
|
Upper Sorbian (Germany) - 1252
|
|
Turkmen (Turkmenistan) - 1250
|
|
Oriya (India) - 0
|
|
Assamese (India) - 0
|
|
Tibetan (People's Republic of China) - 0
|
|
Khmer (Cambodia) - 0
|
|
Lao (Lao P.D.R.) - 0
|
|
Sinhala (Sri Lanka) - 0
|
|
Inuktitut (Canada) - 0
|
|
Amharic (Ethiopia) - 0
|
|
Hausa (Latin) (Nigeria) - 1252
|
|
Yoruba (Nigeria) - 1252
|
|
Bashkir (Russia) - 1251
|
|
Greenlandic (Greenland) - 1252
|
|
Igbo (Nigeria) - 1252
|
|
Yi (People's Republic of China) - 0
|
|
Breton (France) - 1252
|
|
Uighur (People's Republic of China) - 1256
|
|
Occitan (France) - 1252
|
|
Corsican (France) - 1252
|
|
Alsatian (France) - 1252
|
|
Yakut (Russia) - 1251
|
|
K'iche (Guatemala) - 1252
|
|
Kinyarwanda (Rwanda) - 1252
|
|
Wolof (Senegal) - 1252
|
|
Dari (Afghanistan) - 1256
|
|
Lower Sorbian (Germany) - 1252
|
|
Bengali (Bangladesh) - 0
|
|
Mongolian (Traditional Mongolian) (People's Republic of China) - 0
|
|
Tamazight (Latin) (Algeria) - 1252
|
|
English (India) - 1252
|
|
English (Malaysia) - 1252
|
|
English (Singapore) - 1252
|
|
Spanish (United States) - 1252
|
|
|
|
*/
|
|
import java.nio.charset.Charset;
|
|
import java.util.Locale;
|
|
|
|
public class PrintDefaultLocale {
|
|
public static void main(String[] args) {
|
|
System.out.printf("default locale: ID: %s, Name: %s\n",
|
|
Locale.getDefault().toString(),
|
|
Locale.getDefault().getDisplayName(Locale.US));
|
|
System.out.printf("display locale: ID: %s, Name: %s\n",
|
|
Locale.getDefault(Locale.Category.DISPLAY).toString(),
|
|
Locale.getDefault(Locale.Category.DISPLAY).getDisplayName(Locale.US));
|
|
System.out.printf("format locale: ID: %s, Name: %s\n",
|
|
Locale.getDefault(Locale.Category.FORMAT).toString(),
|
|
Locale.getDefault(Locale.Category.FORMAT).getDisplayName(Locale.US));
|
|
System.out.printf("default charset: %s\n", Charset.defaultCharset());
|
|
}
|
|
}
|