2011-12-31 00:02:40 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#
|
|
|
|
# Downloads a large file in chunked encoding with both curl and simple clients
|
|
|
|
|
|
|
|
import logging
|
|
|
|
from tornado.curl_httpclient import CurlAsyncHTTPClient
|
|
|
|
from tornado.simple_httpclient import SimpleAsyncHTTPClient
|
|
|
|
from tornado.ioloop import IOLoop
|
|
|
|
from tornado.options import define, options, parse_command_line
|
|
|
|
from tornado.web import RequestHandler, Application
|
|
|
|
|
2018-01-01 20:01:22 +00:00
|
|
|
try:
|
|
|
|
xrange
|
|
|
|
except NameError:
|
|
|
|
xrange = range
|
|
|
|
|
2011-12-31 00:02:40 +00:00
|
|
|
define('port', default=8888)
|
|
|
|
define('num_chunks', default=1000)
|
|
|
|
define('chunk_size', default=2048)
|
|
|
|
|
2015-03-29 20:22:26 +00:00
|
|
|
|
2011-12-31 00:02:40 +00:00
|
|
|
class ChunkHandler(RequestHandler):
|
|
|
|
def get(self):
|
|
|
|
for i in xrange(options.num_chunks):
|
|
|
|
self.write('A' * options.chunk_size)
|
|
|
|
self.flush()
|
|
|
|
self.finish()
|
|
|
|
|
2015-03-29 20:22:26 +00:00
|
|
|
|
2011-12-31 00:02:40 +00:00
|
|
|
def main():
|
|
|
|
parse_command_line()
|
|
|
|
app = Application([('/', ChunkHandler)])
|
|
|
|
app.listen(options.port, address='127.0.0.1')
|
2015-03-29 20:22:26 +00:00
|
|
|
|
2011-12-31 00:02:40 +00:00
|
|
|
def callback(response):
|
|
|
|
response.rethrow()
|
|
|
|
assert len(response.body) == (options.num_chunks * options.chunk_size)
|
|
|
|
logging.warning("fetch completed in %s seconds", response.request_time)
|
2015-03-29 20:22:26 +00:00
|
|
|
IOLoop.current().stop()
|
2011-12-31 00:02:40 +00:00
|
|
|
|
|
|
|
logging.warning("Starting fetch with curl client")
|
|
|
|
curl_client = CurlAsyncHTTPClient()
|
|
|
|
curl_client.fetch('http://localhost:%d/' % options.port,
|
|
|
|
callback=callback)
|
2015-03-29 20:22:26 +00:00
|
|
|
IOLoop.current().start()
|
2011-12-31 00:02:40 +00:00
|
|
|
|
|
|
|
logging.warning("Starting fetch with simple client")
|
|
|
|
simple_client = SimpleAsyncHTTPClient()
|
|
|
|
simple_client.fetch('http://localhost:%d/' % options.port,
|
|
|
|
callback=callback)
|
2015-03-29 20:22:26 +00:00
|
|
|
IOLoop.current().start()
|
|
|
|
|
2011-12-31 00:02:40 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|