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