summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Lib/test/test__locale.py60
-rw-r--r--Misc/NEWS61
2 files changed, 95 insertions, 26 deletions
diff --git a/Lib/test/test__locale.py b/Lib/test/test__locale.py
index 97aaef8..e0f64ec 100644
--- a/Lib/test/test__locale.py
+++ b/Lib/test/test__locale.py
@@ -1,6 +1,8 @@
-from test.test_support import verbose, TestSkipped
-from _locale import setlocale, LC_NUMERIC, RADIXCHAR, THOUSEP, nl_langinfo
-from _locale import localeconv, Error
+from test.test_support import verbose, TestSkipped, run_unittest
+from _locale import (setlocale, LC_NUMERIC, RADIXCHAR, THOUSEP, nl_langinfo,
+ localeconv, Error)
+from locale import getlocale
+import unittest
candidate_locales = ['es_UY', 'fr_FR', 'fi_FI', 'es_CO', 'pt_PT', 'it_IT',
'et_EE', 'es_PY', 'no_NO', 'nl_NL', 'lv_LV', 'el_GR', 'be_BY', 'fr_BE',
@@ -13,26 +15,32 @@ candidate_locales = ['es_UY', 'fr_FR', 'fi_FI', 'es_CO', 'pt_PT', 'it_IT',
'eu_ES', 'vi_VN', 'af_ZA', 'nb_NO', 'en_DK', 'tg_TJ',
'es_ES.ISO8859-1', 'fr_FR.ISO8859-15', 'ru_RU.KOI8-R', 'ko_KR.eucKR']
-oldlocale = setlocale(LC_NUMERIC)
-try:
- saw_locale = 0
- for loc in candidate_locales:
- try:
- setlocale(LC_NUMERIC, loc)
- except Error:
- continue
- if verbose:
- print "locale %r" % loc
- saw_locale = 1
- nl_radixchar = nl_langinfo(RADIXCHAR)
- li_radixchar = localeconv()['decimal_point']
- if nl_radixchar != li_radixchar:
- print "%r != %r" % (nl_radixchar, li_radixchar)
- nl_radixchar = nl_langinfo(THOUSEP)
- li_radixchar = localeconv()['thousands_sep']
- if nl_radixchar != li_radixchar:
- print "%r != %r" % (nl_radixchar, li_radixchar)
- if not saw_locale:
- raise ImportError, "None of the listed locales found"
-finally:
- setlocale(LC_NUMERIC, oldlocale)
+class _LocaleTests(unittest.TestCase):
+
+ def setUp(self):
+ self.oldlocale = setlocale(LC_NUMERIC)
+
+ def tearDown(self):
+ setlocale(LC_NUMERIC, self.oldlocale)
+
+ def test_lc_numeric(self):
+ for loc in candidate_locales:
+ try:
+ setlocale(LC_NUMERIC, loc)
+ except Error:
+ continue
+ for li, lc in ((RADIXCHAR, "decimal_point"),
+ (THOUSEP, "thousands_sep")):
+ nl_radixchar = nl_langinfo(li)
+ li_radixchar = localeconv()[lc]
+ self.assertEquals(nl_radixchar, li_radixchar,
+ "%r != %r (%s); "
+ "supposed to be %s, set to %s" %
+ (nl_radixchar, li_radixchar, lc,
+ loc, getlocale(LC_NUMERIC)[0]))
+
+def test_main():
+ run_unittest(_LocaleTests)
+
+if __name__ == '__main__':
+ test_main()
diff --git a/Misc/NEWS b/Misc/NEWS
index 1a721cb..4f3ced8 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -4,6 +4,67 @@ Python News
(editors: check NEWS.help for information about editing NEWS using ReST.)
+What's New in Python 2.4 beta 1?
+================================
+
+*Release date: XXXX-XX-XX*
+
+Core and builtins
+-----------------
+
+...
+
+Extension modules
+-----------------
+
+...
+
+Library
+-------
+
+...
+
+Build
+-----
+
+...
+
+C API
+-----
+
+...
+
+Documentation
+-------------
+
+...
+
+Tests
+-----
+
+- test__locale ported to unittest
+
+Windows
+-------
+
+...
+
+Mac
+---
+
+...
+
+New platforms
+-------------
+
+...
+
+Tools/Demos
+-----------
+
+...
+
+
What's New in Python 2.4 alpha 3?
=================================