run_test.pl
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· PL 代码 · 共 83 行
PL
83 行
eval '(exit $?0)' && eval 'exec perl -S $0 ${1+"$@"}'
& eval 'exec perl -S $0 $argv:q'
if 0;
# run_test.pl,v 1.5 2002/03/14 20:13:46 elliott_c Exp
# -*- perl -*-
use lib '../../../bin';
use PerlACE::Run_Test;
$iorfile = PerlACE::LocalFile ("server.ior");
unlink $iorfile;
use Getopt::Std;
local ($opt_i);
if (!getopts ('i:')) {
print "Usage: run_test.pl [-i iterations]\n";
exit 1;
}
$status = 0;
my $iterations = 40;
if (defined $opt_i) {
$iterations = $opt_i;
}
$SV = new PerlACE::Process ("server", "-o $iorfile");
$SV->Spawn ();
if (PerlACE::waitforfile_timed ($iorfile, 10) == -1) {
print STDERR "ERROR: cannot find file <$iorfile>\n";
$SV->Kill (); $SV->TimedWait (1);
exit 1;
}
$count = 0;
for ($i = 0; $i != $iterations; $i++) {
# First spawn all the processes
my @CL = ();
my $concurrent_clients = 30;
for ($j = 0; $j != $concurrent_clients; $j++) {
$CL[$j] = new PerlACE::Process ("client", " -k file://$iorfile");
$CL[$j]->Spawn ();
$count++;
}
# Now wait for each one
for ($j = 0; $j != $concurrent_clients; $j++) {
$client = $CL[$j]->WaitKill (5);
if ($client != 0) {
print STDERR "ERROR: client $j returned $client in iteration $i\n";
$status = 1;
}
}
if ($count % 100 == 0) {
print STDERR "Iteration $i has created $count clients\n";
}
}
$CL = new PerlACE::Process ("client", " -k file://$iorfile -x");
$client = $CL->SpawnWaitKill (20);
if ($client != 0) {
print STDERR "ERROR: client returned $client during test shutdown\n";
$status = 1;
}
$server = $SV->WaitKill (10);
if ($server != 0) {
print STDERR "ERROR: server returned $server\n";
$status = 1;
}
unlink $iorfile;
exit $status;
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?