X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=test%2Fauto-test%2FFTC850.sh;h=5c1c016ea4881793ced5b831c18244ef36f42ea8;hb=refs%2Fheads%2Fmaster;hp=82e50f198fc68b9985fc7bc06ecd2cc3430a880b;hpb=4f7f0cda2f07f62dcbb2e371fc09764b2337a8e9;p=nonrtric.git diff --git a/test/auto-test/FTC850.sh b/test/auto-test/FTC850.sh index 82e50f19..5c1c016e 100755 --- a/test/auto-test/FTC850.sh +++ b/test/auto-test/FTC850.sh @@ -1,7 +1,8 @@ #!/bin/bash # ============LICENSE_START=============================================== -# Copyright (C) 2020 Nordix Foundation. All rights reserved. +# Copyright (C) 2020-2023 Nordix Foundation. All rights reserved. +# Copyright (C) 2023-2024 OpenInfra Foundation Europe. All rights reserved. # ======================================================================== # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -20,24 +21,26 @@ TC_ONELINE_DESCR="Create/delete policies in parallel over a number of rics using a number of child process" #App names to include in the test when running docker, space separated list -DOCKER_INCLUDED_IMAGES="CBS CONSUL CP CR MR PA RICSIM SDNC" +DOCKER_INCLUDED_IMAGES="CP CR MR A1PMS RICSIM SDNC NGW KUBEPROXY" #App names to include in the test when running kubernetes, space separated list -KUBE_INCLUDED_IMAGES="CP CR MR PA RICSIM SDNC" -#Prestarted app (not started by script) to include in the test when running kubernetes, space separated list +KUBE_INCLUDED_IMAGES="CP CR MR A1PMS RICSIM SDNC KUBEPROXY NGW" +#Pre-started app (not started by script) to include in the test when running kubernetes, space separated list KUBE_PRESTARTED_IMAGES="" +#Ignore image in DOCKER_INCLUDED_IMAGES, KUBE_INCLUDED_IMAGES if +#the image is not configured in the supplied env_file +#Used for images not applicable to all supported profile +CONDITIONALLY_IGNORED_IMAGES="NGW" + #Supported test environment profiles -SUPPORTED_PROFILES="ONAP-GUILIN ONAP-HONOLULU ORAN-CHERRY ORAN-DAWN" +SUPPORTED_PROFILES="ONAP-KOHN ONAP-LONDON ONAP-MONTREAL ORAN-G-RELEASE ORAN-H-RELEASE ORAN-I-RELEASE" #Supported run modes SUPPORTED_RUNMODES="DOCKER KUBE" -. ../common/testcase_common.sh $@ -. ../common/agent_api_functions.sh -. ../common/ricsimulator_api_functions.sh -. ../common/mr_api_functions.sh -. ../common/control_panel_api_functions.sh -. ../common/controller_api_functions.sh +. ../common/testcase_common.sh $@ + +setup_testenvironment #### TEST BEGIN #### @@ -47,154 +50,233 @@ SUPPORTED_RUNMODES="DOCKER KUBE" # Tested variants of REST/DMAAP/SDNC config TESTED_VARIANTS="REST REST+SDNC" -#Test agent and simulator protocol versions (others are http only) +#Test a1pms and simulator protocol versions (others are http only) TESTED_PROTOCOLS="HTTP HTTPS" NUM_RICS=20 NUM_POLICIES_PER_RIC=500 -generate_uuid +sim_generate_policy_uuid -if [ "$PMS_VERSION" == "V2" ]; then - notificationurl=$CR_SERVICE_PATH"/test" -else - notificationurl="" -fi +notificationurl=$CR_SERVICE_APP_PATH_0"/test" -for __httpx in $TESTED_PROTOCOLS ; do - for interface in $TESTED_VARIANTS ; do +VERSIONS_TO_RUN=2 - echo "#####################################################################" - echo "#####################################################################" - echo "### Testing agent: "$interface" and "$__httpx - echo "#####################################################################" - echo "#####################################################################" +if [ -n "$A1PMS_V3_FLAG" ] && [ "${A1PMS_V3_FLAG,,}" == "true" ]; then + VERSIONS_TO_RUN=3 +fi - if [ $__httpx == "HTTPS" ]; then - use_cr_https - use_simulator_https - use_mr_https - if [[ $interface = *"SDNC"* ]]; then - use_sdnc_https +for version in $(seq 2 $VERSIONS_TO_RUN); do + if [ "$version" == "3" ]; then + if [ -n "$A1PMS_V3" ] && [ -n "$A1PMS_API_PREFIX_V3" ] && [ -n "$A1PMS_ALIVE_URL_V3" ]; then + export A1PMS_VERSION="$A1PMS_V3" + export A1PMS_API_PREFIX="$A1PMS_API_PREFIX_V3" + export A1PMS_ALIVE_URL="$A1PMS_API_PREFIX$A1PMS_ALIVE_URL_V3" + else + echo "One/All parameters not set in env file (, , )" + break + fi + fi + for __httpx in $TESTED_PROTOCOLS ; do + for interface in $TESTED_VARIANTS ; do + + echo "#####################################################################" + echo "#####################################################################" + echo "### Testing a1pms: "$interface" and "$__httpx" with a1pms V"$version + echo "#####################################################################" + echo "#####################################################################" + + if [ $__httpx == "HTTPS" ]; then + use_cr_https + use_simulator_https + if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then + : + else + use_mr_https + fi + if [[ $interface = *"SDNC"* ]]; then + if [[ "$SDNC_FEATURE_LEVEL" == *"NO_NB_HTTPS"* ]]; then + deviation "SDNC does not support NB https" + use_sdnc_http + else + use_sdnc_https + fi + fi + use_a1pms_rest_https + else + use_cr_http + use_simulator_http + if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then + : + else + use_mr_http + fi + if [[ $interface = *"SDNC"* ]]; then + use_sdnc_http + fi + use_a1pms_rest_http fi - use_agent_rest_https - else - use_cr_http - use_simulator_http - use_mr_http - if [[ $interface = *"SDNC"* ]]; then - use_sdnc_http + + # Clean container and start all needed containers # + clean_environment + + start_kube_proxy + + start_ric_simulators ricsim_g1 $NUM_RICS OSC_2.1.0 + + start_control_panel $SIM_GROUP/$CONTROL_PANEL_COMPOSE_DIR/$CONTROL_PANEL_CONFIG_FILE + + if [ ! -z "$NRT_GATEWAY_APP_NAME" ]; then + start_gateway $SIM_GROUP/$NRT_GATEWAY_COMPOSE_DIR/$NRT_GATEWAY_CONFIG_FILE fi - use_agent_rest_http - fi - # Clean container and start all needed containers # - clean_environment + start_a1pms NORPOXY $SIM_GROUP/$A1PMS_COMPOSE_DIR/$A1PMS_CONFIG_FILE - start_ric_simulators ricsim_g1 $NUM_RICS OSC_2.1.0 + set_a1pms_debug - start_control_panel $SIM_GROUP/$CONTROL_PANEL_COMPOSE_DIR/application.properties - start_policy_agent NORPOXY $SIM_GROUP/$POLICY_AGENT_COMPOSE_DIR/application.yaml - set_agent_debug + if [[ $interface = *"SDNC"* ]]; then + start_sdnc + controller_api_wait_for_status_ok 200 ricsim_g1_1 + prepare_a1pms_config SDNC ".a1pms_config.json" + else + prepare_a1pms_config NOSDNC ".a1pms_config.json" + fi - if [ $RUNMODE == "DOCKER" ]; then - start_consul_cbs - fi + if [ $RUNMODE == "KUBE" ]; then + a1pms_load_config ".a1pms_config.json" + else + a1pms_api_put_configuration 200 ".a1pms_config.json" + fi - if [[ $interface = *"SDNC"* ]]; then - start_sdnc - prepare_consul_config SDNC ".consul_config.json" - else - prepare_consul_config NOSDNC ".consul_config.json" - fi + if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then + : + else + start_mr #Just to prevent errors in the a1pms log... + fi - if [ $RUNMODE == "KUBE" ]; then - agent_load_config ".consul_config.json" - else - consul_config_app ".consul_config.json" - fi + start_cr 1 - start_mr # Not used, but removes error messages from the agent log + sleep_wait 120 "Let A1PMS configuration take effect" - start_cr + a1pms_api_get_status 200 - api_get_status 200 + for ((i=1; i<=$NUM_RICS; i++)) + do + sim_print ricsim_g1_$i interface + done - for ((i=1; i<=$NUM_RICS; i++)) - do - sim_print ricsim_g1_$i interface - done + echo "Load policy type in group 1 simulators" + for ((i=1; i<=$NUM_RICS; i++)) + do + sim_put_policy_type 201 ricsim_g1_$i 1 testdata/OSC/sim_1.json + done - echo "Load policy type in group 1 simulators" - for ((i=1; i<=$NUM_RICS; i++)) - do - sim_put_policy_type 201 ricsim_g1_$i 1 testdata/OSC/sim_1.json - done + if [ "$A1PMS_VERSION" == "V2" ]; then + a1pms_equal json:policy-types 1 300 #Wait for the a1pms to refresh types from the simulator + elif [ "$A1PMS_VERSION" == "V3" ]; then + a1pms_equal json:policytypes 20 300 + fi + + a1pms_api_put_service 201 "serv1" 600 "$CR_SERVICE_APP_PATH_0/1" - if [ "$PMS_VERSION" == "V2" ]; then - api_equal json:policy-types 1 300 #Wait for the agent to refresh types from the simulator - else - api_equal json:policy_types 1 300 #Wait for the agent to refresh types from the simulator - fi + echo "Check the number of types in the a1pms for each ric is 1" + for ((i=1; i<=$NUM_RICS; i++)) + do + if [ "$A1PMS_VERSION" == "V2" ]; then + a1pms_equal json:policy-types?ric_id=ricsim_g1_$i 1 120 + elif [ "$A1PMS_VERSION" == "V3" ]; then + a1pms_equal json:policytypes?nearRtRicId=ricsim_g1_$i 1 120 + fi + done - api_put_service 201 "serv1" 600 "$CR_SERVICE_PATH/1" + START_ID=2000 - echo "Check the number of types in the agent for each ric is 1" - for ((i=1; i<=$NUM_RICS; i++)) - do - if [ "$PMS_VERSION" == "V2" ]; then - api_equal json:policy-types?ric_id=ricsim_g1_$i 1 120 + start_timer "Create $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using $__httpx and V$version policymanagementservice" + + if [ "$A1PMS_VERSION" == "V3" ]; then + a1pms_api_post_policy_parallel 201 "serv1" ricsim_g1_ $NUM_RICS 1 $START_ID NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json $NUM_POLICIES_PER_RIC 7 else - api_equal json:policy_types?ric=ricsim_g1_$i 1 120 + a1pms_api_put_policy_parallel 201 "serv1" ricsim_g1_ $NUM_RICS 1 $START_ID NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json $NUM_POLICIES_PER_RIC 7 fi - done - START_ID=2000 + print_timer "Create $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using $__httpx and V$version policymanagementservice" - start_timer "Create $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using "$__httpx + INSTANCES=$(($NUM_RICS*$NUM_POLICIES_PER_RIC)) + a1pms_equal json:policies $INSTANCES - api_put_policy_parallel 201 "serv1" ricsim_g1_ $NUM_RICS 1 $START_ID NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json $NUM_POLICIES_PER_RIC 7 + for ((i=1; i<=$NUM_RICS; i++)) + do + sim_equal ricsim_g1_$i num_instances $NUM_POLICIES_PER_RIC + done - print_timer "Create $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using "$__httpx + if [ "$A1PMS_VERSION" == "V3" ]; then + allPolicyIds_file_path="./tmp/.policyIds.split.res.txt" + allPolicies_file_path="./tmp/.allPolicies.get.res.json" + res="$(__do_curl $A1PMS_SERVICE_PATH$A1PMS_API_PREFIX"/v1/policies")" + echo $res > "./tmp/.allPolicies.get.res.json" + jq -r '.[].policyId' $allPolicies_file_path > $allPolicyIds_file_path + fi - INSTANCES=$(($NUM_RICS*$NUM_POLICIES_PER_RIC)) - api_equal json:policies $INSTANCES + if [ "$A1PMS_VERSION" == "V3" ]; then + start_timer "Update $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using $__httpx and V$version policymanagementservice" + a1pms_api_update_policy_parallel 200 "serv1" ricsim_g1_ $NUM_RICS 1 14000 NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json $NUM_POLICIES_PER_RIC 7 $allPolicyIds_file_path + print_timer "Update $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using $__httpx and V$version policymanagementservice" + fi - for ((i=1; i<=$NUM_RICS; i++)) - do - sim_equal ricsim_g1_$i num_instances $NUM_POLICIES_PER_RIC - done + start_timer "GET $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using $__httpx and V$version policymanagementservice" - start_timer "Delete $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using "$__httpx + if [ "$A1PMS_VERSION" == "V3" ]; then + a1pms_api_get_policy_parallel_v3 200 $NUM_RICS $allPolicyIds_file_path $START_ID $NUM_POLICIES_PER_RIC 7 + else + a1pms_api_get_policy_parallel 200 $NUM_RICS $START_ID $NUM_POLICIES_PER_RIC 7 + fi - api_delete_policy_parallel 204 $NUM_RICS $START_ID $NUM_POLICIES_PER_RIC 7 + print_timer "GET $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using $__httpx and V$version policymanagementservice" - print_timer "Delete $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using "$__httpx + INSTANCES=$(($NUM_RICS*$NUM_POLICIES_PER_RIC)) + a1pms_equal json:policies $INSTANCES - api_equal json:policies 0 + for ((i=1; i<=$NUM_RICS; i++)) + do + sim_equal ricsim_g1_$i num_instances $NUM_POLICIES_PER_RIC + done - for ((i=1; i<=$NUM_RICS; i++)) - do - sim_equal ricsim_g1_$i num_instances 0 - done + start_timer "Delete $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using $__httpx and V$version policymanagementservice" - for ((i=1; i<=$NUM_RICS; i++)) - do - if [ $interface == "REST+SDNC" ]; then - sim_contains_str ricsim_g1_$i remote_hosts $SDNC_APP_NAME + if [ "$A1PMS_VERSION" == "V3" ]; then + a1pms_api_delete_policy_parallel_v3 204 $NUM_RICS $allPolicyIds_file_path $START_ID $NUM_POLICIES_PER_RIC 7 else - sim_contains_str ricsim_g1_$i remote_hosts $POLICY_AGENT_APP_NAME + a1pms_api_delete_policy_parallel 204 $NUM_RICS $START_ID $NUM_POLICIES_PER_RIC 7 fi - done - check_policy_agent_logs - if [[ $interface = *"SDNC"* ]]; then - check_sdnc_logs - fi + print_timer "Delete $((NUM_POLICIES_PER_RIC*$NUM_RICS)) polices over $interface using $__httpx and V$version policymanagementservice" + + a1pms_equal json:policies 0 + + for ((i=1; i<=$NUM_RICS; i++)) + do + sim_equal ricsim_g1_$i num_instances 0 + done + + for ((i=1; i<=$NUM_RICS; i++)) + do + if [ $interface == "REST+SDNC" ]; then + sim_contains_str ricsim_g1_$i remote_hosts $SDNC_APP_NAME + else + sim_contains_str ricsim_g1_$i remote_hosts $A1PMS_APP_NAME + fi + done - store_logs "${__httpx}__${interface}" + check_a1pms_logs + if [[ $interface = *"SDNC"* ]]; then + check_sdnc_logs + fi + + store_logs "${__httpx}__${interface}" + + done done