blob: 1f7e11b884ab59ef7349306c85b22753563b2b2c [file] [log] [blame]
mbligh56a91f02006-09-14 17:55:19 +00001import test
2from autotest_utils import *
3
4class netperf2(test.test):
5 version = 1
6
7 # ftp://ftp.netperf.org/netperf/netperf-2.4.1.tar.gz
8 def setup(self, tarball = 'netperf-2.4.1.tar.gz'):
9 tarball = unmap_url(self.bindir, tarball, self.tmpdir)
10 extract_tarball_to_dir(tarball, self.srcdir)
11 os.chdir(self.srcdir)
12
13 system('./configure')
14 system('make')
mbligh54e56842006-09-23 06:02:54 +000015
16
17 def initialize(self):
mbligh56a91f02006-09-14 17:55:19 +000018 self.server_path = os.path.join(self.srcdir, 'src/netserver')
19 self.client_path = os.path.join(self.srcdir, 'src/netperf')
20
mbligh54e56842006-09-23 06:02:54 +000021
22 def execute(self, role='client', script='snapshot_script', args=''):
23 all = ['127.0.0.1#netperf-server', '127.0.0.1#netperf-client']
24 job = self.job
25 if (role == 'server'):
26 hostid = '127.0.0.1#netperf-server'
27 self.server_start()
28 job.barrier(hostid, 'start', 30).rendevous(*all)
mbligh0d4a0322006-09-25 14:17:55 +000029 job.barrier(hostid, 'stop', 3600).rendevous(*all)
mbligh54e56842006-09-23 06:02:54 +000030 self.server_stop()
31 elif (role == 'client'):
32 hostid = '127.0.0.1#netperf-client'
33 os.environ['NETPERF_CMD'] = self.client_path
34 job.barrier(hostid, 'start', 30).rendevous(*all)
mblighe8fa3af2006-09-28 23:14:56 +000035 self.client(script, '127.0.0.1', args)
mbligh54e56842006-09-23 06:02:54 +000036 job.barrier(hostid, 'stop', 30).rendevous(*all)
37 else:
38 raise UnhandledError('invalid role specified')
39
mbligh56a91f02006-09-14 17:55:19 +000040
41 def server_start(self):
mbligh54e56842006-09-23 06:02:54 +000042 # we should really record the pid we forked off, but there
43 # was no obvious way to run the daemon in the foreground.
44 # Hacked it for now
mbligh0d4a0322006-09-25 14:17:55 +000045 system('killall netserver', ignorestatus=1)
mbligha8cc6e02006-09-23 05:00:33 +000046 system(self.server_path)
mbligh56a91f02006-09-14 17:55:19 +000047
mbligh54e56842006-09-23 06:02:54 +000048
mbligh56a91f02006-09-14 17:55:19 +000049 def server_stop(self):
50 # this should really just kill the pid I forked, but ...
51 system('killall netserver')
52
mbligh54e56842006-09-23 06:02:54 +000053
mblighe8fa3af2006-09-28 23:14:56 +000054 def client(self, script, server_host, args = 'CPU'):
mbligh56a91f02006-09-14 17:55:19 +000055 # run some client stuff
mblighe8fa3af2006-09-28 23:14:56 +000056 # stdout_path = os.path.join(self.resultsdir, script + '.stdout')
57 # stderr_path = os.path.join(self.resultsdir, script + '.stderr')
58 # self.job.stdout.tee_redirect(stdout_path)
59 # self.job.stderr.tee_redirect(stderr_path)
mbligh56a91f02006-09-14 17:55:19 +000060
mblighe8fa3af2006-09-28 23:14:56 +000061 script_path = os.path.join(self.srcdir, 'doc/examples', script)
62 system('%s %s %s' % (script_path, server_host, args))
63
64 # self.job.stdout.restore()
65 # self.job.stderr.restore()