summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_gettext.py
diff options
context:
space:
mode:
authorMartin v. Löwis <martin@v.loewis.de>2002-11-21 21:45:32 (GMT)
committerMartin v. Löwis <martin@v.loewis.de>2002-11-21 21:45:32 (GMT)
commitd899605e30eef8e77f70184eac15fad1bf770586 (patch)
treec82d9d42d30135449d87fa7f761827bb4154c5f3 /Lib/test/test_gettext.py
parent21b60147e9d4e6c895b581429d292cb60bcdb5e7 (diff)
downloadcpython-d899605e30eef8e77f70184eac15fad1bf770586.zip
cpython-d899605e30eef8e77f70184eac15fad1bf770586.tar.gz
cpython-d899605e30eef8e77f70184eac15fad1bf770586.tar.bz2
Patch #633547: Support plural forms. Do TODOs in test suite.
Diffstat (limited to 'Lib/test/test_gettext.py')
-rw-r--r--Lib/test/test_gettext.py359
1 files changed, 248 insertions, 111 deletions
diff --git a/Lib/test/test_gettext.py b/Lib/test/test_gettext.py
index 08787d0..2a1f24c 100644
--- a/Lib/test/test_gettext.py
+++ b/Lib/test/test_gettext.py
@@ -2,154 +2,283 @@ import os
import base64
import gettext
+import unittest
+from unittest import TestCase
-def test_api_1(localedir, mofile):
- print 'test api 1'
+# TODO:
+# - Add new tests, for example for "dgettext"
+# - Remove dummy tests, for example testing for single and double quotes
+# has no sense, it would have if we were testing a parser (i.e. pygettext)
+# - Tests should have only one assert.
- # Test basic interface
- print 'installing gettext'
- gettext.install('gettext', localedir)
+GNU_MO_DATA = '''\
+3hIElQAAAAAGAAAAHAAAAEwAAAALAAAAfAAAAAAAAACoAAAAFQAAAKkAAAAjAAAAvwAAAKEAAADj
+AAAABwAAAIUBAAALAAAAjQEAAEUBAACZAQAAFgAAAN8CAAAeAAAA9gIAAKEAAAAVAwAABQAAALcD
+AAAJAAAAvQMAAAEAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAABQAAAAYAAAACAAAAAFJh
+eW1vbmQgTHV4dXJ5IFlhY2gtdABUaGVyZSBpcyAlcyBmaWxlAFRoZXJlIGFyZSAlcyBmaWxlcwBU
+aGlzIG1vZHVsZSBwcm92aWRlcyBpbnRlcm5hdGlvbmFsaXphdGlvbiBhbmQgbG9jYWxpemF0aW9u
+CnN1cHBvcnQgZm9yIHlvdXIgUHl0aG9uIHByb2dyYW1zIGJ5IHByb3ZpZGluZyBhbiBpbnRlcmZh
+Y2UgdG8gdGhlIEdOVQpnZXR0ZXh0IG1lc3NhZ2UgY2F0YWxvZyBsaWJyYXJ5LgBtdWxsdXNrAG51
+ZGdlIG51ZGdlAFByb2plY3QtSWQtVmVyc2lvbjogMi4wClBPLVJldmlzaW9uLURhdGU6IDIwMDAt
+MDgtMjkgMTI6MTktMDQ6MDAKTGFzdC1UcmFuc2xhdG9yOiBKLiBEYXZpZCBJYsOhw7FleiA8ai1k
+YXZpZEBub29zLmZyPgpMYW5ndWFnZS1UZWFtOiBYWCA8cHl0aG9uLWRldkBweXRob24ub3JnPgpN
+SU1FLVZlcnNpb246IDEuMApDb250ZW50LVR5cGU6IHRleHQvcGxhaW47IGNoYXJzZXQ9aXNvLTg4
+NTktMQpDb250ZW50LVRyYW5zZmVyLUVuY29kaW5nOiBub25lCkdlbmVyYXRlZC1CeTogcHlnZXR0
+ZXh0LnB5IDEuMQpQbHVyYWwtRm9ybXM6IG5wbHVyYWxzPTI7IHBsdXJhbD1uIT0xOwoAVGhyb2F0
+d29iYmxlciBNYW5ncm92ZQBIYXkgJXMgZmljaGVybwBIYXkgJXMgZmljaGVyb3MAR3V2ZiB6YnFo
+eXIgY2ViaXZxcmYgdmFncmVhbmd2YmFueXZtbmd2YmEgbmFxIHlicG55dm1uZ3ZiYQpmaGNjYmVn
+IHNiZSBsYmhlIENsZ3ViYSBjZWJ0ZW56ZiBvbCBjZWJpdnF2YXQgbmEgdmFncmVzbnByIGdiIGd1
+ciBUQUgKdHJnZ3JrZyB6cmZmbnRyIHBuZ255YnQgeXZvZW5lbC4AYmFjb24Ad2luayB3aW5rAA==
+'''
+
+
+LOCALEDIR = os.path.join('xx', 'LC_MESSAGES')
+MOFILE = os.path.join(LOCALEDIR, 'gettext.mo')
+
+def setup():
+ os.makedirs(LOCALEDIR)
+ fp = open(MOFILE, 'wb')
+ fp.write(base64.decodestring(GNU_MO_DATA))
+ fp.close()
+ os.environ['LANGUAGE'] = 'xx'
+
+def teardown():
+ os.environ['LANGUAGE'] = 'en'
+ os.unlink(MOFILE)
+ os.removedirs(LOCALEDIR)
+
- # test some translations
- print _('albatross')
- print _(u'mullusk')
- print _(r'Raymond Luxury Yach-t')
- print _(ur'nudge nudge')
+class GettextTestCase1(TestCase):
+ def setUp(self):
+ self.localedir = os.curdir
+ self.mofile = MOFILE
- # double quotes
- print _("albatross")
- print _(u"mullusk")
- print _(r"Raymond Luxury Yach-t")
- print _(ur"nudge nudge")
+ gettext.install('gettext', self.localedir)
- # triple single quotes
- print _('''albatross''')
- print _(u'''mullusk''')
- print _(r'''Raymond Luxury Yach-t''')
- print _(ur'''nudge nudge''')
- # triple double quotes
- print _("""albatross""")
- print _(u"""mullusk""")
- print _(r"""Raymond Luxury Yach-t""")
- print _(ur"""nudge nudge""")
+ def test_some_translations(self):
+ # test some translations
+ assert _('albatross') == 'albatross'
+ assert _(u'mullusk') == 'bacon'
+ assert _(r'Raymond Luxury Yach-t') == 'Throatwobbler Mangrove'
+ assert _(ur'nudge nudge') == 'wink wink'
- # multiline strings
- print _('''This module provides internationalization and localization
+
+ def test_double_quotes(self):
+ # double quotes
+ assert _("albatross") == 'albatross'
+ assert _(u"mullusk") == 'bacon'
+ assert _(r"Raymond Luxury Yach-t") == 'Throatwobbler Mangrove'
+ assert _(ur"nudge nudge") == 'wink wink'
+
+
+ def test_triple_single_quotes(self):
+ # triple single quotes
+ assert _('''albatross''') == 'albatross'
+ assert _(u'''mullusk''') == 'bacon'
+ assert _(r'''Raymond Luxury Yach-t''') == 'Throatwobbler Mangrove'
+ assert _(ur'''nudge nudge''') == 'wink wink'
+
+
+ def test_triple_double_quotes(self):
+ # triple double quotes
+ assert _("""albatross""") == 'albatross'
+ assert _(u"""mullusk""") == 'bacon'
+ assert _(r"""Raymond Luxury Yach-t""") == 'Throatwobbler Mangrove'
+ assert _(ur"""nudge nudge""") == 'wink wink'
+
+
+ def test_multiline_strings(self):
+ # multiline strings
+ assert _('''This module provides internationalization and localization
support for your Python programs by providing an interface to the GNU
-gettext message catalog library.''')
+gettext message catalog library.''') == '''Guvf zbqhyr cebivqrf vagreangvbanyvmngvba naq ybpnyvmngvba
+fhccbeg sbe lbhe Clguba cebtenzf ol cebivqvat na vagresnpr gb gur TAH
+trggrkg zrffntr pngnybt yvoenel.'''
- # test the alternative interface
- fp = open(os.path.join(mofile), 'rb')
- t = gettext.GNUTranslations(fp)
- fp.close()
- t.install()
+ def test_the_alternative_interface(self):
+ # test the alternative interface
+ fp = open(os.path.join(self.mofile), 'rb')
+ t = gettext.GNUTranslations(fp)
+ fp.close()
+
+ t.install()
+
+ assert _('nudge nudge') == 'wink wink'
- print _('nudge nudge')
+ # try unicode return type
+ t.install(unicode=1)
- # try unicode return type
- t.install(unicode=1)
+ assert _('mullusk') == 'bacon'
- print _('mullusk')
+class GettextTestCase2(TestCase):
+ def setUp(self):
+ self.localedir = os.curdir
+ gettext.bindtextdomain('gettext', self.localedir)
+ gettext.textdomain('gettext')
-def test_api_2(localedir, mofile):
- print 'test api 2'
+ self._ = gettext.gettext
- gettext.bindtextdomain('gettext', localedir)
- print gettext.bindtextdomain('gettext') == localedir
- gettext.textdomain('gettext')
- # should return 'gettext'
- print gettext.textdomain()
+ def test_bindtextdomain(self):
+ assert gettext.bindtextdomain('gettext') == self.localedir
- # local function override builtin
- _ = gettext.gettext
- # test some translations
- print _('albatross')
- print _(u'mullusk')
- print _(r'Raymond Luxury Yach-t')
- print _(ur'nudge nudge')
+ def test_textdomain(self):
+ assert gettext.textdomain() == 'gettext'
- # double quotes
- print _("albatross")
- print _(u"mullusk")
- print _(r"Raymond Luxury Yach-t")
- print _(ur"nudge nudge")
- # triple single quotes
- print _('''albatross''')
- print _(u'''mullusk''')
- print _(r'''Raymond Luxury Yach-t''')
- print _(ur'''nudge nudge''')
+ def test_some_translations(self):
+ # test some translations
+ assert self._('albatross') == 'albatross'
+ assert self._(u'mullusk') == 'bacon'
+ assert self._(r'Raymond Luxury Yach-t') == 'Throatwobbler Mangrove'
+ assert self._(ur'nudge nudge') == 'wink wink'
- # triple double quotes
- print _("""albatross""")
- print _(u"""mullusk""")
- print _(r"""Raymond Luxury Yach-t""")
- print _(ur"""nudge nudge""")
- # multiline strings
- print _('''This module provides internationalization and localization
+ def test_double_quotes(self):
+ # double quotes
+ assert self._("albatross") == 'albatross'
+ assert self._(u"mullusk") == 'bacon'
+ assert self._(r"Raymond Luxury Yach-t") == 'Throatwobbler Mangrove'
+ assert self._(ur"nudge nudge") == 'wink wink'
+
+
+ def test_triple_single_quotes(self):
+ # triple single quotes
+ assert self._('''albatross''') == 'albatross'
+ assert self._(u'''mullusk''') == 'bacon'
+ assert self._(r'''Raymond Luxury Yach-t''') == 'Throatwobbler Mangrove'
+ assert self._(ur'''nudge nudge''') == 'wink wink'
+
+
+ def test_triple_double_quotes(self):
+ # triple double quotes
+ assert self._("""albatross""") == 'albatross'
+ assert self._(u"""mullusk""") == 'bacon'
+ assert self._(r"""Raymond Luxury Yach-t""") == 'Throatwobbler Mangrove'
+ assert self._(ur"""nudge nudge""") == 'wink wink'
+
+
+ def test_multiline_strings(self):
+ # multiline strings
+ assert self._('''This module provides internationalization and localization
support for your Python programs by providing an interface to the GNU
-gettext message catalog library.''')
+gettext message catalog library.''') == '''Guvf zbqhyr cebivqrf vagreangvbanyvmngvba naq ybpnyvmngvba
+fhccbeg sbe lbhe Clguba cebtenzf ol cebivqvat na vagresnpr gb gur TAH
+trggrkg zrffntr pngnybt yvoenel.'''
- # Now test dgettext()
- def _(message):
- return gettext.dgettext('gettext')
-GNU_MO_DATA = '''\
-3hIElQAAAAAFAAAAHAAAAEQAAAAHAAAAbAAAAAAAAACIAAAAFQAAAIkAAAChAAAAnwAAAAcAAABB
-AQAACwAAAEkBAAAZAQAAVQEAABYAAABvAgAAoQAAAIYCAAAFAAAAKAMAAAkAAAAuAwAAAQAAAAQA
-AAACAAAAAAAAAAUAAAAAAAAAAwAAAABSYXltb25kIEx1eHVyeSBZYWNoLXQAVGhpcyBtb2R1bGUg
-cHJvdmlkZXMgaW50ZXJuYXRpb25hbGl6YXRpb24gYW5kIGxvY2FsaXphdGlvbgpzdXBwb3J0IGZv
-ciB5b3VyIFB5dGhvbiBwcm9ncmFtcyBieSBwcm92aWRpbmcgYW4gaW50ZXJmYWNlIHRvIHRoZSBH
-TlUKZ2V0dGV4dCBtZXNzYWdlIGNhdGFsb2cgbGlicmFyeS4AbXVsbHVzawBudWRnZSBudWRnZQBQ
-cm9qZWN0LUlkLVZlcnNpb246IDIuMApQTy1SZXZpc2lvbi1EYXRlOiAyMDAwLTA4LTI5IDEyOjE5
-LTA0OjAwCkxhc3QtVHJhbnNsYXRvcjogQmFycnkgQS4gV2Fyc2F3IDxiYXJyeUBweXRob24ub3Jn
-PgpMYW5ndWFnZS1UZWFtOiBYWCA8cHl0aG9uLWRldkBweXRob24ub3JnPgpNSU1FLVZlcnNpb246
-IDEuMApDb250ZW50LVR5cGU6IHRleHQvcGxhaW47IGNoYXJzZXQ9a29pOF9yCkNvbnRlbnQtVHJh
-bnNmZXItRW5jb2Rpbmc6IG5vbmUKR2VuZXJhdGVkLUJ5OiBweWdldHRleHQucHkgMS4xCgBUaHJv
-YXR3b2JibGVyIE1hbmdyb3ZlAEd1dmYgemJxaHlyIGNlYml2cXJmIHZhZ3JlYW5ndmJhbnl2bW5n
-dmJhIG5hcSB5YnBueXZtbmd2YmEKZmhjY2JlZyBzYmUgbGJoZSBDbGd1YmEgY2VidGVuemYgb2wg
-Y2ViaXZxdmF0IG5hIHZhZ3Jlc25wciBnYiBndXIgVEFICnRyZ2dya2cgenJmZm50ciBwbmdueWJ0
-IHl2b2VuZWwuAGJhY29uAHdpbmsgd2luawA=
-'''
+class PluralFormsTestCase(TestCase):
+ def setUp(self):
+ self.mofile = MOFILE
+ def test_plural_forms1(self):
+ x = gettext.ngettext('There is %s file', 'There are %s files', 1)
+ assert x == 'Hay %s fichero'
-LOCALEDIR = os.path.join('xx', 'LC_MESSAGES')
-MOFILE = os.path.join(LOCALEDIR, 'gettext.mo')
+ x = gettext.ngettext('There is %s file', 'There are %s files', 2)
+ assert x == 'Hay %s ficheros'
-def setup():
- os.makedirs(LOCALEDIR)
- fp = open(MOFILE, 'wb')
- fp.write(base64.decodestring(GNU_MO_DATA))
- fp.close()
- os.environ['LANGUAGE'] = 'xx'
-def teardown():
- os.environ['LANGUAGE'] = 'en'
- os.unlink(MOFILE)
- os.removedirs(LOCALEDIR)
+ def test_plural_forms2(self):
+ fp = open(os.path.join(self.mofile), 'rb')
+ t = gettext.GNUTranslations(fp)
+ fp.close()
+
+ x = t.ngettext('There is %s file', 'There are %s files', 1)
+ assert x == 'Hay %s fichero'
+
+ x = t.ngettext('There is %s file', 'There are %s files', 2)
+ assert x == 'Hay %s ficheros'
+
+
+ def test_hu(self):
+ f = gettext.c2py('0')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000"
+
+
+ def test_de(self):
+ f = gettext.c2py('n != 1')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "10111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"
+
+
+ def test_fr(self):
+ f = gettext.c2py('n>1')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "00111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"
-try:
- setup()
- test_api_1(os.curdir, MOFILE)
- test_api_2(os.curdir, MOFILE)
-finally:
- teardown()
- pass
+ def test_gd(self):
+ f = gettext.c2py('n==1 ? 0 : n==2 ? 1 : 2')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "20122222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222"
+
+
+ def test_gd2(self):
+ # Tests the combination of parentheses and "?:"
+ f = gettext.c2py('n==1 ? 0 : (n==2 ? 1 : 2)')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "20122222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222"
+
+
+ def test_lt(self):
+ f = gettext.c2py('n%10==1 && n%100!=11 ? 0 : n%10>=2 && (n%100<10 || n%100>=20) ? 1 : 2')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "20111111112222222222201111111120111111112011111111201111111120111111112011111111201111111120111111112011111111222222222220111111112011111111201111111120111111112011111111201111111120111111112011111111"
+
+
+ def test_ru(self):
+ f = gettext.c2py('n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "20111222222222222222201112222220111222222011122222201112222220111222222011122222201112222220111222222011122222222222222220111222222011122222201112222220111222222011122222201112222220111222222011122222"
+
+
+ def test_pl(self):
+ f = gettext.c2py('n==1 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "20111222222222222222221112222222111222222211122222221112222222111222222211122222221112222222111222222211122222222222222222111222222211122222221112222222111222222211122222221112222222111222222211122222"
+
+
+ def test_sl(self):
+ f = gettext.c2py('n%100==1 ? 0 : n%100==2 ? 1 : n%100==3 || n%100==4 ? 2 : 3')
+ s = ''.join([ str(f(x)) for x in range(200) ])
+ assert s == "30122333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333012233333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333"
+
+
+ def test_security(self):
+ # Test for a dangerous expression
+ try:
+ gettext.c2py("os.chmod('/etc/passwd',0777)")
+ except ValueError:
+ pass
+ else:
+ raise AssertionError
+
+
+
+if __name__ == '__main__':
+ try:
+ setup()
+ unittest.main()
+ finally:
+ teardown()
+
# For reference, here's the .po file used to created the .mo data above.
+#
+# The original version was automatically generated from the sources with
+# pygettext. Later it was manually modified to add plural forms support.
'''
# Dummy translation for Python's test_gettext.py module.
@@ -160,12 +289,13 @@ msgid ""
msgstr ""
"Project-Id-Version: 2.0\n"
"PO-Revision-Date: 2000-08-29 12:19-04:00\n"
-"Last-Translator: Barry A. Warsaw <barry@python.org>\n"
+"Last-Translator: J. David Ibanez <j-david@noos.fr>\n"
"Language-Team: XX <python-dev@python.org>\n"
"MIME-Version: 1.0\n"
-"Content-Type: text/plain; charset=koi8_r\n"
-"Content-Transfer-Encoding: none\n"
+"Content-Type: text/plain; charset=iso-8859-1\n"
+"Content-Transfer-Encoding: 8bit\n"
"Generated-By: pygettext.py 1.1\n"
+"Plural-Forms: nplurals=2; plural=n!=1;\n"
#: test_gettext.py:19 test_gettext.py:25 test_gettext.py:31 test_gettext.py:37
#: test_gettext.py:51 test_gettext.py:80 test_gettext.py:86 test_gettext.py:92
@@ -198,4 +328,11 @@ msgstr ""
"Guvf zbqhyr cebivqrf vagreangvbanyvmngvba naq ybpnyvmngvba\n"
"fhccbeg sbe lbhe Clguba cebtenzf ol cebivqvat na vagresnpr gb gur TAH\n"
"trggrkg zrffntr pngnybt yvoenel."
+
+# Manually added, as neither pygettext nor xgettext support plural forms
+# in Python.
+msgid "There is %s file"
+msgid_plural "There are %s files"
+msgstr[0] "Hay %s fichero"
+msgstr[1] "Hay %s ficheros"
'''