]> granicus.if.org Git - python/commitdiff
Work around test_locale failing on Solaris.
authorMartin v. Löwis <martin@v.loewis.de>
Fri, 30 Dec 2005 12:51:45 +0000 (12:51 +0000)
committerMartin v. Löwis <martin@v.loewis.de>
Fri, 30 Dec 2005 12:51:45 +0000 (12:51 +0000)
Will backport to 2.4.

Lib/test/test_locale.py

index 2a33aafb88072a7a5e0086067598a03d6b9b8bf5..1523e77e887bcd840592125e52a5183e62bc2f2f 100644 (file)
@@ -38,13 +38,15 @@ def testformat(formatstr, value, grouping = 0, output=None):
             print "yes"
 
 try:
-    testformat("%f", 1024, grouping=1, output='1,024.000000')
+    # On Solaris 10, the thousands_sep is the empty string
+    sep = locale.localeconv()['thousands_sep']
+    testformat("%f", 1024, grouping=1, output='1%s024.000000' % sep)
     testformat("%f", 102, grouping=1, output='102.000000')
     testformat("%f", -42, grouping=1, output='-42.000000')
     testformat("%+f", -42, grouping=1, output='-42.000000')
     testformat("%20.f", -42, grouping=1, output='                 -42')
-    testformat("%+10.f", -4200, grouping=1, output='    -4,200')
-    testformat("%-10.f", 4200, grouping=1, output='4,200     ')
+    testformat("%+10.f", -4200, grouping=1, output='    -4%s200' % sep)
+    testformat("%-10.f", 4200, grouping=1, output='4%s200     ' % sep)
     # Invoke getpreferredencoding to make sure it does not cause exceptions,
     locale.getpreferredencoding()
 finally:
@@ -65,6 +67,9 @@ def teststrop(s, method, output):
         print "yes"
 
 try:
+    if sys.platform == 'sunos5':
+        # On Solaris, in en_US.UTF-8, \xa0 is a space
+        raise locale.Error
     oldlocale = locale.setlocale(locale.LC_CTYPE)
     locale.setlocale(locale.LC_CTYPE, 'en_US.UTF-8')
 except locale.Error: