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 = '50000';
20 print STDERR
"================ Single-threaded (default) 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";
27 $server_defaultconf = $server->LocalFile ("default$PerlACE::svcconf_ext");
28 $client_defaultconf = $client->LocalFile ("default$PerlACE::svcconf_ext");
30 my $server_iorfile = $server->LocalFile ($iorbase);
31 my $client_iorfile = $client->LocalFile ($iorbase);
32 $server->DeleteFile($iorbase);
33 $client->DeleteFile($iorbase);
35 $SV = $server->CreateProcess ("server", "-ORBdebuglevel $debug_level -o $server_iorfile " .
36 "-ORBSvcConf $server_defaultconf");
37 $CL = $client->CreateProcess ("client", "-k file://$client_iorfile " .
39 "-ORBSvcConf $client_defaultconf");
41 $server_status = $SV->Spawn ();
43 if ($server_status != 0) {
44 print STDERR
"ERROR: server returned $server_status\n";
48 if ($server->WaitForFileTimed ($iorbase,
49 $server->ProcessStartWaitInterval()) == -1) {
50 print STDERR
"ERROR: cannot find file <$server_iorfile>\n";
51 $SV->Kill (); $SV->TimedWait (1);
55 if ($server->GetFile ($iorbase) == -1) {
56 print STDERR
"ERROR: cannot retrieve file <$server_iorfile>\n";
57 $SV->Kill (); $SV->TimedWait (1);
60 if ($client->PutFile ($iorbase) == -1) {
61 print STDERR
"ERROR: cannot set file <$client_iorfile>\n";
62 $SV->Kill (); $SV->TimedWait (1);
66 $client_status = $CL->SpawnWaitKill ($client->ProcessStartWaitInterval() + 45);
68 if ($client_status != 0) {
69 print STDERR
"ERROR: client returned $client_status\n";
73 $server_status = $SV->WaitKill ($server->ProcessStopWaitInterval());
75 if ($server_status != 0) {
76 print STDERR
"ERROR: server returned $server_status\n";
80 $server->DeleteFile($iorbase);
81 $client->DeleteFile($iorbase);