mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 1 | #!/usr/bin/python |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 2 | import os |
| 3 | from autotest_lib.client.bin import test, autotest_utils |
| 4 | from autotest_lib.client.common_lib import utils |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 5 | |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 6 | |
| 7 | class iozone(test.test): |
| 8 | version = 1 |
| 9 | |
mbligh | 920f412 | 2007-07-09 21:43:39 +0000 | [diff] [blame] | 10 | # http://www.iozone.org/src/current/iozone3_283.tar |
| 11 | def setup(self, tarball = 'iozone3_283.tar'): |
mbligh | 34d0117 | 2008-06-05 16:26:31 +0000 | [diff] [blame] | 12 | tarball = utils.unmap_url(self.bindir, tarball, |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 13 | self.tmpdir) |
| 14 | autotest_utils.extract_tarball_to_dir(tarball, self.srcdir) |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 15 | os.chdir(os.path.join(self.srcdir, 'src/current')) |
| 16 | |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 17 | arch = autotest_utils.get_current_kernel_arch() |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 18 | if (arch == 'ppc'): |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 19 | utils.system('make linux-powerpc') |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 20 | elif (arch == 'ppc64'): |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 21 | utils.system('make linux-powerpc64') |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 22 | elif (arch == 'x86_64'): |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 23 | utils.system('make linux-AMD64') |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 24 | else: |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 25 | utils.system('make linux') |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 26 | |
mbligh | 1f33761 | 2007-09-30 01:19:47 +0000 | [diff] [blame] | 27 | |
| 28 | def execute(self, dir = None, iterations=1, args = None): |
mbligh | eea785f | 2008-01-25 16:39:11 +0000 | [diff] [blame] | 29 | self.keyval = open(os.path.join(self.resultsdir, 'keyval'), |
| 30 | 'w') |
mbligh | 1f33761 | 2007-09-30 01:19:47 +0000 | [diff] [blame] | 31 | if not dir: |
| 32 | dir = self.tmpdir |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 33 | os.chdir(dir) |
| 34 | if not args: |
| 35 | args = '-a' |
mbligh | 9f5113d | 2007-06-25 23:41:10 +0000 | [diff] [blame] | 36 | profilers = self.job.profilers |
| 37 | if not profilers.only(): |
mbligh | 6303ed6 | 2007-07-19 16:19:16 +0000 | [diff] [blame] | 38 | for i in range(iterations): |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 39 | output = utils.system_output('%s/src/current/iozone %s' % |
mbligh | eea785f | 2008-01-25 16:39:11 +0000 | [diff] [blame] | 40 | (self.srcdir, args)) |
| 41 | self.__format_results(output) |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 42 | |
| 43 | # Do a profiling run if necessary |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 44 | if profilers.present(): |
| 45 | profilers.start(self) |
mbligh | 9f85792 | 2008-06-05 16:19:07 +0000 | [diff] [blame] | 46 | output = utils.system_output('%s/src/current/iozone %s' % |
mbligh | eea785f | 2008-01-25 16:39:11 +0000 | [diff] [blame] | 47 | (self.srcdir, args)) |
| 48 | self.__format_results(output) |
mbligh | 548ace8 | 2006-10-19 14:36:45 +0000 | [diff] [blame] | 49 | profilers.stop(self) |
| 50 | profilers.report(self) |
mbligh | eea785f | 2008-01-25 16:39:11 +0000 | [diff] [blame] | 51 | |
| 52 | self.keyval.close() |
mbligh | 6303ed6 | 2007-07-19 16:19:16 +0000 | [diff] [blame] | 53 | |
| 54 | |
| 55 | def __format_results(self, results): |
| 56 | labels = ('write', 'rewrite', 'read', 'reread', 'randread', |
| 57 | 'randwrite', 'bkwdread', 'recordrewrite', |
| 58 | 'strideread', 'fwrite', 'frewrite', |
| 59 | 'fread', 'freread') |
mbligh | eea785f | 2008-01-25 16:39:11 +0000 | [diff] [blame] | 60 | for line in results.splitlines(): |
mbligh | 6303ed6 | 2007-07-19 16:19:16 +0000 | [diff] [blame] | 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:]): |
mbligh | eea785f | 2008-01-25 16:39:11 +0000 | [diff] [blame] | 69 | print >> self.keyval, "%d-%d-%s=%d" % (fields[0], fields[1], l, v) |
| 70 | print >> self.keyval |