1 eval '(exit $?0)' && eval 'exec perl -S $0 ${1+"$@"}'
2 & eval 'exec perl -S $0 $argv:q'
7 use lib
"$ENV{ACE_ROOT}/bin";
8 use PerlACE
::TestTarget
;
12 $iterations = '150000';
21 print STDERR
"================ Deferred Synchronous Latency Test\n";
23 my $server = PerlACE
::TestTarget
::create_target
(1) || die "Create target 1 failed\n";
24 my $client = PerlACE
::TestTarget
::create_target
(2) || die "Create target 2 failed\n";
26 my $iorbase = "test.ior";
27 my $server_iorfile = $server->LocalFile ($iorbase);
28 my $client_iorfile = $client->LocalFile ($iorbase);
29 $server->DeleteFile($iorbase);
30 $client->DeleteFile($iorbase);
32 $SV = $server->CreateProcess ("server",
33 "-ORBdebuglevel $debug_level " .
34 "-o $server_iorfile");
36 $CL = $client->CreateProcess ("client",
37 "-i $iterations -b $burst" .
38 "-k file://$client_iorfile");
39 $server_status = $SV->Spawn ();
41 if ($server_status != 0) {
42 print STDERR
"ERROR: server returned $server_status\n";
46 if ($server->WaitForFileTimed ($iorbase,
47 $server->ProcessStartWaitInterval()) == -1) {
48 print STDERR
"ERROR: cannot find file <$server_iorfile>\n";
49 $SV->Kill (); $SV->TimedWait (1);
53 if ($server->GetFile ($iorbase) == -1) {
54 print STDERR
"ERROR: cannot retrieve file <$server_iorfile>\n";
55 $SV->Kill (); $SV->TimedWait (1);
58 if ($client->PutFile ($iorbase) == -1) {
59 print STDERR
"ERROR: cannot set file <$client_iorfile>\n";
60 $SV->Kill (); $SV->TimedWait (1);
64 $client_status = $CL->SpawnWaitKill ($client->ProcessStartWaitInterval() + 225);
66 if ($client_status != 0) {
67 print STDERR
"ERROR: client returned $client_status\n";
71 $server_status = $SV->WaitKill ($server->ProcessStopWaitInterval());
73 if ($server_status != 0) {
74 print STDERR
"ERROR: server returned $server_status\n";
78 $server->DeleteFile($iorbase);
79 $client->DeleteFile($iorbase);