diff options
Diffstat (limited to 'ACE/TAO/tests/CSD_Strategy_Tests/TP_Test_Static/run_test.pl')
-rwxr-xr-x | ACE/TAO/tests/CSD_Strategy_Tests/TP_Test_Static/run_test.pl | 122 |
1 files changed, 122 insertions, 0 deletions
diff --git a/ACE/TAO/tests/CSD_Strategy_Tests/TP_Test_Static/run_test.pl b/ACE/TAO/tests/CSD_Strategy_Tests/TP_Test_Static/run_test.pl new file mode 100755 index 00000000000..d0a8f1cbd47 --- /dev/null +++ b/ACE/TAO/tests/CSD_Strategy_Tests/TP_Test_Static/run_test.pl @@ -0,0 +1,122 @@ +eval '(exit $?0)' && eval 'exec perl -S $0 ${1+"$@"}' + & eval 'exec perl -S $0 $argv:q' + if 0; + +# $Id$ +# -*- perl -*- + +use lib "$ENV{ACE_ROOT}/bin"; +use PerlACE::TestTarget; + +$status = 0; +$debug_level = '0'; + +foreach $i (@ARGV) { + if ($i eq '-debug') { + $debug_level = '10'; + } +} + +my $server = PerlACE::TestTarget::create_target (1) || die "Create target 1 failed\n"; + +$server->AddLibPath ('../TP_Foo_A/.'); +$server->AddLibPath ('../TP_Foo_B/.'); +$server->AddLibPath ('../TP_Foo_C/.'); +$server->AddLibPath ('../TP_Common/.'); + +my $iorbase = "server.ior"; +my $num_clients = 40; + +my $server_iorfile = $server->LocalFile ($iorbase); +$server->DeleteFile($iorbase); + +$SV = $server->CreateProcess ("server_main", "-ORBdebuglevel $debug_level ". + "-o $server_iorfile -n $num_clients"); + +@clients = (); +@CLS = (); +@clients_iorfile = (); + +for ($i = 0; $i < $num_clients; $i++) { + $clients[$i] = PerlACE::TestTarget::create_target ($i+1) || die "Create target $i+1 failed\n"; + + $clients_iorfile[$i] = $clients[$i]->LocalFile ($iorbase); + $clients[$i]->DeleteFile($iorbase); + + $CLS[$i] = $clients[$i]->CreateProcess ("client_main", "-k file://$clients_iorfile[$i]"); +} + +$server_status = $SV->Spawn (); + +if ($server_status != 0) { + print STDERR "ERROR: server returned $server_status\n"; + exit 1; +} + +if ($server->WaitForFileTimed ($iorbase, + $server->ProcessStartWaitInterval()) == -1) { + print STDERR "ERROR: cannot find file <$server_iorfile>\n"; + $SV->Kill (); $SV->TimedWait (1); + exit 1; +} + +if ($server->GetFile ($iorbase) == -1) { + print STDERR "ERROR: cannot retrieve file <$server_iorfile>\n"; + $SV->Kill (); $SV->TimedWait (1); + exit 1; +} + + +for ($i = 0; $i < $num_clients; $i++) { + if ($clients[$i]->PutFile ($iorbase) == -1) { + print STDERR "ERROR: cannot set file <$clients_iorfile[$i]>\n"; + $i = $num_clients; $status = 1; + } +} + +if ($status != 0) { + $SV->Kill (); $SV->TimedWait (1); + exit $status; +} + +my $broken_number = 0; +for ($i = 0; $i < $num_clients; $i++) { + $client_status = $CLS[$i]->Spawn (); + + if ($client_status != 0) { + print STDERR "ERROR: client $i returned $client_status\n"; + $broken_number = $i; $i = $num_clients; $status = 1; + } +} + +if ($status != 0) { + for ($i = 0; $i < $broken_number; $i++) { + $CLS[$i] = Kill (); + } + + $SV->Kill (); $SV->TimedWait (1); + exit $status; +} + +for ($i = 0; $i < $num_clients; $i++) { + $client_status = $CLS[$i]->WaitKill ($clients[$i]->ProcessStartWaitInterval() + 45); + + if ($client_status != 0) { + print STDERR "ERROR: client $i returned $client_status\n"; + $status = 1; + } +} + +$server_status = $SV->WaitKill ($server->ProcessStopWaitInterval() + 45); + +if ($server_status != 0) { + print STDERR "ERROR: server returned $server_status\n"; + $status = 1; +} + +$server->DeleteFile($iorbase); +for ($i = 0; $i < $num_clients; $i++) { + $clients[$i]->DeleteFile($iorbase); +} + +exit $status; |