📄 run_test_registry.pl
字号:
eval '(exit $?0)' && eval 'exec perl -S $0 ${1+"$@"}'
& eval 'exec perl -S $0 $argv:q'
if 0;
# run_test_registry.pl,v 1.2 2003/12/22 01:44:39 wilson_d Exp
# -*- perl -*-
# Purpose:
# To test the FactoryRegistry either as a stand-alone application or as part
# of the replication manager
#
# Command line options:
# --debug_build use exes from this directory
# if not specified use exes from ./release
# -r use ReplicationManager rather than stand-alone factory
# --no_simulate
# use real IOGR-based recovery.
# -v display test progress messages (repeating option increases verbosity
#
# Process being tested:
# FT_Registry
# implements PortableGroup::FactoryRegistry interface.
# or
# FT_ReplicationManager (if -r option is used)
#
# Processes used in test:
# FT_Replica * 3
# implements GenericFactory interface to create TestReplicas
# TestReplica implements TestReplica interface.
# TestReplica implements PullMonitorable interface.
# FT_Client
# client for TestReplica interface.
# client for PullMonitorable.
# Object Group Creator
# Creates groups of objects.
#
# Test Scenario (***Test: marks behavior being tested):
#
# First the test starts a factory registry,
# Then starts three factories. Each factory exists at a separate location.
# The locations are named shire, bree, and rivendell. In a "real" system
# these locations would be on separate computers.
#
# The factory at the shire location knows how to create hobbits.
# The factory at the bree location knows how to create hobbits, elves, and humans.
# The factory at rivendell can create elves.
# Hobbits, elves, and humans are actually TestReplica objects. A creation parameter
# included as part of the registration information specifies which species they are.
#
# ***Test: The factories register themselves with the factory registry. Registration
# information includes the location, the type of object created, a object reference
# to the factory and set of parameters to be passed to the factory's create_object
# method.
#
# An object group creator is started and asked to create three object groups:
# a group of hobbits, a group of elves; and another group of hobbits.
#
# ***Test: the object group creator asks the registry for the set of factories
# that can create the type of object needed, then uses the create_object method
# for each factory to create the actual object.
#
# [temporary until IOGR's are working: The object group creator writes the
# IOR's of the create objects to files -- using a file naming convention to
# distinguish members of the group. It will be enhanced to assemble these
# IORs into an IOGR and either write the IOGR to a file or register it with
# the Naming Service.]
#
# The object group creator is also told to unregister all factories that create humans.
# ***Test: It does so using the unregister_factory_by_type method.
#
# Three clients are started, one at a time. Each client is given a reference
# to an object group
#
# [temporary until IOGRs and transparent reinvocaton work: each client is
# given references to the members of the group and manages its own recovery
# (client mediated fault tolerance)]
#
# Each client sends a few requests to first member of the object group. Eventually
# this member fails and the requests are then rerouted to the second (and last)
# member of the group.
#
# When a clients job is done, it exits and asks the remaining group member to
# exit, too.
#
# The factories are run with the quit-on-idle option so when the last object
# created at that location goes away, the factory exits.
#
# ***Test: As it exits the factory unregisters itself with the factory registry.
# ***Test: A command line option determines whether it uses a single
# unregister_factory_by_location call, or separate unregister_factory calles for
# each type of object created. In this test, the shire location uses unregister_factory,
# and bree and rivendell use unregister_factory_by_location.
#
# The factory registry is also run with the quit-on-idle option so when the last
# factory unregisters itself, the factory registry shuts down to end the test.
use lib '../../../../bin';
#use lib '$ENV{ACE_ROOT}/bin';
use PerlACE::Run_Test;
########################
#command line options
#set defaults:
my($verbose) = 0; # 1: report perl actions before executing them
my($debug_builds) = 0; # 0: use exes from Release directories
my($simulated) = 1; # 1: use "client simulated" fault tolerance
my($use_rm) = 0; # 1: use replication manager; 0 use stand-alone factory registry
foreach $i (@ARGV) {
if ($i eq "--debug_build")
{
$debug_builds = 1;
}
elsif ($i eq "-r") # use RegistrationManager
{
$use_rm = 1
}
elsif ($i eq "--no_simulate") # reverse this once we have FT ORB support
{
$simulated = 0;
}
elsif ($i eq "-v")
{
$verbose += 1;
}
else
{
print "unknown option $i. Expecting: --debug_build, -r --no_simulate, -v\n";
exit(-1);
}
}
my($build_directory) = "/Release";
if ( $debug_builds ) {
$build_directory = "";
}
if ( $verbose > 1) {
print "verbose: $verbose\n";
print "debug_builds: $debug_builds -> $build_directory\n";
print "simulated: $simulated\n";
}
my($species1) = "hobbit";
my($species2) = "elf";
my($species3) = "human";
my($location1) = "shire";
my($location2) = "bree";
my($location3) = "rivendell";
my($location4) = "rohan";
#define temp files
my($rm_ior) = PerlACE::LocalFile ("rm.ior");
my($registry_ior) = PerlACE::LocalFile ("registry.ior");
my($factory1_ior) = PerlACE::LocalFile ("factory1.ior");
my($factory2_ior) = PerlACE::LocalFile ("factory2.ior");
my($factory3_ior) = PerlACE::LocalFile ("factory3.ior");
my($replica1_ior) = PerlACE::LocalFile ("${species1}_${location1}_0.ior");
my($replica2_ior) = PerlACE::LocalFile ("${species1}_${location2}_0.ior");
my($replica3_ior) = PerlACE::LocalFile ("${species2}_${location2}_1.ior");
my($replica4_ior) = PerlACE::LocalFile ("${species2}_${location3}_0.ior");
my($replica5_ior) = PerlACE::LocalFile ("${species1}_${location1}_1.ior");
my($replica6_ior) = PerlACE::LocalFile ("${species1}_${location2}_2.ior");
my($replica1_iogr) = PerlACE::LocalFile ("${species1}_0.iogr");
my($replica2_iogr) = PerlACE::LocalFile ("${species2}_1.iogr");
my($replica3_iogr) = PerlACE::LocalFile ("${species1}_2.iogr");
my($client_data) = PerlACE::LocalFile ("persistent.dat");
#discard junk from previous tests
unlink $rm_ior;
unlink $registry_ior;
unlink $factory1_ior;
unlink $factory2_ior;
unlink $factory3_ior;
unlink $replica1_ior;
unlink $replica2_ior;
unlink $replica3_ior;
unlink $replica4_ior;
unlink $replica5_ior;
unlink $replica6_ior;
unlink $replica1_iogr;
unlink $replica2_iogr;
unlink $client_data;
my($status) = 0;
my ($rm_endpoint) = "-ORBEndpoint iiop://localhost:2833";
my ($registry_opt) = "-f file://$registry_ior";
if ($use_rm) {
$registry_opt = "-ORBInitRef ReplicationManager=corbaloc::localhost:2833/ReplicationManager";
}
my($RM) = new PerlACE::Process ("$ENV{'TAO_ROOT'}/orbsvcs/FT_ReplicationManager$build_directory/FT_ReplicationManager", "-ORBDebugLevel 0 -o $rm_ior $rm_endpoint");
my($RMC) = new PerlACE::Process (".$build_directory/replmgr_controller", "$registry_opt -x");
my($REG) = new PerlACE::Process (".$build_directory/ft_registry", "-o $registry_ior -q");
my($FAC1) = new PerlACE::Process (".$build_directory/ft_replica", "-o $factory1_ior $registry_opt -l $location1 -i $species1 -q");
my($FAC2) = new PerlACE::Process (".$build_directory/ft_replica", "-o $factory2_ior $registry_opt -l $location2 -i $species1 -i $species2 -i $species3 -q -u");
my($FAC3) = new PerlACE::Process (".$build_directory/ft_replica", "-o $factory3_ior $registry_opt -l $location3 -i $species2 -q -u");
# -n means no name service -i means write individual iors
my($CTR) = new PerlACE::Process (".$build_directory/ft_create", "$registry_opt -r $species1 -r $species2 -r $species1 -u $species3 -n -i");
my($CL1);
my($CL2);
my($CL3);
if ($simulated)
{
print "\nTEST: Preparing Client Mediated Fault Tolerance test.\n" if ($verbose);
$CL1 = new PerlACE::Process (".$build_directory/ft_client", "-f file://$replica1_ior -f file://$replica2_ior -c testscript");
$CL2 = new PerlACE::Process (".$build_directory/ft_client", "-f file://$replica3_ior -f file://$replica4_ior -c testscript");
$CL3 = new PerlACE::Process (".$build_directory/ft_client", "-f file://$replica5_ior -f file://$replica6_ior -c testscript");
}
else
{
print "\nTEST: Preparing IOGR based test.\n" if ($verbose);
$CL1 = new PerlACE::Process (".$build_directory/ft_client", "-f file://$replica1_iogr -c testscript");
$CL2 = new PerlACE::Process (".$build_directory/ft_client", "-f file://$replica2_iogr -c testscript");
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -