mbligh | 56a91f0 | 2006-09-14 17:55:19 +0000 | [diff] [blame] | 1 | import test |
| 2 | from autotest_utils import * |
| 3 | |
| 4 | class 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') |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 15 | |
| 16 | |
| 17 | def initialize(self): |
mbligh | 6f5bbce | 2007-08-10 19:18:37 +0000 | [diff] [blame^] | 18 | # netserver doesn't detach properly from the console. When |
| 19 | # it is run from ssh, this causes the ssh command not to |
| 20 | # return even though netserver meant to be backgrounded. |
| 21 | # This behavior is remedied by redirecting fd 0, 1 & 2 |
| 22 | self.server_path = ('%s &>/dev/null </dev/null' |
| 23 | % os.path.join(self.srcdir, 'src/netserver')) |
mbligh | 56a91f0 | 2006-09-14 17:55:19 +0000 | [diff] [blame] | 24 | self.client_path = os.path.join(self.srcdir, 'src/netperf') |
| 25 | |
mbligh | 6f5bbce | 2007-08-10 19:18:37 +0000 | [diff] [blame^] | 26 | |
mbligh | c6b01ed | 2006-10-13 17:03:26 +0000 | [diff] [blame] | 27 | def execute(self, server_ip, client_ip, role, |
| 28 | script='snapshot_script', args=''): |
| 29 | server_tag = server_ip + '#netperf-server' |
| 30 | client_tag = client_ip + '#netperf-client' |
| 31 | all = [server_tag, client_tag] |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 32 | job = self.job |
| 33 | if (role == 'server'): |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 34 | self.server_start() |
apw | da2a62f | 2006-11-06 17:39:25 +0000 | [diff] [blame] | 35 | try: |
| 36 | job.barrier(server_tag, 'start', |
mbligh | 38f8477 | 2007-08-09 21:19:39 +0000 | [diff] [blame] | 37 | 600).rendevous(*all) |
apw | da2a62f | 2006-11-06 17:39:25 +0000 | [diff] [blame] | 38 | job.barrier(server_tag, 'stop', |
| 39 | 3600).rendevous(*all) |
| 40 | finally: |
| 41 | self.server_stop() |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 42 | elif (role == 'client'): |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 43 | os.environ['NETPERF_CMD'] = self.client_path |
mbligh | 38f8477 | 2007-08-09 21:19:39 +0000 | [diff] [blame] | 44 | job.barrier(client_tag, 'start', 600).rendevous(*all) |
mbligh | c6b01ed | 2006-10-13 17:03:26 +0000 | [diff] [blame] | 45 | self.client(script, server_ip, args) |
| 46 | job.barrier(client_tag, 'stop', 30).rendevous(*all) |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 47 | else: |
| 48 | raise UnhandledError('invalid role specified') |
| 49 | |
mbligh | 56a91f0 | 2006-09-14 17:55:19 +0000 | [diff] [blame] | 50 | |
| 51 | def server_start(self): |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 52 | # we should really record the pid we forked off, but there |
| 53 | # was no obvious way to run the daemon in the foreground. |
| 54 | # Hacked it for now |
mbligh | 0d4a032 | 2006-09-25 14:17:55 +0000 | [diff] [blame] | 55 | system('killall netserver', ignorestatus=1) |
mbligh | a8cc6e0 | 2006-09-23 05:00:33 +0000 | [diff] [blame] | 56 | system(self.server_path) |
mbligh | 56a91f0 | 2006-09-14 17:55:19 +0000 | [diff] [blame] | 57 | |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 58 | |
mbligh | 56a91f0 | 2006-09-14 17:55:19 +0000 | [diff] [blame] | 59 | def server_stop(self): |
| 60 | # this should really just kill the pid I forked, but ... |
| 61 | system('killall netserver') |
| 62 | |
mbligh | 54e5684 | 2006-09-23 06:02:54 +0000 | [diff] [blame] | 63 | |
mbligh | c6b01ed | 2006-10-13 17:03:26 +0000 | [diff] [blame] | 64 | def client(self, script, server_ip, args = 'CPU'): |
mbligh | 56a91f0 | 2006-09-14 17:55:19 +0000 | [diff] [blame] | 65 | # run some client stuff |
mbligh | c6b01ed | 2006-10-13 17:03:26 +0000 | [diff] [blame] | 66 | stdout_path = os.path.join(self.resultsdir, script + '.stdout') |
| 67 | stderr_path = os.path.join(self.resultsdir, script + '.stderr') |
| 68 | self.job.stdout.tee_redirect(stdout_path) |
| 69 | self.job.stderr.tee_redirect(stderr_path) |
mbligh | 56a91f0 | 2006-09-14 17:55:19 +0000 | [diff] [blame] | 70 | |
mbligh | e8fa3af | 2006-09-28 23:14:56 +0000 | [diff] [blame] | 71 | script_path = os.path.join(self.srcdir, 'doc/examples', script) |
mbligh | c6b01ed | 2006-10-13 17:03:26 +0000 | [diff] [blame] | 72 | system('%s %s %s' % (script_path, server_ip, args)) |
mbligh | e8fa3af | 2006-09-28 23:14:56 +0000 | [diff] [blame] | 73 | |
mbligh | c6b01ed | 2006-10-13 17:03:26 +0000 | [diff] [blame] | 74 | self.job.stdout.restore() |
| 75 | self.job.stderr.restore() |