Fixed #9659: fixed `wsgi.file_wrapper` in the builtin server. Thanks, mitsuhiko.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10690 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
523da3801d
commit
bfdb7d26aa
|
@ -306,14 +306,15 @@ class ServerHandler(object):
|
||||||
env.setdefault('SERVER_SOFTWARE',self.server_software)
|
env.setdefault('SERVER_SOFTWARE',self.server_software)
|
||||||
|
|
||||||
def finish_response(self):
|
def finish_response(self):
|
||||||
"""Send any iterable data, then close self and the iterable
|
|
||||||
|
|
||||||
Subclasses intended for use in asynchronous servers will
|
|
||||||
want to redefine this method, such that it sets up callbacks
|
|
||||||
in the event loop to iterate over the data, and to call
|
|
||||||
'self.close()' once the response is finished.
|
|
||||||
"""
|
"""
|
||||||
if not self.result_is_file() and not self.sendfile():
|
Send any iterable data, then close self and the iterable
|
||||||
|
|
||||||
|
Subclasses intended for use in asynchronous servers will want to
|
||||||
|
redefine this method, such that it sets up callbacks in the event loop
|
||||||
|
to iterate over the data, and to call 'self.close()' once the response
|
||||||
|
is finished.
|
||||||
|
"""
|
||||||
|
if not self.result_is_file() or not self.sendfile():
|
||||||
for data in self.result:
|
for data in self.result:
|
||||||
self.write(data)
|
self.write(data)
|
||||||
self.finish_content()
|
self.finish_content()
|
||||||
|
|
|
@ -0,0 +1,51 @@
|
||||||
|
from unittest import TestCase
|
||||||
|
from StringIO import StringIO
|
||||||
|
from django.core.servers.basehttp import ServerHandler
|
||||||
|
|
||||||
|
#
|
||||||
|
# Tests for #9659: wsgi.file_wrapper in the builtin server.
|
||||||
|
# We need to mock a couple of of handlers and keep track of what
|
||||||
|
# gets called when using a couple kinds of WSGI apps.
|
||||||
|
#
|
||||||
|
|
||||||
|
class DummyHandler(object):
|
||||||
|
def log_request(*args, **kwargs):
|
||||||
|
pass
|
||||||
|
|
||||||
|
class FileWrapperHandler(ServerHandler):
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
ServerHandler.__init__(self, *args, **kwargs)
|
||||||
|
self.request_handler = DummyHandler()
|
||||||
|
self._used_sendfile = False
|
||||||
|
|
||||||
|
def sendfile(self):
|
||||||
|
self._used_sendfile = True
|
||||||
|
return True
|
||||||
|
|
||||||
|
def wsgi_app(environ, start_response):
|
||||||
|
start_response('200 OK', [('Content-Type', 'text/plain')])
|
||||||
|
return ['Hello World!']
|
||||||
|
|
||||||
|
def wsgi_app_file_wrapper(environ, start_response):
|
||||||
|
start_response('200 OK', [('Content-Type', 'text/plain')])
|
||||||
|
return environ['wsgi.file_wrapper'](StringIO('foo'))
|
||||||
|
|
||||||
|
class WSGIFileWrapperTests(TestCase):
|
||||||
|
"""
|
||||||
|
Test that the wsgi.file_wrapper works for the builting server.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def test_file_wrapper_uses_sendfile(self):
|
||||||
|
env = {'SERVER_PROTOCOL': 'HTTP/1.0'}
|
||||||
|
err = StringIO()
|
||||||
|
handler = FileWrapperHandler(None, StringIO(), err, env)
|
||||||
|
handler.run(wsgi_app_file_wrapper)
|
||||||
|
self.assert_(handler._used_sendfile)
|
||||||
|
|
||||||
|
def test_file_wrapper_no_sendfile(self):
|
||||||
|
env = {'SERVER_PROTOCOL': 'HTTP/1.0'}
|
||||||
|
err = StringIO()
|
||||||
|
handler = FileWrapperHandler(None, StringIO(), err, env)
|
||||||
|
handler.run(wsgi_app)
|
||||||
|
self.failIf(handler._used_sendfile)
|
||||||
|
self.assertEqual(handler.stdout.getvalue().splitlines()[-1],'Hello World!')
|
Loading…
Reference in New Issue