view contrib/raw_wsgi_bench.py @ 5674:68ba3cc79513

Fixed MoinMoinBugs/1.9.2XSSTemplateParameter by escaping template name in messages.
author Eugene Syromyatnikov <evgsyr@gmail.com>
date Thu, 03 Jun 2010 12:47:36 +0400
parents 1d3d282130c8
children
line wrap: on
line source
# -*- coding: utf-8 -*-
"""
    MoinMoin - raw_wsgi_bench

    @copyright: 2008 MoinMoin:FlorianKrupicka
    @license: GNU GPL, see COPYING for details.
"""
import time, itertools, sys, os

from werkzeug.test import Client

from MoinMoin.wsgiapp import application

sys.path.insert(0, os.path.join(os.path.dirname(__file__), 'tests'))

RUNS = 100
RUNS_MARKER = RUNS / 10
DOTS_MARKER = RUNS_MARKER / 5

PAGES = ('FrontPage', 'HelpOnMoinWikiSyntax', 'RecentChanges')

client = Client(application)

for page in PAGES:
    print '=== Run with page "%s" ===' % page
    print 'Running %i WSGI-requests:' % RUNS
    timing = time.time()
    for run in xrange(RUNS):
        appiter, status, headers = client.get('/%s' % page)
        #result = ''.join(appiter)
        if ((run + 1) % RUNS_MARKER == 0):
            sys.stdout.write('%i' % (run + 1))
        elif ((run + 1) % DOTS_MARKER == 0):
            sys.stdout.write('.')
    timing = time.time() - timing

    print
    print 'Finished %i WSGI-requests in %.2f seconds' % (RUNS, timing)
    print 'Time per request: %.4f seconds' % (timing / RUNS)
    print 'Requests per second: %.2f' % (RUNS / timing)