stones.py 680 Bytes
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12
import errno
import hotshot
import hotshot.stats
import os
import sys
import test.pystone


if sys.argv[1:]:
    logfile = sys.argv[1]
else:
    import tempfile
13 14
    logf = tempfile.NamedTemporaryFile()
    logfile = logf.name
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

p = hotshot.Profile(logfile)
benchtime, stones = p.runcall(test.pystone.pystones)
p.close()

print "Pystone(%s) time for %d passes = %g" % \
      (test.pystone.__version__, test.pystone.LOOPS, benchtime)
print "This machine benchmarks at %g pystones/second" % stones

stats = hotshot.stats.load(logfile)
stats.strip_dirs()
stats.sort_stats('time', 'calls')
try:
    stats.print_stats(20)
except IOError, e:
    if e.errno != errno.EPIPE:
        raise