Commit c92eb929 authored by Hanno Schlichting's avatar Hanno Schlichting

Cleanup, avoid duplicated imports in tests for external dependencies.

parent 26370f24
import unittest import unittest
import Testing
import Zope2 import Zope2
import os import os
...@@ -286,16 +285,3 @@ class ImageTests(FileTests): ...@@ -286,16 +285,3 @@ class ImageTests(FileTests):
from OFS.interfaces import IWriteLock from OFS.interfaces import IWriteLock
verifyClass(IWriteLock, Image) verifyClass(IWriteLock, Image)
class ImagePublishTests(Testing.ZopeTestCase.FunctionalTestCase):
def testTagSafe(self):
self.app.manage_addImage("image", "")
res = self.publish(
"/image/tag?height=0&width=0&css_class=%22%3E%3Cscript%20type"
"%3D%22text%2Fjavascript%22%3Ealert('evil')%3B%3C%2Fscript"
"%3E%3Cdiv%20class%3D%22")
self.assertFalse(
'<script type="text/javascript">alert(\'evil\');</script>'
in res.getBody())
...@@ -54,14 +54,12 @@ def test_zpt_i18n(): ...@@ -54,14 +54,12 @@ def test_zpt_i18n():
``Accept-Language`` header which is processed by the ``Accept-Language`` header which is processed by the
``IUserPreferredLangauges`` adapter: ``IUserPreferredLangauges`` adapter:
>>> print http(r''' >>> print(http(r'''
... GET /test_folder_1_/testoid/@@i18n.html HTTP/1.1 ... GET /test_folder_1_/testoid/@@i18n.html HTTP/1.1
... Accept-Language: de ... Accept-Language: de
... ''') ... '''))
HTTP/1.1 200 OK HTTP/1.1 200 OK
... ...
<html>
<body>
<p>Dies ist eine Nachricht</p> <p>Dies ist eine Nachricht</p>
<p>Dies ist eine explizite Nachricht</p> <p>Dies ist eine explizite Nachricht</p>
<p>Dies sind 4 Nachrichten</p> <p>Dies sind 4 Nachrichten</p>
...@@ -72,8 +70,6 @@ def test_zpt_i18n(): ...@@ -72,8 +70,6 @@ def test_zpt_i18n():
</table> </table>
<p>Dies ist eine Nachricht</p> <p>Dies ist eine Nachricht</p>
<p>Dies ist eine Nachricht</p> <p>Dies ist eine Nachricht</p>
</body>
</html>
... ...
...@@ -86,5 +82,6 @@ def test_zpt_i18n(): ...@@ -86,5 +82,6 @@ def test_zpt_i18n():
def test_suite(): def test_suite():
from Testing.ZopeTestCase import FunctionalDocTestSuite from Testing.ZopeTestCase import FunctionalDocTestSuite
from doctest import ELLIPSIS import doctest
return FunctionalDocTestSuite(optionflags=ELLIPSIS) return FunctionalDocTestSuite(
optionflags=doctest.ELLIPSIS | doctest.NORMALIZE_WHITESPACE)
...@@ -70,10 +70,11 @@ Examples ...@@ -70,10 +70,11 @@ Examples
Test Publish Document Test Publish Document
>>> print http(r""" >>> print(http(r"""
... GET /test_folder_1_/index_html HTTP/1.1 ... GET /test_folder_1_/index_html HTTP/1.1
... """, handle_errors=False) ... """, handle_errors=False))
HTTP/1.1 200 OK HTTP/1.1 200 OK
...
Content-Length: 5 Content-Length: 5
Content-Type: text/plain; charset=... Content-Type: text/plain; charset=...
<BLANKLINE> <BLANKLINE>
...@@ -81,10 +82,11 @@ Test Publish Document ...@@ -81,10 +82,11 @@ Test Publish Document
Test parameter containing an additional '?' Test parameter containing an additional '?'
>>> print http(r""" >>> print(http(r"""
... GET /test_folder_1_?foo=bla%3Fbaz HTTP/1.1 ... GET /test_folder_1_?foo=bla%3Fbaz HTTP/1.1
... """) ... """))
HTTP/1.1 200 OK HTTP/1.1 200 OK
...
Content-Length: 5 Content-Length: 5
Content-Type: text/plain; charset=utf-8 Content-Type: text/plain; charset=utf-8
<BLANKLINE> <BLANKLINE>
...@@ -93,9 +95,9 @@ Test parameter containing an additional '?' ...@@ -93,9 +95,9 @@ Test parameter containing an additional '?'
Test Unauthorized Test Unauthorized
>>> self.folder.index_html.manage_permission('View', ['Owner']) >>> self.folder.index_html.manage_permission('View', ['Owner'])
>>> print http(r""" >>> print(http(r"""
... GET /test_folder_1_/index_html HTTP/1.1 ... GET /test_folder_1_/index_html HTTP/1.1
... """, handle_errors=True) ... """, handle_errors=True))
HTTP/1.1 401 Unauthorized HTTP/1.1 401 Unauthorized
... ...
Www-Authenticate: basic realm=... Www-Authenticate: basic realm=...
...@@ -105,11 +107,12 @@ Test Basic Authentication ...@@ -105,11 +107,12 @@ Test Basic Authentication
>>> from AccessControl.Permissions import manage_properties >>> from AccessControl.Permissions import manage_properties
>>> self.setPermissions([manage_properties]) >>> self.setPermissions([manage_properties])
>>> print http(r""" >>> print(http(r"""
... GET /test_folder_1_/index_html/change_title?title=Foo HTTP/1.1 ... GET /test_folder_1_/index_html/change_title?title=Foo HTTP/1.1
... Authorization: Basic %s ... Authorization: Basic %s
... """ % user_auth, handle_errors=False) ... """ % user_auth, handle_errors=False))
HTTP/1.1 200 OK HTTP/1.1 200 OK
...
Content-Length: 0 Content-Length: 0
... ...
...@@ -119,11 +122,12 @@ Test Basic Authentication ...@@ -119,11 +122,12 @@ Test Basic Authentication
Test passing in non-base64-encoded login/pass Test passing in non-base64-encoded login/pass
>>> from Testing.ZopeTestCase import user_name, user_password >>> from Testing.ZopeTestCase import user_name, user_password
>>> print http(r""" >>> print(http(r"""
... GET /test_folder_1_/index_html/change_title?title=Baz HTTP/1.1 ... GET /test_folder_1_/index_html/change_title?title=Baz HTTP/1.1
... Authorization: Basic %s:%s ... Authorization: Basic %s:%s
... """ % (user_name, user_password), handle_errors=False) ... """ % (user_name, user_password), handle_errors=False))
HTTP/1.1 200 OK HTTP/1.1 200 OK
...
Content-Length: 0 Content-Length: 0
... ...
...@@ -132,10 +136,11 @@ Test passing in non-base64-encoded login/pass ...@@ -132,10 +136,11 @@ Test passing in non-base64-encoded login/pass
Test setting cookies Test setting cookies
>>> print http(r""" >>> print(http(r"""
... GET /test_folder_1_/index_html/set_cookie HTTP/1.1 ... GET /test_folder_1_/index_html/set_cookie HTTP/1.1
... """, handle_errors=False) ... """, handle_errors=False))
HTTP/1.1 200 OK HTTP/1.1 200 OK
...
Content-Length: 0 Content-Length: 0
... ...
Set-Cookie: foo="Bar"; Path=/ Set-Cookie: foo="Bar"; Path=/
...@@ -143,11 +148,12 @@ Test setting cookies ...@@ -143,11 +148,12 @@ Test setting cookies
Test reading cookies Test reading cookies
>>> print http(r""" >>> print(http(r"""
... GET /test_folder_1_/index_html/show_cookies HTTP/1.1 ... GET /test_folder_1_/index_html/show_cookies HTTP/1.1
... Cookie: foo=bar; baz="oki doki" ... Cookie: foo=bar; baz="oki doki"
... """, handle_errors=False) ... """, handle_errors=False))
HTTP/1.1 200 OK HTTP/1.1 200 OK
...
Content-Length: 23 Content-Length: 23
Content-Type: text/plain; charset=... Content-Type: text/plain; charset=...
<BLANKLINE> <BLANKLINE>
......
...@@ -149,10 +149,11 @@ def http(request_string, handle_errors=True): ...@@ -149,10 +149,11 @@ def http(request_string, handle_errors=True):
instream = StringIO(request_string) instream = StringIO(request_string)
env = {"HTTP_HOST": 'localhost', env = {
"HTTP_REFERER": 'localhost', 'HTTP_HOST': 'localhost',
"REQUEST_METHOD": method, 'HTTP_REFERER': 'localhost',
"SERVER_PROTOCOL": protocol, 'REQUEST_METHOD': method,
'SERVER_PROTOCOL': protocol,
} }
p = path.split('?', 1) p = path.split('?', 1)
......
...@@ -96,10 +96,11 @@ SHOW_COOKIES_DTML = '''\ ...@@ -96,10 +96,11 @@ SHOW_COOKIES_DTML = '''\
def setUp(self): def setUp(self):
'''This method will run after the test_class' setUp. '''This method will run after the test_class' setUp.
>>> print http(r""" >>> print(http(r"""
... GET /test_folder_1_/index_html HTTP/1.1 ... GET /test_folder_1_/index_html HTTP/1.1
... """) ... """))
HTTP/1.1 200 OK HTTP/1.1 200 OK
...
Content-Length: 5 Content-Length: 5
Content-Type: text/plain; charset=... Content-Type: text/plain; charset=...
<BLANKLINE> <BLANKLINE>
......
...@@ -39,8 +39,8 @@ def doctest_cookies(): ...@@ -39,8 +39,8 @@ def doctest_cookies():
This response looks alright: This response looks alright:
>>> response = self.publish('/test_folder_1_/stub') >>> response = self.publish('/test_folder_1_/stub')
>>> print str(response) #doctest: +ELLIPSIS >>> print(str(response)) #doctest: +ELLIPSIS
Status: 200 OK HTTP/1.1 200 OK
... ...
Set-Cookie: evil="cookie" Set-Cookie: evil="cookie"
... ...
......
...@@ -25,15 +25,15 @@ import zlib ...@@ -25,15 +25,15 @@ import zlib
from zope.event import notify from zope.event import notify
from zExceptions import ( from zExceptions import (
BadRequest,
HTTPRedirection, HTTPRedirection,
InternalError,
NotFound,
Redirect, Redirect,
status_reasons, status_reasons,
Unauthorized, Unauthorized,
) )
from zExceptions.ExceptionFormatter import format_exception from zExceptions.ExceptionFormatter import format_exception
from ZPublisher import BadRequest
from ZPublisher import InternalError
from ZPublisher import NotFound
from ZPublisher.BaseResponse import BaseResponse from ZPublisher.BaseResponse import BaseResponse
from ZPublisher.pubevents import PubBeforeStreaming from ZPublisher.pubevents import PubBeforeStreaming
......
...@@ -363,7 +363,6 @@ def publish_module(environ, start_response, ...@@ -363,7 +363,6 @@ def publish_module(environ, start_response,
else: else:
# If somebody used response.write, that data will be in the # If somebody used response.write, that data will be in the
# stdout StringIO, so we put that before the body. # stdout StringIO, so we put that before the body.
# XXX This still needs verification that it really works.
result = (stdout.getvalue(), response.body) result = (stdout.getvalue(), response.body)
if not repoze_tm_active: if not repoze_tm_active:
...@@ -371,8 +370,8 @@ def publish_module(environ, start_response, ...@@ -371,8 +370,8 @@ def publish_module(environ, start_response,
stdout.close() stdout.close()
for callable in response.after_list: for func in response.after_list:
callable() func()
# Return the result body iterable. # Return the result body iterable.
return result return result
...@@ -12,8 +12,17 @@ ...@@ -12,8 +12,17 @@
############################################################################## ##############################################################################
from six import reraise from six import reraise
from zope.deferredimport import deprecated
from zExceptions import NotFound, BadRequest, InternalError, Forbidden # NOQA
# BBB Zope 5.0
deprecated(
'Please import from zExceptions.',
NotFound='zExceptions:NotFound',
BadRequest='zExceptions:BadRequest',
InternalError='zExceptions:InternalError',
Forbidden='zExceptions:Forbidden',
)
class Retry(Exception): class Retry(Exception):
......
import unittest import unittest
from zExceptions import NotFound
from zope.interface import implements from zope.interface import implements
from zope.publisher.interfaces import IPublishTraverse from zope.publisher.interfaces import IPublishTraverse
from zope.publisher.interfaces import NotFound as ztkNotFound from zope.publisher.interfaces import NotFound as ztkNotFound
...@@ -15,7 +16,7 @@ class DummyTraverser(object): ...@@ -15,7 +16,7 @@ class DummyTraverser(object):
raise ztkNotFound(self, name) raise ztkNotFound(self, name)
class BaseRequest_factory: class BaseRequest_factory(object):
def _makeOne(self, root): def _makeOne(self, root):
from Acquisition import Implicit from Acquisition import Implicit
...@@ -37,7 +38,6 @@ class BaseRequest_factory: ...@@ -37,7 +38,6 @@ class BaseRequest_factory:
self.base = str(base) self.base = str(base)
def notFoundError(self, name): def notFoundError(self, name):
from zExceptions import NotFound
raise NotFound(name) raise NotFound(name)
forbiddenError = notFoundError forbiddenError = notFoundError
...@@ -280,7 +280,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -280,7 +280,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
def test_traverse_withBDEmpty(self): def test_traverse_withBDEmpty(self):
# Collector 1079 (infinite loop 2) # Collector 1079 (infinite loop 2)
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder._setObject('objWithBD', self._makeObjectWithBD()) folder._setObject('objWithBD', self._makeObjectWithBD())
folder.objWithBD._default_path = [''] folder.objWithBD._default_path = ['']
...@@ -290,7 +289,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -290,7 +289,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
def test_traverse_withBBT_handles_AttributeError(self): def test_traverse_withBBT_handles_AttributeError(self):
# Test that if __bobo_traverse__ raises AttributeError # Test that if __bobo_traverse__ raises AttributeError
# that we get a NotFound # that we get a NotFound
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
def _faux___bobo_traverse__(REQUEST, name): def _faux___bobo_traverse__(REQUEST, name):
...@@ -331,7 +329,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -331,7 +329,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
# and __bobo_traverse__ # and __bobo_traverse__
# __bobo_traverse__ should raise an AttributeError, which will # __bobo_traverse__ should raise an AttributeError, which will
# raise a NotFound # raise a NotFound
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder._setObject('objWithBDBBT', self._makeObjectWithBDBBT()) folder._setObject('objWithBDBBT', self._makeObjectWithBDBBT())
folder.objWithBDBBT._default_path = ['xxx'] folder.objWithBDBBT._default_path = ['xxx']
...@@ -356,14 +353,12 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -356,14 +353,12 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
self.assertEqual(r.response.base, '') self.assertEqual(r.response.base, '')
def test_traverse_attribute_without_docstring(self): def test_traverse_attribute_without_docstring(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder._setObject('objBasic', self._makeBasicObject()) folder._setObject('objBasic', self._makeBasicObject())
r = self._makeOne(root) r = self._makeOne(root)
self.assertRaises(NotFound, r.traverse, 'folder/objBasic/noview') self.assertRaises(NotFound, r.traverse, 'folder/objBasic/noview')
def test_traverse_acquired_attribute_without_docstring(self): def test_traverse_acquired_attribute_without_docstring(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
root._setObject('objBasic', root._setObject('objBasic',
self._makeObjectWithEmptyDocstring()) self._makeObjectWithEmptyDocstring())
...@@ -371,7 +366,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -371,7 +366,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
self.assertRaises(NotFound, r.traverse, 'folder/objBasic') self.assertRaises(NotFound, r.traverse, 'folder/objBasic')
def test_traverse_class_without_docstring(self): def test_traverse_class_without_docstring(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder._setObject('objWithoutDocstring', folder._setObject('objWithoutDocstring',
self._makeObjectWithEmptyDocstring()) self._makeObjectWithEmptyDocstring())
...@@ -379,7 +373,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -379,7 +373,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
self.assertRaises(NotFound, r.traverse, 'folder/objWithoutDocstring') self.assertRaises(NotFound, r.traverse, 'folder/objWithoutDocstring')
def test_traverse_attribute_of_class_without_docstring(self): def test_traverse_attribute_of_class_without_docstring(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder._setObject('objWithoutDocstring', folder._setObject('objWithoutDocstring',
self._makeObjectWithEmptyDocstring()) self._makeObjectWithEmptyDocstring())
...@@ -388,7 +381,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -388,7 +381,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
'folder/objWithoutDocstring/view') 'folder/objWithoutDocstring/view')
def test_traverse_attribute_and_class_without_docstring(self): def test_traverse_attribute_and_class_without_docstring(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
r = self._makeOne(root) r = self._makeOne(root)
folder._setObject('objWithoutDocstring', folder._setObject('objWithoutDocstring',
...@@ -397,28 +389,24 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -397,28 +389,24 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
'folder/objWithoutDocstring/noview') 'folder/objWithoutDocstring/noview')
def test_traverse_simple_string(self): def test_traverse_simple_string(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder.simpleString = 'foo' folder.simpleString = 'foo'
r = self._makeOne(root) r = self._makeOne(root)
self.assertRaises(NotFound, r.traverse, 'folder/simpleString') self.assertRaises(NotFound, r.traverse, 'folder/simpleString')
def test_traverse_simple_list(self): def test_traverse_simple_list(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder.simpleList = [] folder.simpleList = []
r = self._makeOne(root) r = self._makeOne(root)
self.assertRaises(NotFound, r.traverse, 'folder/simpleList') self.assertRaises(NotFound, r.traverse, 'folder/simpleList')
def test_traverse_simple_boolean(self): def test_traverse_simple_boolean(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder.simpleBoolean = True folder.simpleBoolean = True
r = self._makeOne(root) r = self._makeOne(root)
self.assertRaises(NotFound, r.traverse, 'folder/simpleBoolean') self.assertRaises(NotFound, r.traverse, 'folder/simpleBoolean')
def test_traverse_simple_complex(self): def test_traverse_simple_complex(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder.simpleComplex = complex(1) folder.simpleComplex = complex(1)
folder.simpleString = 'foo' folder.simpleString = 'foo'
...@@ -426,14 +414,12 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -426,14 +414,12 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
self.assertRaises(NotFound, r.traverse, 'folder/simpleComplex') self.assertRaises(NotFound, r.traverse, 'folder/simpleComplex')
def test_traverse_simple_set(self): def test_traverse_simple_set(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder.simpleSet = set([]) folder.simpleSet = set([])
r = self._makeOne(root) r = self._makeOne(root)
self.assertRaises(NotFound, r.traverse, 'folder/simpleSet') self.assertRaises(NotFound, r.traverse, 'folder/simpleSet')
def test_traverse_simple_frozen_set(self): def test_traverse_simple_frozen_set(self):
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder.simpleFrozenSet = frozenset([]) folder.simpleFrozenSet = frozenset([])
r = self._makeOne(root) r = self._makeOne(root)
...@@ -470,7 +456,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -470,7 +456,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
def test_traverse_unsubscriptable(self): def test_traverse_unsubscriptable(self):
# See https://bugs.launchpad.net/bugs/213311 # See https://bugs.launchpad.net/bugs/213311
from ZPublisher import NotFound
r = self._makeOne(None) r = self._makeOne(None)
self.assertRaises(NotFound, r.traverse, 'not_found') self.assertRaises(NotFound, r.traverse, 'not_found')
...@@ -479,7 +464,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory): ...@@ -479,7 +464,6 @@ class TestBaseRequest(unittest.TestCase, BaseRequest_factory):
self.assertEqual(r.traverse('dummy'), 'dummy object') self.assertEqual(r.traverse('dummy'), 'dummy object')
def test_traverse_publishTraverse_error(self): def test_traverse_publishTraverse_error(self):
from ZPublisher import NotFound
r = self._makeOne(DummyTraverser()) r = self._makeOne(DummyTraverser())
self.assertRaises(NotFound, r.traverse, 'not_found') self.assertRaises(NotFound, r.traverse, 'not_found')
...@@ -715,7 +699,6 @@ class TestBaseRequestViews(TestRequestViewsBase): ...@@ -715,7 +699,6 @@ class TestBaseRequestViews(TestRequestViewsBase):
def test_traverse_view_attr_acquired(self): def test_traverse_view_attr_acquired(self):
# normal acquired attribute without view # normal acquired attribute without view
from ZPublisher import NotFound
root, folder = self._makeRootAndFolder() root, folder = self._makeRootAndFolder()
folder2 = root._setObject( folder2 = root._setObject(
'folder2', self._makeDummyObjectWithAttr('folder2')) 'folder2', self._makeDummyObjectWithAttr('folder2'))
......
import base64
from StringIO import StringIO
import sys import sys
import unittest import unittest
from zExceptions import NotFound
from zope.component import provideAdapter
from zope.i18n.interfaces import IUserPreferredLanguages
from zope.i18n.interfaces.locales import ILocale
from zope.publisher.browser import BrowserLanguages
from zope.publisher.interfaces.http import IHTTPRequest
from zope.testing.cleanup import cleanUp from zope.testing.cleanup import cleanUp
from ZPublisher.tests.testBaseRequest import TestRequestViewsBase from ZPublisher.tests.testBaseRequest import TestRequestViewsBase
...@@ -31,7 +39,6 @@ class HTTPRequestFactoryMixin(object): ...@@ -31,7 +39,6 @@ class HTTPRequestFactoryMixin(object):
return HTTPRequest return HTTPRequest
def _makeOne(self, stdin=None, environ=None, response=None, clean=1): def _makeOne(self, stdin=None, environ=None, response=None, clean=1):
from StringIO import StringIO
from ZPublisher.HTTPResponse import HTTPResponse from ZPublisher.HTTPResponse import HTTPResponse
if stdin is None: if stdin is None:
stdin = StringIO() stdin = StringIO()
...@@ -715,8 +722,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -715,8 +722,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
def test_close_removes_stdin_references(self): def test_close_removes_stdin_references(self):
# Verifies that all references to the input stream go away on # Verifies that all references to the input stream go away on
# request.close(). Otherwise a tempfile may stick around. # request.close(). Otherwise a tempfile may stick around.
import sys
from StringIO import StringIO
s = StringIO(TEST_FILE_DATA) s = StringIO(TEST_FILE_DATA)
start_count = sys.getrefcount(s) start_count = sys.getrefcount(s)
...@@ -728,7 +733,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -728,7 +733,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
def test_processInputs_w_large_input_gets_tempfile(self): def test_processInputs_w_large_input_gets_tempfile(self):
# checks fileupload object supports the filename # checks fileupload object supports the filename
from StringIO import StringIO
s = StringIO(TEST_LARGEFILE_DATA) s = StringIO(TEST_LARGEFILE_DATA)
req = self._makeOne(stdin=s, environ=TEST_ENVIRON.copy()) req = self._makeOne(stdin=s, environ=TEST_ENVIRON.copy())
...@@ -739,7 +743,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -739,7 +743,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
def test_processInputs_with_file_upload_gets_iterator(self): def test_processInputs_with_file_upload_gets_iterator(self):
# checks fileupload object supports the iterator protocol # checks fileupload object supports the iterator protocol
# collector entry 1837 # collector entry 1837
from StringIO import StringIO
s = StringIO(TEST_FILE_DATA) s = StringIO(TEST_FILE_DATA)
req = self._makeOne(stdin=s, environ=TEST_ENVIRON.copy()) req = self._makeOne(stdin=s, environ=TEST_ENVIRON.copy())
...@@ -752,7 +755,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -752,7 +755,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
self.assertEqual(f.xreadlines(), f) self.assertEqual(f.xreadlines(), f)
def test__authUserPW_simple(self): def test__authUserPW_simple(self):
import base64
user_id = 'user' user_id = 'user'
password = 'password' password = 'password'
encoded = base64.encodestring('%s:%s' % (user_id, password)) encoded = base64.encodestring('%s:%s' % (user_id, password))
...@@ -768,7 +770,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -768,7 +770,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
def test__authUserPW_with_embedded_colon(self): def test__authUserPW_with_embedded_colon(self):
# http://www.zope.org/Collectors/Zope/2039 # http://www.zope.org/Collectors/Zope/2039
import base64
user_id = 'user' user_id = 'user'
password = 'embedded:colon' password = 'embedded:colon'
encoded = base64.encodestring('%s:%s' % (user_id, password)) encoded = base64.encodestring('%s:%s' % (user_id, password))
...@@ -812,11 +813,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -812,11 +813,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
self.assertEqual(request.debug, '2') self.assertEqual(request.debug, '2')
def test_locale_property_accessor(self): def test_locale_property_accessor(self):
from zope.component import provideAdapter
from zope.publisher.browser import BrowserLanguages
from zope.publisher.interfaces.http import IHTTPRequest
from zope.i18n.interfaces import IUserPreferredLanguages
from zope.i18n.interfaces.locales import ILocale
from ZPublisher.HTTPRequest import _marker from ZPublisher.HTTPRequest import _marker
provideAdapter(BrowserLanguages, [IHTTPRequest], provideAdapter(BrowserLanguages, [IHTTPRequest],
...@@ -839,11 +835,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -839,11 +835,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
self.assert_(request.get('locale') is None) self.assert_(request.get('locale') is None)
def test_locale_in_qs(self): def test_locale_in_qs(self):
from zope.component import provideAdapter
from zope.publisher.browser import BrowserLanguages
from zope.publisher.interfaces.http import IHTTPRequest
from zope.i18n.interfaces import IUserPreferredLanguages
provideAdapter(BrowserLanguages, [IHTTPRequest], provideAdapter(BrowserLanguages, [IHTTPRequest],
IUserPreferredLanguages) IUserPreferredLanguages)
...@@ -858,12 +849,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -858,12 +849,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
self.assertEqual(request['locale'], '1') self.assertEqual(request['locale'], '1')
def test_locale_property_override_via_form_other(self): def test_locale_property_override_via_form_other(self):
from zope.component import provideAdapter
from zope.publisher.browser import BrowserLanguages
from zope.publisher.interfaces.http import IHTTPRequest
from zope.i18n.interfaces import IUserPreferredLanguages
from zope.i18n.interfaces.locales import ILocale
provideAdapter(BrowserLanguages, [IHTTPRequest], provideAdapter(BrowserLanguages, [IHTTPRequest],
IUserPreferredLanguages) IUserPreferredLanguages)
env = {'HTTP_ACCEPT_LANGUAGE': 'en'} env = {'HTTP_ACCEPT_LANGUAGE': 'en'}
...@@ -881,12 +866,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -881,12 +866,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
self.assertEqual(request.locale, '2') self.assertEqual(request.locale, '2')
def test_locale_semantics(self): def test_locale_semantics(self):
from zope.component import provideAdapter
from zope.publisher.browser import BrowserLanguages
from zope.publisher.interfaces.http import IHTTPRequest
from zope.i18n.interfaces import IUserPreferredLanguages
from zope.i18n.interfaces.locales import ILocale
provideAdapter(BrowserLanguages, [IHTTPRequest], provideAdapter(BrowserLanguages, [IHTTPRequest],
IUserPreferredLanguages) IUserPreferredLanguages)
env_ = {'HTTP_ACCEPT_LANGUAGE': 'en'} env_ = {'HTTP_ACCEPT_LANGUAGE': 'en'}
...@@ -910,12 +889,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -910,12 +889,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
self.assertEqual(locale.id.variant, variant) self.assertEqual(locale.id.variant, variant)
def test_locale_fallback(self): def test_locale_fallback(self):
from zope.component import provideAdapter
from zope.publisher.browser import BrowserLanguages
from zope.publisher.interfaces.http import IHTTPRequest
from zope.i18n.interfaces import IUserPreferredLanguages
from zope.i18n.interfaces.locales import ILocale
provideAdapter(BrowserLanguages, [IHTTPRequest], provideAdapter(BrowserLanguages, [IHTTPRequest],
IUserPreferredLanguages) IUserPreferredLanguages)
...@@ -1084,7 +1057,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin): ...@@ -1084,7 +1057,6 @@ class HTTPRequestTests(unittest.TestCase, HTTPRequestFactoryMixin):
def test_resolve_url_errorhandling(self): def test_resolve_url_errorhandling(self):
# Check that resolve_url really raises the same error # Check that resolve_url really raises the same error
# it received from ZPublisher.BaseRequest.traverse # it received from ZPublisher.BaseRequest.traverse
from zExceptions import NotFound
request = self._makeOne() request = self._makeOne()
request['PARENTS'] = [object()] request['PARENTS'] = [object()]
self.assertRaises( self.assertRaises(
...@@ -1129,7 +1101,6 @@ class TestHTTPRequestZope3Views(TestRequestViewsBase): ...@@ -1129,7 +1101,6 @@ class TestHTTPRequestZope3Views(TestRequestViewsBase):
def test_no_traversal_of_view_request_attribute(self): def test_no_traversal_of_view_request_attribute(self):
# make sure views don't accidentally publish the 'request' attribute # make sure views don't accidentally publish the 'request' attribute
from ZPublisher import NotFound
root, _ = self._makeRootAndFolder() root, _ = self._makeRootAndFolder()
# make sure the view itself is traversable: # make sure the view itself is traversable:
......
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
import unittest from StringIO import StringIO
import sys import sys
import unittest
from zExceptions import (
BadRequest,
Forbidden,
InternalError,
NotFound,
ResourceLockedError,
Unauthorized,
)
class HTTPResponseTests(unittest.TestCase): class HTTPResponseTests(unittest.TestCase):
...@@ -56,7 +66,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -56,7 +66,6 @@ class HTTPResponseTests(unittest.TestCase):
self.assertEqual(response.headers, {}) self.assertEqual(response.headers, {})
def test_ctor_w_status_exception(self): def test_ctor_w_status_exception(self):
from zExceptions import Unauthorized
response = self._makeOne(status=Unauthorized) response = self._makeOne(status=Unauthorized)
self.assertEqual(response.status, 401) self.assertEqual(response.status, 401)
self.assertEqual(response.errmsg, 'Unauthorized') self.assertEqual(response.errmsg, 'Unauthorized')
...@@ -141,28 +150,24 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -141,28 +150,24 @@ class HTTPResponseTests(unittest.TestCase):
self.assertEqual(response.errmsg, 'Bad Request') self.assertEqual(response.errmsg, 'Bad Request')
def test_setStatus_BadRequest(self): def test_setStatus_BadRequest(self):
from zExceptions import BadRequest
response = self._makeOne() response = self._makeOne()
response.setStatus(BadRequest) response.setStatus(BadRequest)
self.assertEqual(response.status, 400) self.assertEqual(response.status, 400)
self.assertEqual(response.errmsg, 'Bad Request') self.assertEqual(response.errmsg, 'Bad Request')
def test_setStatus_Unauthorized_exception(self): def test_setStatus_Unauthorized_exception(self):
from zExceptions import Unauthorized
response = self._makeOne() response = self._makeOne()
response.setStatus(Unauthorized) response.setStatus(Unauthorized)
self.assertEqual(response.status, 401) self.assertEqual(response.status, 401)
self.assertEqual(response.errmsg, 'Unauthorized') self.assertEqual(response.errmsg, 'Unauthorized')
def test_setStatus_Forbidden_exception(self): def test_setStatus_Forbidden_exception(self):
from zExceptions import Forbidden
response = self._makeOne() response = self._makeOne()
response.setStatus(Forbidden) response.setStatus(Forbidden)
self.assertEqual(response.status, 403) self.assertEqual(response.status, 403)
self.assertEqual(response.errmsg, 'Forbidden') self.assertEqual(response.errmsg, 'Forbidden')
def test_setStatus_NotFound_exception(self): def test_setStatus_NotFound_exception(self):
from zExceptions import NotFound
response = self._makeOne() response = self._makeOne()
response.setStatus(NotFound) response.setStatus(NotFound)
self.assertEqual(response.status, 404) self.assertEqual(response.status, 404)
...@@ -170,13 +175,11 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -170,13 +175,11 @@ class HTTPResponseTests(unittest.TestCase):
def test_setStatus_ResourceLockedError_exception(self): def test_setStatus_ResourceLockedError_exception(self):
response = self._makeOne() response = self._makeOne()
from zExceptions import ResourceLockedError
response.setStatus(ResourceLockedError) response.setStatus(ResourceLockedError)
self.assertEqual(response.status, 423) self.assertEqual(response.status, 423)
self.assertEqual(response.errmsg, 'Locked') self.assertEqual(response.errmsg, 'Locked')
def test_setStatus_InternalError_exception(self): def test_setStatus_InternalError_exception(self):
from zExceptions import InternalError
response = self._makeOne() response = self._makeOne()
response.setStatus(InternalError) response.setStatus(InternalError)
self.assertEqual(response.status, 500) self.assertEqual(response.status, 500)
...@@ -615,7 +618,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -615,7 +618,6 @@ class HTTPResponseTests(unittest.TestCase):
# (r19315): "merged content type on error fixes from 2.3 # (r19315): "merged content type on error fixes from 2.3
# If the str of the object returs a Python "pointer" looking mess, # If the str of the object returs a Python "pointer" looking mess,
# don't let it get treated as HTML. # don't let it get treated as HTML.
from ZPublisher import NotFound
BOGUS = '<Bogus a39d53d>' BOGUS = '<Bogus a39d53d>'
response = self._makeOne() response = self._makeOne()
self.assertRaises(NotFound, response.setBody, BOGUS) self.assertRaises(NotFound, response.setBody, BOGUS)
...@@ -782,7 +784,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -782,7 +784,6 @@ class HTTPResponseTests(unittest.TestCase):
self.assertEqual(response.quoteHTML(BEFORE), AFTER) self.assertEqual(response.quoteHTML(BEFORE), AFTER)
def test_notFoundError(self): def test_notFoundError(self):
from ZPublisher import NotFound
response = self._makeOne() response = self._makeOne()
try: try:
response.notFoundError() response.notFoundError()
...@@ -793,7 +794,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -793,7 +794,6 @@ class HTTPResponseTests(unittest.TestCase):
self.fail("Didn't raise NotFound") self.fail("Didn't raise NotFound")
def test_notFoundError_w_entry(self): def test_notFoundError_w_entry(self):
from ZPublisher import NotFound
response = self._makeOne() response = self._makeOne()
try: try:
response.notFoundError('ENTRY') response.notFoundError('ENTRY')
...@@ -804,7 +804,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -804,7 +804,6 @@ class HTTPResponseTests(unittest.TestCase):
self.fail("Didn't raise NotFound") self.fail("Didn't raise NotFound")
def test_forbiddenError(self): def test_forbiddenError(self):
from ZPublisher import NotFound
response = self._makeOne() response = self._makeOne()
try: try:
response.forbiddenError() response.forbiddenError()
...@@ -815,7 +814,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -815,7 +814,6 @@ class HTTPResponseTests(unittest.TestCase):
self.fail("Didn't raise NotFound") self.fail("Didn't raise NotFound")
def test_forbiddenError_w_entry(self): def test_forbiddenError_w_entry(self):
from ZPublisher import NotFound
response = self._makeOne() response = self._makeOne()
try: try:
response.forbiddenError('ENTRY') response.forbiddenError('ENTRY')
...@@ -826,7 +824,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -826,7 +824,6 @@ class HTTPResponseTests(unittest.TestCase):
self.fail("Didn't raise NotFound") self.fail("Didn't raise NotFound")
def test_debugError(self): def test_debugError(self):
from ZPublisher import NotFound
response = self._makeOne() response = self._makeOne()
try: try:
response.debugError('testing') response.debugError('testing')
...@@ -838,7 +835,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -838,7 +835,6 @@ class HTTPResponseTests(unittest.TestCase):
self.fail("Didn't raise NotFound") self.fail("Didn't raise NotFound")
def test_badRequestError_valid_parameter_name(self): def test_badRequestError_valid_parameter_name(self):
from ZPublisher import BadRequest
response = self._makeOne() response = self._makeOne()
try: try:
response.badRequestError('some_parameter') response.badRequestError('some_parameter')
...@@ -850,7 +846,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -850,7 +846,6 @@ class HTTPResponseTests(unittest.TestCase):
self.fail("Didn't raise BadRequest") self.fail("Didn't raise BadRequest")
def test_badRequestError_invalid_parameter_name(self): def test_badRequestError_invalid_parameter_name(self):
from ZPublisher import InternalError
response = self._makeOne() response = self._makeOne()
try: try:
response.badRequestError('URL1') response.badRequestError('URL1')
...@@ -883,7 +878,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -883,7 +878,6 @@ class HTTPResponseTests(unittest.TestCase):
'basic realm="Folly"') 'basic realm="Folly"')
def test_unauthorized_no_debug_mode(self): def test_unauthorized_no_debug_mode(self):
from zExceptions import Unauthorized
response = self._makeOne() response = self._makeOne()
try: try:
response.unauthorized() response.unauthorized()
...@@ -895,7 +889,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -895,7 +889,6 @@ class HTTPResponseTests(unittest.TestCase):
self.fail("Didn't raise Unauthorized") self.fail("Didn't raise Unauthorized")
def test_unauthorized_w_debug_mode_no_credentials(self): def test_unauthorized_w_debug_mode_no_credentials(self):
from zExceptions import Unauthorized
response = self._makeOne() response = self._makeOne()
response.debug_mode = True response.debug_mode = True
try: try:
...@@ -907,7 +900,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -907,7 +900,6 @@ class HTTPResponseTests(unittest.TestCase):
self.fail("Didn't raise Unauthorized") self.fail("Didn't raise Unauthorized")
def test_unauthorized_w_debug_mode_w_credentials(self): def test_unauthorized_w_debug_mode_w_credentials(self):
from zExceptions import Unauthorized
response = self._makeOne() response = self._makeOne()
response.debug_mode = True response.debug_mode = True
response._auth = 'bogus' response._auth = 'bogus'
...@@ -1243,7 +1235,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -1243,7 +1235,6 @@ class HTTPResponseTests(unittest.TestCase):
self.assertEqual(lines[5], 'BLAH') self.assertEqual(lines[5], 'BLAH')
def test_write_already_wrote(self): def test_write_already_wrote(self):
from StringIO import StringIO
stdout = StringIO() stdout = StringIO()
response = self._makeOne(stdout=stdout) response = self._makeOne(stdout=stdout)
response.write('Kilroy was here!') response.write('Kilroy was here!')
...@@ -1258,7 +1249,6 @@ class HTTPResponseTests(unittest.TestCase): ...@@ -1258,7 +1249,6 @@ class HTTPResponseTests(unittest.TestCase):
self.assertEqual(lines[4], 'Kilroy was here!') self.assertEqual(lines[4], 'Kilroy was here!')
def test_write_not_already_wrote(self): def test_write_not_already_wrote(self):
from StringIO import StringIO
stdout = StringIO() stdout = StringIO()
response = self._makeOne(stdout=stdout) response = self._makeOne(stdout=stdout)
response._wrote = True response._wrote = True
......
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