Commit daffcc78 authored by Tres Seaver's avatar Tres Seaver

Forward port fix for Launchpad #229549 from the 2.10 branch.

parent 2e75a35b
...@@ -14,6 +14,9 @@ Zope Changes ...@@ -14,6 +14,9 @@ Zope Changes
Bugs Fixed Bugs Fixed
- Launchpad #229549: Don't ignore 'debug' flag when rendering
page templates (thanks to Eric Steele for the patch).
- Fixed against-the-rules zope.conf option 'fast_listen' to read - Fixed against-the-rules zope.conf option 'fast_listen' to read
'fast-listen' (dash, not underscore). 'fast-listen' (dash, not underscore).
......
...@@ -86,7 +86,15 @@ class PageTemplate(ExtensionClass.Base, ...@@ -86,7 +86,15 @@ class PageTemplate(ExtensionClass.Base,
def pt_render(self, source=False, extra_context={}): def pt_render(self, source=False, extra_context={}):
c = self.pt_getContext() c = self.pt_getContext()
c.update(extra_context) c.update(extra_context)
return super(PageTemplate, self).pt_render(c, source=source) debug = getattr(c['request'], 'debug', None)
if debug is not None:
showtal = getattr(debug, 'showTAL', False)
sourceAnnotations = getattr(debug, 'sourceAnnotations', False)
else:
showtal = sourceAnnotations = False
return super(PageTemplate, self).pt_render(c, source=source, sourceAnnotations=sourceAnnotations,
showtal=showtal)
def pt_errors(self, namespace={}): def pt_errors(self, namespace={}):
self._cook_check() self._cook_check()
......
...@@ -152,6 +152,20 @@ class ZPTUnicodeEncodingConflictResolution(ZopeTestCase): ...@@ -152,6 +152,20 @@ class ZPTUnicodeEncodingConflictResolution(ZopeTestCase):
state = cPickle.dumps(empty, protocol=1) state = cPickle.dumps(empty, protocol=1)
clone = cPickle.loads(state) clone = cPickle.loads(state)
def testDebugFlags(self):
# Test for bug 229549
manage_addPageTemplate(self.app, 'test',
text='<div tal:content="string:foo">bar</div>',
encoding='ascii')
zpt = self.app['test']
from zope.publisher.base import DebugFlags
self.app.REQUEST.debug = DebugFlags()
self.assertEqual(zpt.pt_render(), unicode('<div>foo</div>\n'))
self.app.REQUEST.debug.showTAL = True
self.assertEqual(zpt.pt_render(), unicode('<div tal:content="string:foo">foo</div>\n'))
self.app.REQUEST.debug.sourceAnnotations = True
self.assertEqual(zpt.pt_render().startswith(unicode('<!--')), True)
class ZopePageTemplateFileTests(ZopeTestCase): class ZopePageTemplateFileTests(ZopeTestCase):
def testPT_RenderWithAscii(self): def testPT_RenderWithAscii(self):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment