Merge pull request #2220 from DOCGroup/revert-2217-jwi-inetwraning
[ACE_TAO.git] / TAO / performance-tests / Latency / AMH_Single_Threaded / run_test.pl
blobe24bf587920e3e4cb6b6cd4b415fa7cdfda7b70d
1 eval '(exit $?0)' && eval 'exec perl -S $0 ${1+"$@"}'
2 & eval 'exec perl -S $0 $argv:q'
3 if 0;
5 # -*- perl -*-
7 use lib "$ENV{ACE_ROOT}/bin";
8 use PerlACE::TestTarget;
10 $status = 0;
11 $debug_level = '0';
13 $iterations = '150000';
15 foreach $i (@ARGV) {
16 if ($i eq '-debug') {
17 $debug_level = '10';
21 my $server = PerlACE::TestTarget::create_target (1) || die "Create target 1 failed\n";
22 my $client = PerlACE::TestTarget::create_target (2) || die "Create target 2 failed\n";
24 my $iorbase = "test.ior";
25 my $server_iorfile = $server->LocalFile ($iorbase);
26 my $client_iorfile = $client->LocalFile ($iorbase);
27 $server->DeleteFile($iorbase);
28 $client->DeleteFile($iorbase);
30 $SV = $server->CreateProcess ("server", "-ORBdebuglevel $debug_level -o $server_iorfile");
31 $CL = $client->CreateProcess ("client", "-k file://$client_iorfile " .
32 "-i $iterations");
34 print STDERR "=============== AMH Single-Threaded Latency Test\n";
36 $server_status = $SV->Spawn ();
38 if ($server_status != 0) {
39 print STDERR "ERROR: server returned $server_status\n";
40 exit 1;
43 if ($server->WaitForFileTimed ($iorbase,
44 $server->ProcessStartWaitInterval()) == -1) {
45 print STDERR "ERROR: cannot find file <$server_iorfile>\n";
46 $SV->Kill (); $SV->TimedWait (1);
47 exit 1;
50 if ($server->GetFile ($iorbase) == -1) {
51 print STDERR "ERROR: cannot retrieve file <$server_iorfile>\n";
52 $SV->Kill (); $SV->TimedWait (1);
53 exit 1;
55 if ($client->PutFile ($iorbase) == -1) {
56 print STDERR "ERROR: cannot set file <$client_iorfile>\n";
57 $SV->Kill (); $SV->TimedWait (1);
58 exit 1;
61 $client_status = $CL->SpawnWaitKill ($client->ProcessStartWaitInterval() + 100);
63 if ($client_status != 0) {
64 print STDERR "ERROR: client returned $client_status\n";
65 $status = 1;
68 $server_status = $SV->WaitKill ($server->ProcessStopWaitInterval());
70 if ($server_status != 0) {
71 print STDERR "ERROR: server returned $server_status\n";
72 $status = 1;
75 $server->DeleteFile($iorbase);
76 $client->DeleteFile($iorbase);
78 exit $status;