author | Christophe de Vienne <christophe@unlish.com> |
Sat, 03 Jan 2015 16:51:32 +0100 | |
changeset 11535 | dd875009cc47 |
child 11537 | caf268942436 |
permissions | -rw-r--r-- |
11535
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
1 |
import cProfile |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
2 |
import itertools |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
3 |
from pyramid.view import view_config |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
4 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
5 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
6 |
@view_config(route_name='profile_ping') |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
7 |
def ping(request): |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
8 |
request.response.text = u'pong' |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
9 |
return request.response |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
10 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
11 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
12 |
@view_config(route_name='profile_cnx') |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
13 |
def cnx(request): |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
14 |
request.cw_cnx |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
15 |
request.response.text = u'pong' |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
16 |
return request.response |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
17 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
18 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
19 |
def wsgi_profile(app, filename='program.prof', dump_every=50): |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
20 |
profile = cProfile.Profile() |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
21 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
22 |
counter = itertools.count(1) |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
23 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
24 |
def application(environ, start_response): |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
25 |
profile.enable() |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
26 |
try: |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
27 |
return app(environ, start_response) |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
28 |
finally: |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
29 |
profile.disable() |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
30 |
if not counter.next() % dump_every: |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
31 |
print "Dump profile stats to %s" % filename |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
32 |
profile.create_stats() |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
33 |
profile.dump_stats(filename) |
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
34 |
|
dd875009cc47
[profile] Add a profiling tool
Christophe de Vienne <christophe@unlish.com>
parents:
diff
changeset
|
35 |
return application |