Use a variable on the stack to not have a temporary in the call
[ACE_TAO.git] / TAO / performance-tests / Latency / AMI / run_test.pl
blob5412cdf3438c27e0d419e20a9cbb69e151d0f6f0
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';
12 $iterations = '150000';
14 foreach $i (@ARGV) {
15 if ($i eq '-debug') {
16 $debug_level = '10';
20 print STDERR "================ AMI Latency test\n";
22 my $server = PerlACE::TestTarget::create_target (1) || die "Create target 1 failed\n";
23 my $client = PerlACE::TestTarget::create_target (2) || die "Create target 2 failed\n";
25 my $iorbase = "test.ior";
26 my $server_iorfile = $server->LocalFile ($iorbase);
27 my $client_iorfile = $client->LocalFile ($iorbase);
28 $server->DeleteFile($iorbase);
29 $client->DeleteFile($iorbase);
31 $SV = $server->CreateProcess ("server",
32 "-ORBdebuglevel $debug_level " .
33 "-o $server_iorfile");
35 $CL = $client->CreateProcess ("client",
36 "-i $iterations " .
37 "-k file://$client_iorfile");
38 $server_status = $SV->Spawn ();
40 if ($server_status != 0) {
41 print STDERR "ERROR: server returned $server_status\n";
42 exit 1;
45 if ($server->WaitForFileTimed ($iorbase,
46 $server->ProcessStartWaitInterval()) == -1) {
47 print STDERR "ERROR: cannot find file <$server_iorfile>\n";
48 $SV->Kill (); $SV->TimedWait (1);
49 exit 1;
52 if ($server->GetFile ($iorbase) == -1) {
53 print STDERR "ERROR: cannot retrieve file <$server_iorfile>\n";
54 $SV->Kill (); $SV->TimedWait (1);
55 exit 1;
57 if ($client->PutFile ($iorbase) == -1) {
58 print STDERR "ERROR: cannot set file <$client_iorfile>\n";
59 $SV->Kill (); $SV->TimedWait (1);
60 exit 1;
63 # Very slow machines need > 3 minutes to finish
64 $client_status = $CL->SpawnWaitKill ($client->ProcessStartWaitInterval() + 200);
66 if ($client_status != 0) {
67 print STDERR "ERROR: client returned $client_status\n";
68 $status = 1;
71 $server_status = $SV->WaitKill ($server->ProcessStopWaitInterval());
73 if ($server_status != 0) {
74 print STDERR "ERROR: server returned $server_status\n";
75 $status = 1;
78 $server->DeleteFile($iorbase);
79 $client->DeleteFile($iorbase);
81 exit $status;