ACE+TAO-6_5_17
[ACE_TAO.git] / TAO / tests / Portable_Interceptors / IORInterceptor / run_test.pl
blob1277cb4fd27bc9bfd829e12a165632faba28d07b
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 foreach $i (@ARGV) {
14 if ($i eq '-debug') {
15 $debug_level = '10';
19 my $server = PerlACE::TestTarget::create_target (1) || die "Create target 1 failed\n";
20 my $client = PerlACE::TestTarget::create_target (2) || die "Create target 2 failed\n";
22 my $iorbase = "server.ior";
23 my $server_iorfile = $server->LocalFile ($iorbase);
24 my $client_iorfile = $client->LocalFile ($iorbase);
25 $server->DeleteFile($iorbase);
26 $client->DeleteFile($iorbase);
28 $SV = $server->CreateProcess ("server", "-ORBdebuglevel $debug_level -o $server_iorfile");
29 $CL = $client->CreateProcess ("client", "-k file://$client_iorfile");
30 $server_status = $SV->Spawn ();
32 if ($server_status != 0) {
33 print STDERR "ERROR: server returned $server_status\n";
34 exit 1;
37 if ($server->WaitForFileTimed ($iorbase,
38 $server->ProcessStartWaitInterval()) == -1) {
39 print STDERR "ERROR: cannot find file <$server_iorfile>\n";
40 $SV->Kill (); $SV->TimedWait (1);
41 exit 1;
44 if ($server->GetFile ($iorbase) == -1) {
45 print STDERR "ERROR: cannot retrieve file <$server_iorfile>\n";
46 $SV->Kill (); $SV->TimedWait (1);
47 exit 1;
49 if ($client->PutFile ($iorbase) == -1) {
50 print STDERR "ERROR: cannot set file <$client_iorfile>\n";
51 $SV->Kill (); $SV->TimedWait (1);
52 exit 1;
55 $client_status = $CL->SpawnWaitKill ($server->ProcessStartWaitInterval() + 45);
57 if ($client_status != 0) {
58 print STDERR "ERROR: client returned $client_status\n";
59 $status = 1;
62 $server_status = $SV->WaitKill ($server->ProcessStopWaitInterval());
64 if ($server_status != 0) {
65 print STDERR "ERROR: server returned $server_status\n";
66 $status = 1;
69 $server->GetStderrLog();
70 $client->GetStderrLog();
72 $server->DeleteFile($iorbase);
73 $client->DeleteFile($iorbase);
75 exit $status;