[Zope-Checkins] CVS: Zope3/lib/python/Zope/TAL/tests - test_htmltalparser.py:1.25.14.2.6.1 test_talinterpreter.py:1.3.14.1.8.1

Fred L. Drake, Jr. fdrake@acm.org
Wed, 20 Mar 2002 18:36:31 -0500


Update of /cvs-repository/Zope3/lib/python/Zope/TAL/tests
In directory cvs.zope.org:/tmp/cvs-serv20026/tests

Modified Files:
      Tag: fdrake-tal-i18n-branch
	test_htmltalparser.py test_talinterpreter.py 
Log Message:
Preliminary attempts to start the I18N support for TAL.
This initial checkin is not quite working yet, but we have come a long way.
(we = Fred & Stephen Richter)


=== Zope3/lib/python/Zope/TAL/tests/test_htmltalparser.py 1.25.14.2 => 1.25.14.2.6.1 ===
               'name': 'bar', 'href': 'foo'}),
             ('startTag', ('a',
-             [('href', 'foo', 0, '$string:http://www.zope.org$'),
+             [('href', 'foo', 0, '$string:http://www.zope.org$', 0),
               ('name', 'name="bar"'),
               ('tal:attributes',
                'href string:http://www.zope.org; x string:y', 3),
-              ('x', None, 1, '$string:y$')])),
+              ('x', None, 1, '$string:y$', 0)])),
             ('endScope', ()),
             rawtext('link</a>'),
             ])
@@ -403,12 +403,13 @@
             ('beginScope',
              {'tal:attributes': 'src string:foo.png',
               'tal:replace': 'structure string:<img>'}),
-            ('insertStructure', ('$string:<img>$',
-             {'src': '$string:foo.png$'},
-             [('startTag', ('p',
-               [('tal:replace', 'structure string:<img>', 3),
-                ('tal:attributes', 'src string:foo.png', 3)])),
-              rawtext('duh</p>')])),
+            ('insertStructure',
+             ('$string:<img>$',
+              {'src': ('$string:foo.png$', 0)},
+              [('startTag', ('p',
+                             [('tal:replace', 'structure string:<img>', 3),
+                              ('tal:attributes', 'src string:foo.png', 3)])),
+               rawtext('duh</p>')])),
             ('endScope', ()),
             ])
 
@@ -471,6 +472,18 @@
                            2*"<p metal:fill-slot='y' />" + "</html>", exc)
         self._should_error("<p metal:foobar='x' />", exc)
         self._should_error("<p metal:define-macro='x'>", exc)
+
+    #
+    #  I18N test cases
+    #
+
+    def check_i18n_attributes(self):
+        self._run_check("<img alt='foo' i18n:attributes='alt'>", [
+            ('setPosition', (1, 0)),
+            ('startTag', ('img',
+             [('alt', 'foo', 0, None, 1),
+              ('i18n:attributes', 'alt', 3)])),
+            ])
         
 
 def test_suite():


=== Zope3/lib/python/Zope/TAL/tests/test_talinterpreter.py 1.3.14.1 => 1.3.14.1.8.1 ===
 from StringIO import StringIO
 
-from Zope.TAL.TALDefs import METALError
+from Zope.TAL.TALDefs import METALError, I18NError
 from Zope.TAL.HTMLTALParser import HTMLTALParser
 from Zope.TAL.TALInterpreter import TALInterpreter
 from Zope.TAL.DummyEngine import DummyEngine
@@ -47,6 +47,29 @@
         self.macro[0] = ("version", "duh")
 
 
+class I18NErrorsTestCase(TestCaseBase):
+
+    def _check(self, src, msg):
+        try:
+            self._compile(src)
+        except I18NError:
+            pass
+        else:
+            self.fail(msg)
+
+    def check_id_with_replace(self):
+        self._check('<p i18n:id="foo" tal:replace="string:splat"></p>',
+                    "expected i18n:id with tal:replace to be denied")
+
+    def check_missing_values(self):
+        self._check('<p i18n:attributes=""></p>',
+                    "missing i18n:attributes value not caught")
+        self._check('<p i18n:data=""></p>',
+                    "missing i18n:data value not caught")
+        self._check('<p i18n:id=""></p>',
+                    "missing i18n:id value not caught")
+
+
 class OutputPresentationTestCase(TestCaseBase):
 
     def check_attribute_wrapping(self):
@@ -71,6 +94,7 @@
 
 def test_suite():
     suite = unittest.TestSuite()
+    suite.addTest(unittest.makeSuite(I18NErrorsTestCase, "check_"))
     suite.addTest(unittest.makeSuite(MacroErrorsTestCase, "check_"))
     suite.addTest(unittest.makeSuite(OutputPresentationTestCase, "check_"))
     return suite