summaryrefslogtreecommitdiffstats
path: root/tests/test_ipalib/test_request.py
diff options
context:
space:
mode:
authorJason Gerard DeRose <jderose@redhat.com>2008-12-18 16:58:48 -0700
committerJason Gerard DeRose <jderose@redhat.com>2008-12-18 16:58:48 -0700
commit9a69adeef001ddd0c55513271cf02eedc0a9aef8 (patch)
treeea9ad448f6a82418f2e809242dd8c03fdecb9cf6 /tests/test_ipalib/test_request.py
parentdc54dee622bf9ff95a59530423ac5caa01868373 (diff)
downloadfreeipa-9a69adeef001ddd0c55513271cf02eedc0a9aef8.tar.gz
freeipa-9a69adeef001ddd0c55513271cf02eedc0a9aef8.tar.xz
freeipa-9a69adeef001ddd0c55513271cf02eedc0a9aef8.zip
Added request.create_translation() function and corresponding unit tests
Diffstat (limited to 'tests/test_ipalib/test_request.py')
-rw-r--r--tests/test_ipalib/test_request.py45
1 files changed, 44 insertions, 1 deletions
diff --git a/tests/test_ipalib/test_request.py b/tests/test_ipalib/test_request.py
index 7ccf9b828..1b9c9e3d2 100644
--- a/tests/test_ipalib/test_request.py
+++ b/tests/test_ipalib/test_request.py
@@ -21,8 +21,9 @@
Test the `ipalib.request` module.
"""
+import threading
import locale
-from tests.util import raises
+from tests.util import raises, TempDir
from ipalib.constants import OVERRIDE_ERROR
from ipalib import request
@@ -54,3 +55,45 @@ def test_set_languages():
assert c.languages == locale.getdefaultlocale()[:1]
del c.languages
assert not hasattr(c, 'languages')
+
+
+def test_create_translation():
+ """
+ Test the `ipalib.request.create_translation` function.
+ """
+ f = request.create_translation
+ c = request.context
+ t = TempDir()
+
+ # Test that StandardError is raised if gettext or ngettext:
+ assert not (hasattr(c, 'gettext') or hasattr(c, 'ngettext'))
+ for name in 'gettext', 'ngettext':
+ setattr(c, name, None)
+ e = raises(StandardError, f, 'ipa', None)
+ assert str(e) == (
+ 'create_translation() already called in thread %r' %
+ threading.currentThread().getName()
+ )
+ delattr(c, name)
+
+ # Test using default language:
+ assert not hasattr(c, 'gettext')
+ assert not hasattr(c, 'ngettext')
+ assert not hasattr(c, 'languages')
+ f('ipa', t.path)
+ assert hasattr(c, 'gettext')
+ assert hasattr(c, 'ngettext')
+ assert c.languages == locale.getdefaultlocale()[:1]
+ del c.gettext
+ del c.ngettext
+ del c.languages
+
+ # Test using explicit languages:
+ langs = ('de', 'es')
+ f('ipa', t.path, *langs)
+ assert hasattr(c, 'gettext')
+ assert hasattr(c, 'ngettext')
+ assert c.languages == langs
+ del c.gettext
+ del c.ngettext
+ del c.languages