summaryrefslogtreecommitdiff
path: root/TAO/tests/LongWrites/run_test.pl
blob: eae2e6aaf7f4fc50456ef264121e05b1fa8ba980 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
eval '(exit $?0)' && eval 'exec perl -S $0 ${1+"$@"}'
     & eval 'exec perl -S $0 $argv:q'
     if 0;

# $Id$
# -*- perl -*-

use lib '../../../bin';
use PerlACE::Run_Test;
use Cwd;
use Getopt::Std;

my $iorfile = PerlACE::LocalFile ("test.ior");
unlink $iorfile;

local ($opt_i, $opt_p);

if (!getopts ('i:p:')) {
    print "Usage: run_test.pl [-p payload_size] [-i iterations]\n";
    exit 1;
}

my $server_args = "";
if (defined $opt_i) {
    $server_args .= " -i ".$opt_i;
}
if (defined $opt_p) {
    $server_args .= " -p ".$opt_p;
}

foreach my $i ("ONEWAY", "WRITE", "READ_WRITE") {

  print "================ Running test $i ================\n";

  my $SV = new PerlACE::Process ("server", "-o $iorfile $server_args");

  $SV->Spawn ();

  if (PerlACE::waitforfile_timed ($iorfile, 10) == -1) {
    print STDERR "ERROR: cannot find file <$iorfile>\n";
    $SV->Kill (); $SV->TimedWait (1);
    exit 1;
  }

  $CL1 = new PerlACE::Process ("client", " -k file://$iorfile -t $i");
  $CL2 = new PerlACE::Process ("client", " -k file://$iorfile -t $i");
  $CL3 = new PerlACE::Process ("client", " -k file://$iorfile -t $i");

  $CL1->Spawn ();
  $CL2->Spawn ();
  $CL3->Spawn ();

  $client1 = $CL1->WaitKill (120);
  $client2 = $CL2->WaitKill (120);
  $client3 = $CL3->WaitKill (120);
  $server = $SV->WaitKill (5);

  unlink $iorfile;
  
  if ($server != 0
      || $client1 != 0 || $client2 != 0 || $client3 != 0) {
    print "ERROR: non-zero status returned by the server or clients\n";
    print "ERROR: server = $server, client1 = $client1, client2 = $client2, client3 = $client3\n";
    exit 1;
  }
}

exit 0;