jdk-24/jdk/test/java/util/Locale/PrintDefaultLocale.java
Kelly O'Hair fe008ae27a 6943119: Rebrand source copyright notices
Reviewed-by: darcy, weijun
2010-05-25 15:58:33 -07:00

239 lines
11 KiB
Java

/*
* Copyright (c) 2007, 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.println(Locale.getDefault().toString());
System.out.println(Locale.getDefault().getDisplayName(Locale.US));
System.out.println(Charset.defaultCharset());
}
}