blob: da5962f0cbe4a66f5b25b6023fa5658d4266c091 [file] [log] [blame]
#!/bin/bash
# ============LICENSE_START===============================================
# Copyright (C) 2020 Nordix Foundation. 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.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ============LICENSE_END=================================================
#
TC_ONELINE_DESCR="Full agent API walk through using agent REST/DMAAP and with/without SDNC A1 Controller"
. ../common/testcase_common.sh $@
. ../common/agent_api_functions.sh
. ../common/ricsimulator_api_functions.sh
#### TEST BEGIN ####
#Local vars in test script
##########################
# Path to callback receiver
CR_PATH="http://$CR_APP_NAME:$CR_EXTERNAL_PORT/callbacks"
# Tested variants of REST/DMAAP/SDNC config
TESTED_VARIANTS="REST DMAAP REST+SDNC DMAAP+SDNC"
#Test agent and simulator protocol versions (others are http only)
TESTED_PROTOCOLS="HTTP HTTPS"
for __httpx in $TESTED_PROTOCOLS ; do
for interface in $TESTED_VARIANTS ; do
echo "#####################################################################"
echo "#####################################################################"
echo "### Testing agent: $interface using $__httpx"
echo "#####################################################################"
echo "#####################################################################"
# Clean container and start all needed containers #
clean_containers
if [ $__httpx == "HTTPS" ]; then
#"Using secure ports towards simulators"
use_simulator_https
else
#"Using non-secure ports towards simulators"
use_simulator_http
fi
start_ric_simulators ricsim_g1 1 OSC_2.1.0
start_ric_simulators ricsim_g2 1 STD_1.1.3
start_mr
if [ $__httpx == "HTTPS" ]; then
deviation "TR17 - agent cannot use https towards MR - test combo $interface and $__httpx"
#This is the intention
#echo "Using secure ports between agent and MR"
#use_mr_https
#Work around until it is fixed
#"Using non-secure ports between agent and MR"
use_mr_http
else
#"Using non-secure ports between agent and MR"
use_mr_http
fi
start_cr
if [ $interface == "REST+SDNC" ] || [ $interface == "DMAAP+SDNC" ]; then
start_sdnc
if [ $__httpx == "HTTPS" ]; then
# "Using secure ports towards SDNC"
use_sdnc_https
else
#"Using non-secure ports towards SDNC"
use_sdnc_http
fi
fi
start_consul_cbs
if [ $interface == "REST+SDNC" ] || [ $interface == "DMAAP+SDNC" ]; then
prepare_consul_config SDNC ".consul_config.json"
else
prepare_consul_config NOSDNC ".consul_config.json"
fi
consul_config_app ".consul_config.json"
start_control_panel
start_policy_agent
set_agent_debug
if [ $interface == "DMAAP" ] || [ $interface == "DMAAP+SDNC" ]; then
use_agent_dmaap
else
if [ $__httpx == "HTTPS" ]; then
#"Using secure ports towards the agent"
use_agent_rest_https
else
#"Using non-secure ports towards the agent"
use_agent_rest_http
fi
fi
cr_equal received_callbacks 0
mr_equal requests_submitted 0
sim_put_policy_type 201 ricsim_g1_1 1 testdata/OSC/sim_1.json
sim_put_policy_type 201 ricsim_g1_1 2 testdata/OSC/sim_2.json
api_equal json:rics 2 60
api_equal json:policy_schemas 3 120
api_equal json:policy_types 3
api_equal json:policies 0
api_equal json:policy_ids 0
echo "############################################"
echo "############## Health check ################"
echo "############################################"
api_get_status 200
echo "############################################"
echo "##### Service registry and supervision #####"
echo "############################################"
api_get_services 404 "service1"
api_put_service 201 "service1" 1000 "$CR_PATH/1"
api_put_service 200 "service1" 2000 "$CR_PATH/1"
api_put_service 400 "service2" -1 "$CR_PATH/2"
api_put_service 400 "service2" "wrong" "$CR_PATH/2"
api_put_service 400 "service2" 100 "/test"
api_put_service 400 "service2" 100 "test-path"
api_put_service 201 "service2" 300 "ftp://localhost:80/test"
api_get_services 200 "service1" "service1" 2000 "$CR_PATH/1"
api_get_service_ids 200 "service1" "service2"
api_put_service 201 "service3" 5000 "$CR_PATH/3"
api_get_service_ids 200 "service1" "service2" "service3"
api_get_services 200 "service1" "service1" 2000 "$CR_PATH/1"
api_get_services 200 NOSERVICE "service1" 2000 "$CR_PATH/1" "service2" 300 "ftp://localhost:80/test" "service3" 5000 "$CR_PATH/3"
api_get_services 200
deviation "TR2 - Keep alive shall return 200/201 according to doc, only 200 works - test combo $interface and $__httpx"
#The below should work, keept here until fixed or other decision made
#api_put_services_keepalive 201 "service1"
#Using the below until decision
api_put_services_keepalive 200 "service1"
deviation "TR2 - Keep alive shall return 200/201 according to doc, only 200 works - test combo $interface and $__httpx"
#The below should work, keept here until fixed or other decision made
#api_put_services_keepalive 201 "service3"
#Using the below until decision
api_put_services_keepalive 200 "service3"
api_put_services_keepalive 200 "service1"
api_put_services_keepalive 200 "service3"
api_put_services_keepalive 404 "service5"
api_get_service_ids 200 "service1" "service2" "service3"
api_delete_services 204 "service1"
api_get_service_ids 200 "service2" "service3"
api_put_service 201 "service1" 50 "$CR_PATH/1"
api_get_service_ids 200 "service1" "service2" "service3"
api_delete_services 204 "service1"
api_delete_services 204 "service3"
api_equal json:services 1
api_delete_services 204 "service2"
api_equal json:services 0
echo "############################################"
echo "############## RIC Repository ##############"
echo "############################################"
api_get_rics 200 NOTYPE "ricsim_g1_1:me1_ricsim_g1_1,me2_ricsim_g1_1:1,2:AVAILABLE ricsim_g2_1:me1_ricsim_g2_1,me2_ricsim_g2_1:EMPTYTYPE:AVAILABLE"
api_get_rics 200 1 "ricsim_g1_1:me1_ricsim_g1_1,me2_ricsim_g1_1:1,2:AVAILABLE"
api_get_rics 404 47
api_get_rics 404 "test"
api_get_ric 200 me1_ricsim_g1_1 ricsim_g1_1
api_get_ric 200 me2_ricsim_g1_1 ricsim_g1_1
api_get_ric 200 me1_ricsim_g2_1 ricsim_g2_1
api_get_ric 200 me2_ricsim_g2_1 ricsim_g2_1
api_get_ric 404 test
echo "############################################"
echo "########### A1 Policy Management ###########"
echo "############################################"
deviation "TR9 - agent modify the type with type id - test combo $interface and $__httpx"
#Behaviour accepted for now
api_get_policy_schema 200 1 testdata/OSC/1-agent-modified.json
deviation "TR9 - agent modify the type with type id - test combo $interface and $__httpx"
#Behaviour accepted for now
api_get_policy_schema 200 2 testdata/OSC/2-agent-modified.json
api_get_policy_schema 404 3
deviation "TR9 - agent modify the type with type id - test combo $interface and $__httpx"
#Behaviour accepted for now
api_get_policy_schemas 200 NORIC testdata/OSC/1-agent-modified.json testdata/OSC/2-agent-modified.json NOFILE
deviation "TR9 - agent modify the type with type id - test combo $interface and $__httpx"
#Behaviour accepted for now
api_get_policy_schemas 200 ricsim_g1_1 testdata/OSC/1-agent-modified.json testdata/OSC/2-agent-modified.json
api_get_policy_schemas 200 ricsim_g2_1 NOFILE
api_get_policy_schemas 404 test
api_get_policy_types 200 NORIC 1 2 EMPTY
api_get_policy_types 200 ricsim_g1_1 1 2
api_get_policy_types 200 ricsim_g2_1 EMPTY
api_get_policy_types 404 dummy-ric
api_put_service 201 "service10" 3600 "$CR_PATH/1"
deviation "TR10 - agent allows policy creation on unregistered service (orig problem) - test combo $interface and $__httpx"
#Kept until decison
#api_put_policy 400 "unregistered-service" ricsim_g1_1 1 2000 testdata/OSC/pi1_template.json
#Allow 201 for now
api_put_policy 201 "unregistered-service" ricsim_g1_1 1 2000 testdata/OSC/pi1_template.json
api_put_policy 201 "service10" ricsim_g1_1 1 5000 testdata/OSC/pi1_template.json
api_put_policy 200 "service10" ricsim_g1_1 1 5000 testdata/OSC/pi1_template.json
api_put_policy 201 "service10" ricsim_g2_1 NOTYPE 5100 testdata/STD/pi1_template.json
api_put_policy 200 "service10" ricsim_g2_1 NOTYPE 5100 testdata/STD/pi1_template.json
VAL='NOT IN EFFECT'
api_get_policy_status 200 5000 OSC "$VAL" "false"
api_get_policy_status 200 5100 STD "UNDEFINED"
deviation "TR10 - agent allows policy creation on unregistered service (side effect of orig. problem)- test combo $interface and $__httpx"
#kept until decision
#api_equal json:policies 2
#Allow 3 for now
api_equal json:policies 3
deviation "TR10 - agent allows policy creation on unregistered service (side effect of orig. problem)- test combo $interface and $__httpx"
#kept until decision
#api_equal json:policy_ids 2
#Allow 3 for now
api_equal json:policy_ids 3
deviation "TR10 - agent allows policy creation on unregistered service (side effect of orig. problem)- test combo $interface and $__httpx"
#kept until decision
#api_get_policy_ids 200 NORIC NOSERVICE NOTYPE 5000 5100
#Allow policy create with unregistered service for now
api_get_policy_ids 200 NORIC NOSERVICE NOTYPE 5000 5100 2000
deviation "TR10 - agent allows policy creation on unregistered service (side effect of orig. problem)- test combo $interface and $__httpx"
#kept until decision
#api_get_policy_ids 200 ricsim_g1_1 NOSERVICE NOTYPE 5000
#Allow policy create with unregistered service for now
api_get_policy_ids 200 ricsim_g1_1 NOSERVICE NOTYPE 5000 2000
api_get_policy_ids 200 ricsim_g2_1 NOSERVICE NOTYPE 5100
api_get_policy_ids 200 NORIC "service10" NOTYPE 5000 5100
deviation "TR10 - agent allows policy creation on unregistered service (side effect of orig. problem)- test combo $interface and $__httpx"
#kept until decision
#api_get_policy_ids 200 NORIC NOSERVICE 1 5000
#Allow policy create with unregistered service for now
api_get_policy_ids 200 NORIC NOSERVICE 1 5000 2000
api_get_policy_ids 200 NORIC NOSERVICE 2 NOID
api_get_policy_ids 200 ricsim_g2_1 NOSERVICE 1 NOID
api_get_policy 200 5000 testdata/OSC/pi1_template.json
api_get_policy 200 5100 testdata/STD/pi1_template.json
api_get_policies 200 ricsim_g1_1 "service10" 1 5000 ricsim_g1_1 "service10" 1 testdata/OSC/pi1_template.json
deviation "TR10 - agent allows policy creation on unregistered service (side effect of orig. problem)- test combo $interface and $__httpx"
#kept until decision
#api_delete_policy 404 2000
#Allow policy create with unregistered service for now
api_delete_policy 204 2000
api_delete_policy 404 1500
api_delete_policy 204 5000
api_equal json:policies 1
api_equal json:policy_ids 1
api_delete_policy 204 5100
api_equal json:policies 0
api_equal json:policy_ids 0
cr_equal received_callbacks 0
if [ $interface == "DMAAP" ] || [ $interface == "DMAAP+SDNC" ]; then
mr_greater requests_submitted 0
VAL=$(mr_read requests_submitted)
mr_equal requests_fetched $VAL
mr_equal responses_submitted $VAL
mr_equal responses_fetched $VAL
mr_equal current_requests 0
mr_equal current_responses 0
else
mr_equal requests_submitted 0
fi
if [ $interface == "REST+SDNC" ] || [ $interface == "DMAAP+SDNC" ]; then
sim_contains_str ricsim_g1_1 remote_hosts "a1-controller"
sim_contains_str ricsim_g2_1 remote_hosts "a1-controller"
else
sim_contains_str ricsim_g1_1 remote_hosts "policy-agent"
sim_contains_str ricsim_g2_1 remote_hosts "policy-agent"
fi
check_policy_agent_logs
check_control_panel_logs
store_logs "${__httpx}__${interface}"
done
done
#### TEST COMPLETE ####
print_result
auto_clean_containers