annotate genshi/filters/tests/i18n.py @ 500:0742f421caba experimental-inline

Merged revisions 487-603 via svnmerge from http://svn.edgewall.org/repos/genshi/trunk
author cmlenz
date Fri, 01 Jun 2007 17:21:47 +0000
parents
children 1837f39efd6f
rev   line source
500
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
1 # -*- coding: utf-8 -*-
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
2 #
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
3 # Copyright (C) 2007 Edgewall Software
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
4 # All rights reserved.
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
5 #
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
6 # This software is licensed as described in the file COPYING, which
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
7 # you should have received as part of this distribution. The terms
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
8 # are also available at http://genshi.edgewall.org/wiki/License.
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
9 #
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
10 # This software consists of voluntary contributions made by many
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
11 # individuals. For the exact contribution history, see the revision
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
12 # history and logs, available at http://genshi.edgewall.org/log/.
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
13
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
14 import doctest
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
15 from StringIO import StringIO
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
16 import unittest
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
17
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
18 from genshi.template import MarkupTemplate
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
19 from genshi.filters.i18n import Translator
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
20
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
21
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
22 class TranslatorTestCase(unittest.TestCase):
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
23
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
24 def test_extract_plural_form(self):
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
25 tmpl = MarkupTemplate("""<html xmlns:py="http://genshi.edgewall.org/">
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
26 ${ngettext("Singular", "Plural", num)}
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
27 </html>""")
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
28 translator = Translator()
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
29 messages = list(translator.extract(tmpl.stream))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
30 self.assertEqual(1, len(messages))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
31 self.assertEqual((2, 'ngettext', (u'Singular', u'Plural')), messages[0])
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
32
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
33 def test_extract_included_attribute_text(self):
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
34 tmpl = MarkupTemplate("""<html xmlns:py="http://genshi.edgewall.org/">
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
35 <span title="Foo"></span>
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
36 </html>""")
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
37 translator = Translator()
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
38 messages = list(translator.extract(tmpl.stream))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
39 self.assertEqual(1, len(messages))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
40 self.assertEqual((2, None, u'Foo'), messages[0])
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
41
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
42 def test_extract_attribute_expr(self):
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
43 tmpl = MarkupTemplate("""<html xmlns:py="http://genshi.edgewall.org/">
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
44 <input type="submit" value="${_('Save')}" />
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
45 </html>""")
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
46 translator = Translator()
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
47 messages = list(translator.extract(tmpl.stream))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
48 self.assertEqual(1, len(messages))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
49 self.assertEqual((2, '_', u'Save'), messages[0])
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
50
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
51 def test_extract_non_included_attribute_interpolated(self):
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
52 tmpl = MarkupTemplate("""<html xmlns:py="http://genshi.edgewall.org/">
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
53 <a href="#anchor_${num}">Foo</a>
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
54 </html>""")
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
55 translator = Translator()
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
56 messages = list(translator.extract(tmpl.stream))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
57 self.assertEqual(1, len(messages))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
58 self.assertEqual((2, None, u'Foo'), messages[0])
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
59
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
60 def test_extract_text_from_sub(self):
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
61 tmpl = MarkupTemplate("""<html xmlns:py="http://genshi.edgewall.org/">
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
62 <py:if test="foo">Foo</py:if>
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
63 </html>""")
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
64 translator = Translator()
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
65 messages = list(translator.extract(tmpl.stream))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
66 self.assertEqual(1, len(messages))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
67 self.assertEqual((2, None, u'Foo'), messages[0])
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
68
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
69
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
70 def suite():
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
71 suite = unittest.TestSuite()
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
72 suite.addTest(unittest.makeSuite(TranslatorTestCase, 'test'))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
73 suite.addTests(doctest.DocTestSuite(Translator.__module__))
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
74 return suite
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
75
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
76 if __name__ == '__main__':
0742f421caba Merged revisions 487-603 via svnmerge from
cmlenz
parents:
diff changeset
77 unittest.main(defaultTest='suite')
Copyright (C) 2012-2017 Edgewall Software