#!/bin/bash
# ============LICENSE_START===============================================
-# Copyright (C) 2020 Nordix Foundation. All rights reserved.
+# Copyright (C) 2020-2023 Nordix Foundation. All rights reserved.
+# Copyright (C) 2023 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.
# ============LICENSE_END=================================================
#
-TC_ONELINE_DESCR="Basic use case, register service, create/update policy, delete policy, de-register service using both STD and OSC interface while mixing REST and Dmaap"
+TC_ONELINE_DESCR="Basic use case, register service, create/update policy, delete policy, de-register service using both STD and OSC interface while mixing REST"
-#App names to exclude checking pulling images for, space separated list
-EXCLUDED_IMAGES="SDNC SDNC_ONAP"
+#App names to include in the test when running docker, space separated list
+DOCKER_INCLUDED_IMAGES="CP CR MR A1PMS RICSIM NGW KUBEPROXY"
-. ../common/testcase_common.sh $@
-. ../common/agent_api_functions.sh
-. ../common/ricsimulator_api_functions.sh
-
-#### TEST BEGIN ####
-
-generate_uuid
+#App names to include in the test when running kubernetes, space separated list
+KUBE_INCLUDED_IMAGES=" MR CR A1PMS RICSIM CP KUBEPROXY NGW"
+#Pre-started app (not started by script) to include in the test when running kubernetes, space separated list
+KUBE_PRESTARTED_IMAGES=""
-#Local vars in test script
-##########################
-# Path to callback receiver
-CR_PATH="http://$CR_APP_NAME:$CR_EXTERNAL_PORT/callbacks"
-use_cr_http
+#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"
-clean_containers
+#Supported test environment profiles
+SUPPORTED_PROFILES="ONAP-KOHN ONAP-LONDON ONAP-MONTREAL ORAN-G-RELEASE ORAN-H-RELEASE ORAN-I-RELEASE"
+#Supported run modes
+SUPPORTED_RUNMODES="DOCKER KUBE"
-start_ric_simulators ricsim_g1 3 OSC_2.1.0
-
-start_ric_simulators ricsim_g2 5 STD_1.1.3
+. ../common/testcase_common.sh $@
-start_mr
+setup_testenvironment
-start_cr
+#### TEST BEGIN ####
+VERSIONS_TO_RUN=2
-start_consul_cbs
+if [ -n "$A1PMS_V3_FLAG" ] && [ "${A1PMS_V3_FLAG,,}" == "true" ]; then
+ VERSIONS_TO_RUN=3
+fi
-prepare_consul_config NOSDNC ".consul_config.json"
-consul_config_app ".consul_config.json"
+for version in $(seq 2 $VERSIONS_TO_RUN); do
-start_control_panel
+ echo "#####################################################################"
+ echo "#####################################################################"
+ echo "### Testing a1pms: V${version}"
+ echo "#####################################################################"
+ echo "#####################################################################"
-start_policy_agent
+ 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 (<A1PMS_V3>, <A1PMS_API_PREFIX_V3>, <A1PMS_ALIVE_URL_V3>)"
+ break
+ fi
+ fi
+ sim_generate_policy_uuid
-set_agent_debug
+ use_simulator_http
+ use_mr_http
+ use_a1pms_rest_http
-use_agent_rest_http
-api_get_status 200
+ clean_environment
-sim_print ricsim_g1_1 interface
+ start_kube_proxy
-sim_print ricsim_g2_1 interface
+ start_ric_simulators ricsim_g1 3 OSC_2.1.0
-sim_put_policy_type 201 ricsim_g1_1 1 testdata/OSC/sim_1.json
+ start_ric_simulators ricsim_g2 5 STD_1.1.3
-api_equal json:policy_types 2 60
+ start_ric_simulators ricsim_g3 1 STD_2.0.0
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ :
+ else
+ start_mr
+ fi
-# Create policies
-use_agent_rest_http
+ start_cr 1
-api_put_service 201 "service1" 3600 "$CR_PATH/1"
-api_put_policy 201 "service1" ricsim_g1_1 1 2000 NOTRANSIENT testdata/OSC/pi1_template.json 1
+ start_control_panel $SIM_GROUP/$CONTROL_PANEL_COMPOSE_DIR/$CONTROL_PANEL_CONFIG_FILE
-sim_equal ricsim_g1_1 num_instances 1
+ if [ ! -z "$NRT_GATEWAY_APP_NAME" ]; then
+ start_gateway $SIM_GROUP/$NRT_GATEWAY_COMPOSE_DIR/$NRT_GATEWAY_CONFIG_FILE
+ fi
+ start_a1pms NORPOXY $SIM_GROUP/$A1PMS_COMPOSE_DIR/$A1PMS_CONFIG_FILE
-use_agent_dmaap_http
+ set_a1pms_debug
-api_put_policy 201 "service1" ricsim_g1_1 1 3000 NOTRANSIENT testdata/OSC/pi1_template.json 1
+ use_a1pms_rest_http
-sim_equal ricsim_g1_1 num_instances 2
+ prepare_a1pms_config NOSDNC ".a1pms_config.json"
-use_agent_rest_http
+ if [ $RUNMODE == "KUBE" ]; then
+ a1pms_load_config ".a1pms_config.json"
+ else
+ a1pms_api_put_configuration 200 ".a1pms_config.json"
+ fi
-api_put_policy 201 "service1" ricsim_g2_1 NOTYPE 2100 NOTRANSIENT testdata/STD/pi1_template.json 1
+ sleep_wait 120 "Let A1PMS configuration take effect"
-sim_equal ricsim_g2_1 num_instances 1
+ a1pms_api_get_status 200
+ sim_print ricsim_g1_1 interface
-use_agent_dmaap_http
+ sim_print ricsim_g2_1 interface
-api_put_policy 201 "service1" ricsim_g2_1 NOTYPE 3100 NOTRANSIENT testdata/STD/pi1_template.json 1
+ sim_print ricsim_g3_1 interface
-sim_equal ricsim_g2_1 num_instances 2
+ sim_put_policy_type 201 ricsim_g1_1 1 testdata/OSC/sim_1.json
+ sim_put_policy_type 201 ricsim_g3_1 STD_QOS_0_2_0 testdata/STD2/sim_qos.json
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_equal json:policytypes 7 300
+ else
+ a1pms_equal json:policy-types 3 300
+ fi
-#Update policies
-use_agent_rest_http
+ # Create policies
-api_put_service 200 "service1" 3600 "$CR_PATH/1"
+ notificationurl=$CR_SERVICE_APP_PATH_0"/test"
-api_put_policy 200 "service1" ricsim_g1_1 1 2000 NOTRANSIENT testdata/OSC/pi1_template.json 1
+ use_a1pms_rest_http
-sim_equal ricsim_g1_1 num_instances 2
+ a1pms_api_put_service 201 "service1" 3600 "$CR_SERVICE_APP_PATH_0/1"
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_post_policy_v3 201 "service1" ricsim_g1_1 1 2000 NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json 1
+ else
+ a1pms_api_put_policy 201 "service1" ricsim_g1_1 1 2000 NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json 1
+ fi
-use_agent_dmaap_http
+ sim_equal ricsim_g1_1 num_instances 1
-api_put_policy 200 "service1" ricsim_g1_1 1 3000 NOTRANSIENT testdata/OSC/pi1_template.json 1
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
-sim_equal ricsim_g1_1 num_instances 2
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_post_policy_v3 201 "service1" ricsim_g1_1 1 3000 NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json 1
+ else
+ a1pms_api_put_policy 201 "service1" ricsim_g1_1 1 3000 NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json 1
+ fi
+ sim_equal ricsim_g1_1 num_instances 2
-use_agent_rest_http
+ use_a1pms_rest_http
-api_put_policy 200 "service1" ricsim_g2_1 NOTYPE 2100 NOTRANSIENT testdata/STD/pi1_template.json 1
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_post_policy_v3 201 "service1" ricsim_g2_1 NOTYPE 2100 NOTRANSIENT $notificationurl testdata/STD/pi1_template.json 1
+ else
+ a1pms_api_put_policy 201 "service1" ricsim_g2_1 NOTYPE 2100 NOTRANSIENT $notificationurl testdata/STD/pi1_template.json 1
+ fi
-sim_equal ricsim_g2_1 num_instances 2
+ sim_equal ricsim_g2_1 num_instances 1
-use_agent_dmaap_http
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
-api_put_policy 200 "service1" ricsim_g2_1 NOTYPE 3100 NOTRANSIENT testdata/STD/pi1_template.json 1
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_post_policy_v3 201 "service1" ricsim_g2_1 NOTYPE 3100 NOTRANSIENT $notificationurl testdata/STD/pi1_template.json 1
+ else
+ a1pms_api_put_policy 201 "service1" ricsim_g2_1 NOTYPE 3100 NOTRANSIENT $notificationurl testdata/STD/pi1_template.json 1
+ fi
-sim_equal ricsim_g2_1 num_instances 2
+ sim_equal ricsim_g2_1 num_instances 2
-# Check policies
-api_get_policy 200 2000 testdata/OSC/pi1_template.json
-api_get_policy 200 3000 testdata/OSC/pi1_template.json
-api_get_policy 200 2100 testdata/STD/pi1_template.json
-api_get_policy 200 3100 testdata/STD/pi1_template.json
+ use_a1pms_rest_http
-# Remove policies
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_post_policy_v3 201 "service1" ricsim_g3_1 STD_QOS_0_2_0 2200 true $notificationurl testdata/STD2/pi_qos_template.json 1
+ else
+ a1pms_api_put_policy 201 "service1" ricsim_g3_1 STD_QOS_0_2_0 2200 true $notificationurl testdata/STD2/pi_qos_template.json 1
+ fi
-use_agent_dmaap_http
-api_delete_policy 204 2000
-use_agent_rest_http
-api_delete_policy 204 3000
-use_agent_dmaap_http
-api_delete_policy 204 2100
-use_agent_rest_http
-api_delete_policy 204 3100
+ sim_equal ricsim_g3_1 num_instances 1
-sim_equal ricsim_g1_1 num_instances 0
-sim_equal ricsim_g2_1 num_instances 0
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
-# Check remote host access to simulator
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_post_policy_v3 201 "service1" ricsim_g3_1 STD_QOS_0_2_0 3200 NOTRANSIENT $notificationurl testdata/STD2/pi_qos_template.json 1
+ else
+ a1pms_api_put_policy 201 "service1" ricsim_g3_1 STD_QOS_0_2_0 3200 NOTRANSIENT $notificationurl testdata/STD2/pi_qos_template.json 1
+ fi
-sim_contains_str ricsim_g1_1 remote_hosts "policy-agent"
-sim_contains_str ricsim_g2_1 remote_hosts "policy-agent"
+ sim_equal ricsim_g3_1 num_instances 2
-# Check policy removal
-use_agent_rest_http
-api_get_policy 404 2000
-api_get_policy 404 3000
-api_get_policy 404 2100
-api_get_policy 404 3100
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ # Check policies
+ a1pms_api_get_policy 200 2000 testdata/OSC/pi1_template.json "service1" ricsim_g1_1 1 false $notificationurl
+ a1pms_api_get_policy 200 3000 testdata/OSC/pi1_template.json "service1" ricsim_g1_1 1 false $notificationurl
+ a1pms_api_get_policy 200 2100 testdata/STD/pi1_template.json "service1" ricsim_g2_1 NOTYPE false $notificationurl
+ a1pms_api_get_policy 200 3100 testdata/STD/pi1_template.json "service1" ricsim_g2_1 NOTYPE false $notificationurl
+ a1pms_api_get_policy 200 2200 testdata/STD2/pi_qos_template.json "service1" ricsim_g3_1 STD_QOS_0_2_0 true $notificationurl
+ a1pms_api_get_policy 200 3200 testdata/STD2/pi_qos_template.json "service1" ricsim_g3_1 STD_QOS_0_2_0 true $notificationurl
+ fi
-# Remove the service
-use_agent_dmaap_http
-api_delete_services 204 "service1"
+ #Update policies
+ use_a1pms_rest_http
-api_get_services 404 "service1"
+ a1pms_api_put_service 200 "service1" 3600 "$CR_SERVICE_APP_PATH_0/1"
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_put_policy_v3 200 2000 testdata/OSC/pi1_template.json 1
+ else
+ a1pms_api_put_policy 200 "service1" ricsim_g1_1 1 2000 NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json 1
+ fi
+ sim_equal ricsim_g1_1 num_instances 2
-check_policy_agent_logs
-#### TEST COMPLETE ####
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
+
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_put_policy_v3 200 3000 testdata/OSC/pi1_template.json 1
+ else
+ a1pms_api_put_policy 200 "service1" ricsim_g1_1 1 3000 NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json 1
+ fi
+
+ sim_equal ricsim_g1_1 num_instances 2
+
+
+ use_a1pms_rest_http
+
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_put_policy_v3 200 2100 testdata/STD/pi1_template.json 1
+ else
+ a1pms_api_put_policy 200 "service1" ricsim_g2_1 NOTYPE 2100 NOTRANSIENT $notificationurl testdata/STD/pi1_template.json 1
+ fi
+
+ sim_equal ricsim_g2_1 num_instances 2
+
+
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
+
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_put_policy_v3 200 3100 testdata/STD/pi1_template.json 1
+ else
+ a1pms_api_put_policy 200 "service1" ricsim_g2_1 NOTYPE 3100 NOTRANSIENT $notificationurl testdata/STD/pi1_template.json 1
+ fi
+
+ sim_equal ricsim_g2_1 num_instances 2
+
+ use_a1pms_rest_http
+
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_put_policy_v3 200 2200 testdata/STD2/pi_qos_template.json 1
+ else
+ a1pms_api_put_policy 200 "service1" ricsim_g3_1 STD_QOS_0_2_0 2200 true $notificationurl testdata/STD2/pi_qos_template.json 1
+ fi
+
+ sim_equal ricsim_g3_1 num_instances 2
+
+
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
+
+ if [ "$A1PMS_VERSION" == "V3" ]; then
+ a1pms_api_put_policy_v3 200 3200 testdata/STD2/pi_qos_template.json 1
+ else
+ a1pms_api_put_policy 200 "service1" ricsim_g3_1 STD_QOS_0_2_0 3200 true $notificationurl testdata/STD2/pi_qos_template.json 1
+ fi
+
+ sim_equal ricsim_g3_1 num_instances 2
+
+ if [ "$A1PMS_VERSION" != "V3" ]; then
+ # Check policies
+ a1pms_api_get_policy 200 2000 testdata/OSC/pi1_template.json "service1" ricsim_g1_1 1 false $notificationurl
+ a1pms_api_get_policy 200 3000 testdata/OSC/pi1_template.json "service1" ricsim_g1_1 1 false $notificationurl
+ a1pms_api_get_policy 200 2100 testdata/STD/pi1_template.json "service1" ricsim_g2_1 NOTYPE false $notificationurl
+ a1pms_api_get_policy 200 3100 testdata/STD/pi1_template.json "service1" ricsim_g2_1 NOTYPE false $notificationurl
+ a1pms_api_get_policy 200 2200 testdata/STD2/pi_qos_template.json "service1" ricsim_g3_1 STD_QOS_0_2_0 true $notificationurl
+ a1pms_api_get_policy 200 3200 testdata/STD2/pi_qos_template.json "service1" ricsim_g3_1 STD_QOS_0_2_0 true $notificationurl
+ fi
+
+ sim_equal ricsim_g1_1 num_instances 2
+ sim_equal ricsim_g2_1 num_instances 2
+
+ sim_equal ricsim_g3_1 num_instances 2
+
+ # Remove policies
+
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
+ a1pms_api_delete_policy 204 2000
+ use_a1pms_rest_http
+ a1pms_api_delete_policy 204 3000
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
+ a1pms_api_delete_policy 204 2100
+ use_a1pms_rest_http
+ a1pms_api_delete_policy 204 3100
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
+ a1pms_api_delete_policy 204 2200
+ use_a1pms_rest_http
+ a1pms_api_delete_policy 204 3200
+
+ sim_equal ricsim_g1_1 num_instances 0
+ sim_equal ricsim_g2_1 num_instances 0
+
+ sim_equal ricsim_g3_1 num_instances 0
+
+ # Check remote host access to simulator
+
+ sim_contains_str ricsim_g1_1 remote_hosts $A1PMS_APP_NAME
+ sim_contains_str ricsim_g2_1 remote_hosts $A1PMS_APP_NAME
+ sim_contains_str ricsim_g3_1 remote_hosts $A1PMS_APP_NAME
+
+ # Check policy removal
+ use_a1pms_rest_http
+ a1pms_api_get_policy 404 2000
+ a1pms_api_get_policy 404 3000
+ a1pms_api_get_policy 404 2100
+ a1pms_api_get_policy 404 3100
+
+ a1pms_api_get_policy 404 2200
+ a1pms_api_get_policy 404 3200
+
+ # Remove the service
+ if [[ "$A1PMS_FEATURE_LEVEL" == *"NO-DMAAP"* ]]; then
+ use_a1pms_rest_http
+ else
+ use_a1pms_dmaap_http
+ fi
+ a1pms_api_delete_services 204 "service1"
+
+ a1pms_api_get_services 404 "service1"
+
+ check_a1pms_logs
+done
+ #### TEST COMPLETE ####
store_logs END
print_result
-auto_clean_containers
\ No newline at end of file
+auto_clean_environment