1 eval '(exit $?0)' && eval 'exec perl -S $0 ${1+"$@"}'
2 & eval 'exec perl -S $0 $argv:q'
7 use lib
"$ENV{ACE_ROOT}/bin";
8 use PerlACE
::TestTarget
;
19 my $ns = PerlACE
::TestTarget
::create_target
(1) || die "Create target 1 failed\n";
20 my $nfs = PerlACE
::TestTarget
::create_target
(2) || die "Create target 2 failed\n";
21 my $sup = PerlACE
::TestTarget
::create_target
(3) || die "Create target 3 failed\n";
22 my $con = PerlACE
::TestTarget
::create_target
(4) || die "Create target 4 failed\n";
24 $sup->AddLibPath ('../lib');
25 $con->AddLibPath ('../lib');
31 $ns_port = $ns->RandomPort ();
32 $ns_host = $ns->HostName ();
34 $supiorfile = "supplier.ior";
35 $nfsiorfile = "notify.ior";
36 $nfsconffile = "notify$PerlACE::svcconf_ext";
37 $nfs2conffile = "notify2$PerlACE::svcconf_ext";
39 my $nfs_nfsiorfile = $nfs->LocalFile ($nfsiorfile);
40 my $nfs_nfsconffile = $nfs->LocalFile ($nfsconffile);
41 my $nfs_nfs2conffile = $nfs->LocalFile ($nfs2conffile);
42 my $sup_supiorfile = $sup->LocalFile ($supiorfile);
43 my $con_supiorfile = $con->LocalFile ($supiorfile);
44 $nfs->DeleteFile ($nfsiorfile);
45 $sup->DeleteFile ($supiorfile);
46 $con->DeleteFile ($supiorfile);
48 $NS = $ns->CreateProcess ("$ENV{TAO_ROOT}/orbsvcs/Naming_Service/tao_cosnaming",
49 " -ORBEndpoint iiop://$ns_host:$ns_port");
51 $NFS = $nfs->CreateProcess ("$ENV{TAO_ROOT}/orbsvcs/Notify_Service/tao_cosnotification",
52 "-ORBInitRef NameService=corbaloc::" .
53 "$ns_host:$ns_port/NameService " .
54 "-IORoutput $nfs_nfsiorfile -ORBSvcConf " .
57 $SUP = $sup->CreateProcess ("Supplier",
58 "-ORBDebugLevel $debug_level " .
59 "-ORBInitRef NameService=iioploc://" .
60 "$ns_host:$ns_port/NameService -d $domain1 ".
61 "-o $sup_supiorfile");
63 $CON = $con->CreateProcess ("Consumer");
64 $CON_Args = "-ORBInitRef NameService=corbaloc::$ns_host:" .
65 "$ns_port/NameService -f $expect_pass ".
66 "-k file://$con_supiorfile";
68 $NS_status = $NS->Spawn ();
69 if ($NS_status != 0) {
70 print STDERR
"ERROR: Name Service returned $NS_status\n";
74 $NFS_status = $NFS->Spawn ();
75 if ($NFS_status != 0) {
76 print STDERR
"ERROR: Notify Service returned $NFS_status\n";
79 if ($nfs->WaitForFileTimed ($nfsiorfile,$nfs->ProcessStartWaitInterval()+5) == -1) {
80 print STDERR
"ERROR: cannot find file <$nfs_nfsiorfile>\n";
81 $NS->Kill (); $NS->TimedWait (1);
82 $NFS->Kill (); $NFS->TimedWait (1);
86 print "************** Running Consumer 1 ************\n";
88 $SUP_status = $SUP->Spawn ();
89 if ($SUP_status != 0) {
90 print STDERR
"ERROR: Supplier returned $SUP_status\n";
93 if ($sup->WaitForFileTimed ($supiorfile,$sup->ProcessStartWaitInterval()+5) == -1) {
94 print STDERR
"ERROR: cannot find file <$sup_supiorfile>\n";
95 $SUP->Kill (); $SUP->TimedWait (1);
96 $NS->Kill (); $NS->TimedWait (1);
97 $NFS->Kill (); $NFS->TimedWait (1);
100 if ($sup->GetFile ($supiorfile) == -1) {
101 print STDERR
"ERROR: cannot retrieve file <$sup_supiorfile>\n";
102 $SUP->Kill (); $SUP->TimedWait (1);
103 $NS->Kill (); $NS->TimedWait (1);
104 $NFS->Kill (); $NFS->TimedWait (1);
107 if ($con->PutFile ($supiorfile) == -1) {
108 print STDERR
"ERROR: cannot set file <$con_suporfile>\n";
109 $SUP->Kill (); $SUP->TimedWait (1);
110 $NS->Kill (); $NS->TimedWait (1);
111 $NFS->Kill (); $NFS->TimedWait (1);
115 $CON->Arguments($CON_Args);
116 $CON_status = $CON->SpawnWaitKill ($con->ProcessStartWaitInterval()+45);
117 if ($CON_status != 0) {
118 print STDERR
"ERROR: Consumer returned $CON_status\n";
119 $SUP->Kill (); $SUP->TimedWait (1);
120 $NS->Kill (); $NS->TimedWait (1);
121 $NFS->Kill (); $NFS->TimedWait (1);
125 $SUP_status = $SUP->WaitKill ($sup->ProcessStopWaitInterval());
126 if ($SUP_status != 0) {
127 print STDERR
"ERROR: Supplier returned $SUP_status\n";
128 $NS->Kill (); $NS->TimedWait (1);
129 $NFS->Kill (); $NFS->TimedWait (1);
133 $sup->DeleteFile ($supiorfile);
134 $con->DeleteFile ($supiorfile);
136 $SUP = $sup->CreateProcess ("Supplier",
137 "-ORBDebugLevel $debug_level " .
138 "-ORBInitRef NameService=iioploc://" .
139 "$ns_host:$ns_port/NameService -d $domain2 ".
140 "-o $sup_supiorfile");
142 $CON = $con->CreateProcess ("Consumer");
143 $CON_Args = "-ORBInitRef NameService=corbaloc::$ns_host:" .
144 "$ns_port/NameService -f $expect_fail ".
145 "-k file://$con_supiorfile";
147 print "************** Running Consumer 2 ************\n";
149 $SUP_status = $SUP->Spawn ();
150 if ($SUP_status != 0) {
151 print STDERR
"ERROR: Supplier returned $SUP_status\n";
154 if ($sup->WaitForFileTimed ($supiorfile,$sup->ProcessStartWaitInterval()+5) == -1) {
155 print STDERR
"ERROR: cannot find file <$sup_supiorfile>\n";
156 $SUP->Kill (); $SUP->TimedWait (1);
157 $NS->Kill (); $NS->TimedWait (1);
158 $NFS->Kill (); $NFS->TimedWait (1);
161 if ($sup->GetFile ($supiorfile) == -1) {
162 print STDERR
"ERROR: cannot retrieve file <$sup_supiorfile>\n";
163 $SUP->Kill (); $SUP->TimedWait (1);
164 $NS->Kill (); $NS->TimedWait (1);
165 $NFS->Kill (); $NFS->TimedWait (1);
168 if ($con->PutFile ($supiorfile) == -1) {
169 print STDERR
"ERROR: cannot set file <$con_suporfile>\n";
170 $SUP->Kill (); $SUP->TimedWait (1);
171 $NS->Kill (); $NS->TimedWait (1);
172 $NFS->Kill (); $NFS->TimedWait (1);
176 $CON->Arguments($CON_Args);
177 $CON_status = $CON->SpawnWaitKill ($con->ProcessStartWaitInterval()+45);
178 if ($CON_status != 0) {
179 print STDERR
"ERROR: Consumer returned $CON_status\n";
180 $SUP->Kill (); $SUP->TimedWait (1);
181 $NS->Kill (); $NS->TimedWait (1);
182 $NFS->Kill (); $NFS->TimedWait (1);
186 $SUP_status = $SUP->WaitKill ($sup->ProcessStopWaitInterval());
187 if ($SUP_status != 0) {
188 print STDERR
"ERROR: Supplier returned $SUP_status\n";
189 $NS->Kill (); $NS->TimedWait (1);
190 $NFS->Kill (); $NFS->TimedWait (1);
194 $NFS_status = $NFS->Kill ($nfs->ProcessStopWaitInterval());
195 if ($NFS_status != 0) {
196 print STDERR
"ERROR: Notify Service returned $NFS_status\n";
197 $NS->Kill (); $NS->TimedWait (1);
201 $sup->DeleteFile ($supiorfile);
202 $con->DeleteFile ($supiorfile);
203 $nfs->DeleteFile ($nfsiorfile);
205 $NFS = $nfs->CreateProcess ("$ENV{TAO_ROOT}/orbsvcs/Notify_Service/tao_cosnotification",
206 "-ORBInitRef NameService=corbaloc::" .
207 "$ns_host:$ns_port/NameService " .
208 "-IORoutput $nfs_nfsiorfile -ORBSvcConf " .
209 "$nfs_nfs2conffile");
211 $SUP = $sup->CreateProcess ("Supplier",
212 "-ORBDebugLevel $debug_level " .
213 "-ORBInitRef NameService=iioploc://" .
214 "$ns_host:$ns_port/NameService -d $domain1 ".
215 "-o $sup_supiorfile");
217 $CON = $con->CreateProcess ("Consumer");
218 $CON_Args = "-ORBInitRef NameService=corbaloc::$ns_host:" .
219 "$ns_port/NameService -f $expect_pass ".
220 "-k file://$con_supiorfile";
223 $NFS_status = $NFS->Spawn ();
224 if ($NFS_status != 0) {
225 print STDERR
"ERROR: Notify Service returned $NFS_status\n";
228 if ($nfs->WaitForFileTimed ($nfsiorfile,$nfs->ProcessStartWaitInterval()+5) == -1) {
229 print STDERR
"ERROR: cannot find file <$nfs_nfsiorfile>\n";
230 $NS->Kill (); $NS->TimedWait (1);
231 $NFS->Kill (); $NFS->TimedWait (1);
235 print "************** Running Consumer 3 ************\n";
237 $SUP_status = $SUP->Spawn ();
238 if ($SUP_status != 0) {
239 print STDERR
"ERROR: Supplier returned $SUP_status\n";
242 if ($sup->WaitForFileTimed ($supiorfile,$sup->ProcessStartWaitInterval()+5) == -1) {
243 print STDERR
"ERROR: cannot find file <$sup_supiorfile>\n";
244 $SUP->Kill (); $SUP->TimedWait (1);
245 $NS->Kill (); $NS->TimedWait (1);
246 $NFS->Kill (); $NFS->TimedWait (1);
249 if ($sup->GetFile ($supiorfile) == -1) {
250 print STDERR
"ERROR: cannot retrieve file <$sup_supiorfile>\n";
251 $SUP->Kill (); $SUP->TimedWait (1);
252 $NS->Kill (); $NS->TimedWait (1);
253 $NFS->Kill (); $NFS->TimedWait (1);
256 if ($con->PutFile ($supiorfile) == -1) {
257 print STDERR
"ERROR: cannot set file <$con_suporfile>\n";
258 $SUP->Kill (); $SUP->TimedWait (1);
259 $NS->Kill (); $NS->TimedWait (1);
260 $NFS->Kill (); $NFS->TimedWait (1);
264 $CON->Arguments($CON_Args);
265 $CON_status = $CON->SpawnWaitKill ($con->ProcessStartWaitInterval()+45);
266 if ($CON_status != 0) {
267 print STDERR
"ERROR: Consumer returned $CON_status\n";
268 $SUP->Kill (); $SUP->TimedWait (1);
269 $NS->Kill (); $NS->TimedWait (1);
270 $NFS->Kill (); $NFS->TimedWait (1);
274 $SUP_status = $SUP->WaitKill ($sup->ProcessStopWaitInterval());
275 if ($SUP_status != 0) {
276 print STDERR
"ERROR: Supplier returned $SUP_status\n";
277 $NS->Kill (); $NS->TimedWait (1);
278 $NFS->Kill (); $NFS->TimedWait (1);
282 $sup->DeleteFile ($supiorfile);
283 $con->DeleteFile ($supiorfile);
285 $SUP = $sup->CreateProcess ("Supplier",
286 "-ORBDebugLevel $debug_level " .
287 "-ORBInitRef NameService=iioploc://" .
288 "$ns_host:$ns_port/NameService -d $domain2 ".
289 "-o $sup_supiorfile");
291 $CON = $con->CreateProcess ("Consumer");
292 $CON_Args = "-ORBInitRef NameService=corbaloc::$ns_host:" .
293 "$ns_port/NameService -f $expect_pass ".
294 "-k file://$con_supiorfile";
296 print "************** Running Consumer 4 ************\n";
298 $SUP_status = $SUP->Spawn ();
299 if ($SUP_status != 0) {
300 print STDERR
"ERROR: Supplier returned $SUP_status\n";
303 if ($sup->WaitForFileTimed ($supiorfile,$sup->ProcessStartWaitInterval()+5) == -1) {
304 print STDERR
"ERROR: cannot find file <$sup_supiorfile>\n";
305 $SUP->Kill (); $SUP->TimedWait (1);
306 $NS->Kill (); $NS->TimedWait (1);
307 $NFS->Kill (); $NFS->TimedWait (1);
310 if ($sup->GetFile ($supiorfile) == -1) {
311 print STDERR
"ERROR: cannot retrieve file <$sup_supiorfile>\n";
312 $SUP->Kill (); $SUP->TimedWait (1);
313 $NS->Kill (); $NS->TimedWait (1);
314 $NFS->Kill (); $NFS->TimedWait (1);
317 if ($con->PutFile ($supiorfile) == -1) {
318 print STDERR
"ERROR: cannot set file <$con_suporfile>\n";
319 $SUP->Kill (); $SUP->TimedWait (1);
320 $NS->Kill (); $NS->TimedWait (1);
321 $NFS->Kill (); $NFS->TimedWait (1);
325 $CON->Arguments($CON_Args);
326 $CON_status = $CON->SpawnWaitKill ($con->ProcessStartWaitInterval()+45);
327 if ($CON_status != 0) {
328 print STDERR
"ERROR: Consumer returned $CON_status\n";
332 $SUP_status = $SUP->WaitKill ($sup->ProcessStopWaitInterval());
333 if ($SUP_status != 0) {
334 print STDERR
"ERROR: Supplier returned $SUP_status\n";
338 $NFS_status = $NFS->Kill ($nfs->ProcessStopWaitInterval());
339 if ($NFS_status != 0) {
340 print STDERR
"ERROR: Notify Service returned $NFS_status\n";
344 $NS_status = $NS->TerminateWaitKill ($ns->ProcessStopWaitInterval());
345 if ($NS_status != 0) {
346 print STDERR
"ERROR: Naming Service returned $NS_status\n";
350 $nfs->DeleteFile ($nfsiorfile);
351 $sup->DeleteFile ($supiorfile);
352 $con->DeleteFile ($supiorfile);