diff options
Diffstat (limited to 'TAO/orbsvcs/tests/AVStreams/Bidirectional_Flows/run_test.pl')
-rwxr-xr-x | TAO/orbsvcs/tests/AVStreams/Bidirectional_Flows/run_test.pl | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/TAO/orbsvcs/tests/AVStreams/Bidirectional_Flows/run_test.pl b/TAO/orbsvcs/tests/AVStreams/Bidirectional_Flows/run_test.pl new file mode 100755 index 00000000000..2b53d1e8f49 --- /dev/null +++ b/TAO/orbsvcs/tests/AVStreams/Bidirectional_Flows/run_test.pl @@ -0,0 +1,77 @@ +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::Run_Test; +use File::stat; + +# amount of delay between running the servers + +$sleeptime = 2; +$status = 0; + +$nsior = PerlACE::LocalFile ("ns.ior"); +$outfile = PerlACE::LocalFile ("output"); + +# generate test stream data +$input = PerlACE::generate_test_file("test_input", 102400); + +unlink $nsior; + +$NS = new PerlACE::Process ($ENV{"TAO_ROOT"}."/orbsvcs/Naming_Service/Naming_Service", "-o $nsior"); +$SV = new PerlACE::Process ("receiver", "-ORBInitRef NameService=file://$nsior -f output"); +$CL = new PerlACE::Process ("sender", "-ORBInitRef NameService=file://$nsior -f $input -r 2"); + +print STDERR "Starting Naming Service\n"; + +$NS->Spawn (); + +if (PerlACE::waitforfile_timed ($nsior, 5) == -1) { + print STDERR "ERROR: cannot find naming service IOR file\n"; + $NS->Kill (); + exit 1; +} + +print STDERR "Starting Receiver\n"; + +$RE1_result = $SV->Spawn (); + +if ($RE1_result != 0) { + print STDERR "ERROR: Receiver returned $RE1_result\n"; + $NS->Kill (); + exit 1; +} + +sleep $sleeptime; + +print STDERR "Starting Sender\n"; + +$sender = $CL->SpawnWaitKill (200); + +if ($sender != 0) { + print STDERR "ERROR: sender returned $sender\n"; + $status = 1; +} + +$receiver = $SV->TerminateWaitKill (5); + +if ($receiver != 0) { + print STDERR "ERROR: receiver returned $receiver\n"; + $status = 1; +} + +$nserver = $NS->TerminateWaitKill (5); + +if ($nserver != 0) { + print STDERR "ERROR: Naming Service returned $nserver\n"; + $status = 1; +} + +unlink $nsior; +unlink $output, $input; + +exit $status; |