X-Git-Url: https://git.teslayout.com/public/public/public/?a=blobdiff_plain;f=example%2Fdiameter%2Flauncher%2FDEPLOY.sh;h=7ea9942f18581bb0e8c2e6786c7139e22df64c3e;hb=f548ce5889cd69ed0c9fb17e2dccf47fbeb41784;hp=906a0b2de2bfcc684af66da913b156998a0c36f8;hpb=127e9289b0f410f51a364ac887b6ab7ec58ec6d7;p=anna.git diff --git a/example/diameter/launcher/DEPLOY.sh b/example/diameter/launcher/DEPLOY.sh index 906a0b2..7ea9942 100755 --- a/example/diameter/launcher/DEPLOY.sh +++ b/example/diameter/launcher/DEPLOY.sh @@ -3,32 +3,21 @@ ############# # VARIABLES # ############# -SETUPS_DIR=../../../source/diameter/stack/setups -MSGDTD=../../../include/anna/diameter/codec/message.dtd -DCTDTD=../../../include/anna/diameter/stack/dictionary.dtd -SERVICES=./resources/services_examples -STACK_EXAMPLES=./resources/stack_examples +SCR_DIR=`readlink -f $(dirname $0)` +PROJECT_ROOT=$(readlink -f ../../..) +SETUPS_DIR=$PROJECT_ROOT/source/diameter/stack/setups +MSGDTD=$PROJECT_ROOT/include/anna/diameter/codec/message.dtd +DCTDTD=$PROJECT_ROOT/include/anna/diameter/stack/dictionary.dtd +SERVICES=$SCR_DIR/resources/services_examples +STACK_EXAMPLES=$SCR_DIR/resources/stack_examples SRVDTD=$SERVICES/services.dtd - -# Executables in priority order: -EXEC_installed=/opt/bin/anna/example_diameter_launcher -EXECS=( $EXEC_installed ./release/example_diameter_launcher ./debug/example_diameter_launcher ) - -# Stack management -STACKMGMT_EXEC_installed=/opt/bin/anna/example_diameter_stackManagement -STACKMGMT_EXECS=( $STACKMGMT_EXEC_installed ../stackManagement/release/example_diameter_stackManagement ../stackManagement/debug/example_diameter_stackManagement ) - -# Dynamic library: -DYNLIB_installed=/usr/local/lib/libanna_dynamicLauncherProcedure.so -DYNLIBS=( $DYNLIB_installed ../../../dynamic/launcher/default/release/libanna_dynamicLauncherProcedure.so ../../../dynamic/launcher/default/debug/libanna_dynamicLauncherProcedure.so ) +VARIANT= ############# # FUNCTIONS # ############# _exit () { - echo - echo $1 - echo + echo -e "\n$1\n" exit 1 } @@ -74,7 +63,7 @@ STARTED=\`pgrep \$EXE$ 2>/dev/null\` 0> launcher.trace rm -f counters/* test-reports/* # Execution line: -export LD_LIBRARY_PATH=\$PWD +export LD_LIBRARY_PATH=\$PWD/dynlibs ./\$EXE --services services.xml --cntDir counters --tmDir test-reports $other & echo \$! > .pid EOF @@ -85,7 +74,8 @@ EOF ############# # EXECUTION # ############# -cd `dirname $0` +cd $SCR_DIR + echo echo "---------------------------------------" echo "Anna Diameter Launcher (ADML) deployment" @@ -95,33 +85,13 @@ echo " (--help or -h for more info)" echo echo "Basic checkings ..." -# Launcher executable: -available= -for EXEC in ${EXECS[@]}; do - echo -n "Looking executable at '$EXEC' ... " - [ -x $EXEC ] && { available=yes ; echo "available !" ; break ; } - echo "not found" -done -[ -z "$available" ] && _exit "Anna Diameter Launcher (ADML) is not installed neither linked. See README.md (Install section)." - -# Dictionary creation: -available= -for STACKMGMT_EXEC in ${STACKMGMT_EXECS[@]}; do - echo -n "Looking stack management executable at '$STACKMGMT_EXEC' ... " - [ -x $STACKMGMT_EXEC ] && { available=yes ; echo "available !" ; break ; } - echo "not found" -done -[ -z "$available" ] && _exit "Anna Diameter Stack Management Tool is not installed neither linked. See README.md (Install section)." -STACKMGMT_EXEC=`readlink -f $STACKMGMT_EXEC` - -# Dynamic library: -available= -for DYNLIB in ${DYNLIBS[@]}; do - echo -n "Looking dynamic library at '$DYNLIB' ... " - [ -x $DYNLIB ] && { available=yes ; echo "available !" ; break ; } - echo "not found" -done -[ -z "$available" ] && _exit "Anna Diameter Launcher Dynamic Procedure Library (ADML) is not installed neither linked. See README.md (Install section)." +# Get variant and main executables: +[ -f $SCR_DIR/release/example_diameter_launcher ] && VARIANT=release +[ -f $SCR_DIR/debug/example_diameter_launcher ] && VARIANT=debug +[ -z "$VARIANT" ] && _exit "Cannot locate neither 'release' nor 'debug' variant !" +echo "Variant: $VARIANT" +ADML_EXEC=$SCR_DIR/$VARIANT/example_diameter_launcher +STACKMGMT_EXEC=$(readlink -f $SCR_DIR/../stackManagement/$VARIANT/example_diameter_stackManagement) [ ! -d $SETUPS_DIR ] && _exit "Diameter stacks not found ($SETUPS_DIR)." @@ -192,26 +162,50 @@ mkdir -p $DPATH/stacks mkdir -p $DPATH/DTDs mkdir -p $DPATH/counters mkdir -p $DPATH/test-reports -cp $DYNLIB $DPATH -[ "$option" = "b" ] && mkdir -p $DPATH/services +# Dynamic libs: +mkdir -p $DPATH/dynlibs +DYNLIBS=( $(find $PROJECT_ROOT -name "*.so" | grep -w $VARIANT) ) + +for dynlib in ${DYNLIBS[@]} +do + dynlib_bn=$(basename $dynlib) + if [ "$dynlib_bn" != "libanna_dynamicLauncherProcedure.so" ] + then + cp $dynlib $DPATH/dynlibs + else + ########## ADML Dynamic libs system ########## + # Create structure from $PROJECT_ROOT/dynamic/launcher + suffix_path=$(echo $dynlib | awk -F"$PROJECT_ROOT/dynamic/launcher/" '{ print $2 }') + target=$(dirname $DPATH/dynlibs/$(dirname $suffix_path)) + mkdir -p $target + cp $dynlib $target + + # Additional resources + dynlib_dn=$(dirname $dynlib) + dynlib_dn_dn=$(dirname $dynlib_dn) + cp $dynlib_dn_dn/*.xml $target 2>/dev/null + cp $dynlib_dn_dn/dynamic.suffix $target 2>/dev/null + cp -r $dynlib_dn_dn/services $target 2>/dev/null + fi +done -# ADML executable: -if [ "$EXEC" = "$EXEC_installed" ] -then - ln -s $EXEC_installed $DPATH/ADML-launcher -else - cp $EXEC $DPATH/ADML-launcher -fi +# ADML dynamic libs selection script: +cp $SCR_DIR/resources/scripts/select_dynlib.sh $DPATH/dynlibs/select.sh -# Stack management tool: -if [ "$STACKMGMT_EXEC" = "$STACKMGMT_EXEC_installed" ] -then - ln -s $STACKMGMT_EXEC_installed $DPATH/stacks/stack-mgmt -fi -# Copy binary just in case: +# Default dynamic library: +cd $DPATH/dynlibs +ln -s default/libanna_dynamicLauncherProcedure.so +cd - >/dev/null + +# Basic setup: +[ "$option" = "b" ] && mkdir -p $DPATH/services + +# Copy executables: +cp $ADML_EXEC $DPATH/ADML-launcher [ ! -f $DPATH/stacks/stack-mgmt ] && cp $STACKMGMT_EXEC $DPATH/stacks/stack-mgmt +# Copy resources: cp -rL $DEPLOYMENTS_DIR/* $DPATH cp $SETUPS_DIR/*xml $DPATH/stacks cp $SETUPS_DIR/*sh $DPATH/stacks @@ -230,12 +224,20 @@ stacks/makeAutonomous.sh commands_qosControl.xml stacks/stack-mgmt >/dev/null ln -s stacks/autonomous.commands_qosControl.xml dictionary.xml cd - >/dev/null +if [ "$option" = "s" ] +then + cd $DPATH + ln -s services_example services + mv run.sh .run-one.sh + mv run_all.sh run.sh + mv operation.sh .operation-one.sh + mv operation_all.sh operation.sh + rm dictionary.xml + cd - >/dev/null +fi + # Help: +echo "Done !" +echo "(see README at '$DPATH')" echo -echo "Go to '$DPATH' and see README file" -echo -echo "Done!" -echo -echo -