]> granicus.if.org Git - python/commitdiff
Issue #14135: Make sure tests don't leave the locale changed for any
authorBrett Cannon <brett@python.org>
Mon, 1 Apr 2013 16:53:13 +0000 (12:53 -0400)
committerBrett Cannon <brett@python.org>
Mon, 1 Apr 2013 16:53:13 +0000 (12:53 -0400)
category.

Thanks to Westley Martinez for trying to fix the issue and Atsuo
Ishimoto for an initial patch.

Lib/test/regrtest.py

index 45b454116fe3ece2dae4ec341520a869b61418ac..4f747802765bb14bd99bd58b30bd644f94ced211 100755 (executable)
@@ -127,6 +127,7 @@ import builtins
 import faulthandler
 import io
 import json
+import locale
 import logging
 import os
 import platform
@@ -1061,7 +1062,7 @@ class saved_test_environment:
                  'sys.warnoptions', 'threading._dangling',
                  'multiprocessing.process._dangling',
                  'sysconfig._CONFIG_VARS', 'sysconfig._INSTALL_SCHEMES',
-                 'support.TESTFN',
+                 'support.TESTFN', 'locale'
                 )
 
     def get_sys_argv(self):
@@ -1230,6 +1231,14 @@ class saved_test_environment:
             elif os.path.isdir(support.TESTFN):
                 shutil.rmtree(support.TESTFN)
 
+    _locale_categories = [getattr(locale, lc)
+                          for lc in dir(locale) if lc.startswith('LC_')]
+    def get_locale(self):
+        return tuple(map(locale.getlocale, self._locale_categories))
+    def restore_locale(self, saved):
+        for category, setting in zip(self._locale_categories, saved):
+            locale.setlocale(category, setting)
+
     def resource_info(self):
         for name in self.resources:
             method_suffix = name.replace('.', '_')