Commit ee13d242 authored by Andreas Jung's avatar Andreas Jung

- Collector #1991: ZPublisher did not deal properly with a trailing

        %20 in the URL
parent afc0b6dc
......@@ -18,6 +18,9 @@ Zope Changes
Bugs fixed
- Collector #1991: ZPublisher did not deal properly with a trailing
%20 in the URL
- Collector #1989: 'test.py' now copyied to $ZOPE_HOME/bin
during installation, which re-enables tests run from the instance
home.
......
......@@ -93,8 +93,9 @@ def publish(request, module_name, after_list, debug=0,
if bobo_before is not None:
bobo_before()
# Get a nice clean path list:
path=request_get('PATH_INFO').strip()
# Get the path list.
# According to RFC1738 a trailing space in the path is valid.
path=request_get('PATH_INFO')
request['PARENTS']=parents=[object]
......
......@@ -266,6 +266,65 @@ def testPublisher():
"""
pass
class ObjectNotFound:
"""Mock object for traversing to.
"""
def __call__(self):
tracer.append('ObjectNotFound')
return 'ObjectNotFound'
class PathRequest(Request):
def __init__(self, path):
self.PATH_INFO = path
Request.__init__(self)
def get(self, a, b=''):
if a == 'PATH_INFO':
return self.PATH_INFO
else:
return ''
def traverse(self, path, validated_hook):
if path == self.PATH_INFO:
return Object()
else:
return ObjectNotFound()
def testPublishPath():
"""
Tests to ensure that publish passes paths through to the request without
stripping spaces (as this can lead to google indexing pages with a trailing
space when someone has a typo in an href to you're site). Zope bug #1991.
>>> from ZPublisher.Publish import publish
Without the trailing space, should work normally
>>> tracer.reset()
>>> request = PathRequest('/foo')
>>> response = publish(request, module_name, after_list)
>>> tracer.showTracedPath()
begin
__call__
commit
Now with a trailing space, should also work normally, but in zope 2.9.0
and earlier publish did a strip() on the path so instead of __call__ you
an ObjectNotFound in the trace.
>>> tracer.reset()
>>> request = PathRequest('/foo ')
>>> response = publish(request, module_name, after_list)
>>> tracer.showTracedPath()
begin
__call__
commit
"""
pass
from zope.testing import doctest
......
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