2011-07-28 05:01:05 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#
|
|
|
|
# A simple benchmark of tornado template rendering, based on
|
|
|
|
# https://github.com/mitsuhiko/jinja2/blob/master/examples/bench.py
|
|
|
|
|
2011-07-28 05:09:49 +00:00
|
|
|
import sys
|
2011-07-28 05:01:05 +00:00
|
|
|
from timeit import Timer
|
|
|
|
|
|
|
|
from tornado.options import options, define, parse_command_line
|
|
|
|
from tornado.template import Template
|
|
|
|
|
|
|
|
define('num', default=100, help='number of iterations')
|
2011-07-28 05:09:49 +00:00
|
|
|
define('dump', default=False, help='print template generated code and exit')
|
2011-07-28 05:01:05 +00:00
|
|
|
|
|
|
|
context = {
|
|
|
|
'page_title': 'mitsuhiko\'s benchmark',
|
2018-01-06 23:32:44 +00:00
|
|
|
'table': [dict(a=1, b=2, c=3, d=4, e=5,
|
|
|
|
f=6, g=7, h=8, i=9, j=10) for x in range(1000)]
|
2011-07-28 05:01:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
tmpl = Template("""\
|
|
|
|
<!doctype html>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<title>{{ page_title }}</title>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<div class="header">
|
|
|
|
<h1>{{ page_title }}</h1>
|
|
|
|
</div>
|
|
|
|
<ul class="navigation">
|
|
|
|
{% for href, caption in [ \
|
|
|
|
('index.html', 'Index'), \
|
|
|
|
('downloads.html', 'Downloads'), \
|
|
|
|
('products.html', 'Products') \
|
|
|
|
] %}
|
|
|
|
<li><a href="{{ href }}">{{ caption }}</a></li>
|
|
|
|
{% end %}
|
|
|
|
</ul>
|
|
|
|
<div class="table">
|
|
|
|
<table>
|
|
|
|
{% for row in table %}
|
|
|
|
<tr>
|
|
|
|
{% for cell in row %}
|
|
|
|
<td>{{ cell }}</td>
|
|
|
|
{% end %}
|
|
|
|
</tr>
|
|
|
|
{% end %}
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
</body>
|
|
|
|
</html>\
|
|
|
|
""")
|
|
|
|
|
2018-01-01 19:43:18 +00:00
|
|
|
|
2011-07-28 05:01:05 +00:00
|
|
|
def render():
|
|
|
|
tmpl.generate(**context)
|
|
|
|
|
2018-01-01 19:43:18 +00:00
|
|
|
|
2011-07-28 05:01:05 +00:00
|
|
|
def main():
|
|
|
|
parse_command_line()
|
2011-07-28 05:09:49 +00:00
|
|
|
if options.dump:
|
2015-02-06 02:29:13 +00:00
|
|
|
print(tmpl.code)
|
2011-07-28 05:09:49 +00:00
|
|
|
sys.exit(0)
|
2011-07-28 05:01:05 +00:00
|
|
|
t = Timer(render)
|
|
|
|
results = t.timeit(options.num) / options.num
|
2018-01-01 18:43:55 +00:00
|
|
|
print('%0.3f ms per iteration' % (results * 1000))
|
2011-07-28 05:01:05 +00:00
|
|
|
|
2018-01-01 19:43:18 +00:00
|
|
|
|
2011-07-28 05:01:05 +00:00
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|