diff options
author | Éric Araujo <merwok@netwok.org> | 2010-10-04 23:57:46 (GMT) |
---|---|---|
committer | Éric Araujo <merwok@netwok.org> | 2010-10-04 23:57:46 (GMT) |
commit | 298be5161f27006a82bf499fcd7a990cb5ee4a87 (patch) | |
tree | 6c262cb543dd39ce972d12e19f0f17e45c32f67a | |
parent | 2fdbfc507e0a2e2b92415bf5a25090a6839ae799 (diff) | |
download | cpython-298be5161f27006a82bf499fcd7a990cb5ee4a87.zip cpython-298be5161f27006a82bf499fcd7a990cb5ee4a87.tar.gz cpython-298be5161f27006a82bf499fcd7a990cb5ee4a87.tar.bz2 |
Merged revisions 85223 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
........
r85223 | eric.araujo | 2010-10-05 01:52:37 +0200 (mar., 05 oct. 2010) | 3 lines
Fix interaction of custom translation classes and caching (#9042)
........
-rw-r--r-- | Lib/gettext.py | 2 | ||||
-rw-r--r-- | Lib/test/test_gettext.py | 31 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 35 insertions, 1 deletions
diff --git a/Lib/gettext.py b/Lib/gettext.py index 4c957c0..f9392d8 100644 --- a/Lib/gettext.py +++ b/Lib/gettext.py @@ -419,7 +419,7 @@ def translation(domain, localedir=None, languages=None, # once. result = None for mofile in mofiles: - key = os.path.abspath(mofile) + key = (class_, os.path.abspath(mofile)) t = _translations.get(key) if t is None: with open(mofile, 'rb') as fp: diff --git a/Lib/test/test_gettext.py b/Lib/test/test_gettext.py index d667819..69ffcb7 100644 --- a/Lib/test/test_gettext.py +++ b/Lib/test/test_gettext.py @@ -335,6 +335,37 @@ class WeirdMetadataTest(GettextBaseTest): 'John Doe <jdoe@example.com>\nJane Foobar <jfoobar@example.com>') +class DummyGNUTranslations(gettext.GNUTranslations): + def foo(self): + return 'foo' + + +class GettextCacheTestCase(GettextBaseTest): + def test_cache(self): + self.localedir = os.curdir + self.mofile = MOFILE + + self.assertEqual(len(gettext._translations), 0) + + t = gettext.translation('gettext', self.localedir) + + self.assertEqual(len(gettext._translations), 1) + + t = gettext.translation('gettext', self.localedir, + class_=DummyGNUTranslations) + + self.assertEqual(len(gettext._translations), 2) + self.assertEqual(t.__class__, DummyGNUTranslations) + + # Calling it again doesn't add to the cache + + t = gettext.translation('gettext', self.localedir, + class_=DummyGNUTranslations) + + self.assertEqual(len(gettext._translations), 2) + self.assertEqual(t.__class__, DummyGNUTranslations) + + def test_main(): support.run_unittest(__name__) @@ -124,6 +124,9 @@ C-API Library ------- +- Issue #9042: Fix interaction of custom translation classes and caching in + gettext. + - Issue #9065: tarfile no longer uses "root" as the default for the uname and gname field. |