blob: 8347a3201c08d2402e69c74ebaf60b07ecd2efcb [file] [log] [blame]
mbligh548ace82006-10-19 14:36:45 +00001#!/usr/bin/python
mbligh9f857922008-06-05 16:19:07 +00002import os
3from autotest_lib.client.bin import test, autotest_utils
4from autotest_lib.client.common_lib import utils
mbligh548ace82006-10-19 14:36:45 +00005
mbligh548ace82006-10-19 14:36:45 +00006
7class iozone(test.test):
jadmanski0afbb632008-06-06 21:10:57 +00008 version = 1
mbligh548ace82006-10-19 14:36:45 +00009
jadmanski0afbb632008-06-06 21:10:57 +000010 # http://www.iozone.org/src/current/iozone3_283.tar
11 def setup(self, tarball = 'iozone3_283.tar'):
12 tarball = utils.unmap_url(self.bindir, tarball,
13 self.tmpdir)
14 autotest_utils.extract_tarball_to_dir(tarball, self.srcdir)
15 os.chdir(os.path.join(self.srcdir, 'src/current'))
mbligh548ace82006-10-19 14:36:45 +000016
jadmanski0afbb632008-06-06 21:10:57 +000017 arch = autotest_utils.get_current_kernel_arch()
18 if (arch == 'ppc'):
19 utils.system('make linux-powerpc')
20 elif (arch == 'ppc64'):
21 utils.system('make linux-powerpc64')
22 elif (arch == 'x86_64'):
23 utils.system('make linux-AMD64')
24 else:
25 utils.system('make linux')
mbligh548ace82006-10-19 14:36:45 +000026
mbligh1f337612007-09-30 01:19:47 +000027
jadmanski0afbb632008-06-06 21:10:57 +000028 def execute(self, dir = None, iterations=1, args = None):
29 self.keyval = open(os.path.join(self.resultsdir, 'keyval'),
30 'w')
31 if not dir:
32 dir = self.tmpdir
33 os.chdir(dir)
34 if not args:
35 args = '-a'
36 profilers = self.job.profilers
37 if not profilers.only():
38 for i in range(iterations):
39 output = utils.system_output('%s/src/current/iozone %s' %
40 (self.srcdir, args))
41 self.__format_results(output)
mbligh548ace82006-10-19 14:36:45 +000042
jadmanski0afbb632008-06-06 21:10:57 +000043 # Do a profiling run if necessary
44 if profilers.present():
45 profilers.start(self)
46 output = utils.system_output('%s/src/current/iozone %s' %
47 (self.srcdir, args))
48 self.__format_results(output)
49 profilers.stop(self)
50 profilers.report(self)
mbligheea785f2008-01-25 16:39:11 +000051
jadmanski0afbb632008-06-06 21:10:57 +000052 self.keyval.close()
mbligh6303ed62007-07-19 16:19:16 +000053
54
jadmanski0afbb632008-06-06 21:10:57 +000055 def __format_results(self, results):
56 labels = ('write', 'rewrite', 'read', 'reread', 'randread',
57 'randwrite', 'bkwdread', 'recordrewrite',
58 'strideread', 'fwrite', 'frewrite',
59 'fread', 'freread')
60 for line in results.splitlines():
61 fields = line.split()
62 if len(fields) != 15:
63 continue
64 try:
65 fields = tuple([int(i) for i in fields])
66 except ValueError:
67 continue
68 for l, v in zip(labels, fields[2:]):
69 print >> self.keyval, "%d-%d-%s=%d" % (fields[0], fields[1], l, v)
70 print >> self.keyval