Test env updates for dmaap messages in batch and for running external agent

Restructured and consolidated testcases

Various minor updates and adjustment to test functions

Change-Id: Ie796b04b7a12bbd410b56db19d718e1c5a0510de
Issue-ID: NONRTRIC-154
Signed-off-by: BjornMagnussonXA <bjorn.magnusson@est.tech>
diff --git a/test/auto-test/FTC810.sh b/test/auto-test/FTC810.sh
new file mode 100755
index 0000000..2631a16
--- /dev/null
+++ b/test/auto-test/FTC810.sh
@@ -0,0 +1,237 @@
+#!/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="Repeatedly create and delete policies in each RICs for 24h. Via agent REST/DMAAP/DMAAP_BATCH and SDNC using http"
+
+. ../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"
+# Number of RICs per interface type (OSC and STD)
+NUM_RICS=30
+# Number of policy instances per RIC
+NUM_INSTANCES=5
+
+clean_containers
+
+start_ric_simulators ricsim_g1 $NUM_RICS OSC_2.1.0
+
+start_ric_simulators ricsim_g2 $NUM_RICS STD_1.1.3
+
+start_mr
+
+start_cr
+
+start_consul_cbs
+
+prepare_consul_config      SDNC  ".consul_config.json"
+consul_config_app                  ".consul_config.json"
+
+start_sdnc
+
+start_control_panel
+
+start_policy_agent
+
+use_agent_rest_http
+
+api_get_status 200
+
+echo "Print the interface for group 1 simulators, shall be OSC"
+for ((i=1; i<=$NUM_RICS; i++))
+do
+   sim_print ricsim_g1_$i interface
+done
+
+echo "Print the interface for group 2 simulators, shall be STD"
+for ((i=1; i<=$NUM_RICS; i++))
+do
+   sim_print ricsim_g2_$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 "Check the number of instances in  group 1 simulators, shall be 0"
+for ((i=1; i<=$NUM_RICS; i++))
+do
+   sim_equal ricsim_g1_$i num_instances 0
+done
+
+echo "Check the number of instances in  group 2 simulators, shall be 0"
+for ((i=1; i<=$NUM_RICS; i++))
+do
+   sim_equal ricsim_g2_$i num_instances 0
+done
+
+echo "Wait for the agent to refresh types from the simulator"
+api_equal json:policy_types 2 120
+
+echo "Check the number of types in the agent for each ric is 1"
+for ((i=1; i<=$NUM_RICS; i++))
+do
+   api_equal json:policy_types?ric=ricsim_g1_$i 1 120
+done
+
+echo "Register a service"
+api_put_service 201 "serv1" 0 "$CR_PATH/1"
+
+TEST_DURATION=$((24*3600))
+TEST_START=$SECONDS
+
+AGENT_INTERFACES="REST DMAAP DMAAP-BATCH"
+
+MR_MESSAGES=0
+
+while [ $(($SECONDS-$TEST_START)) -lt $TEST_DURATION ]; do
+
+    echo ""
+    echo "#########################################################################################################"
+    echo -e $BOLD"INFO: Test executed for: "$(($SECONDS-$TEST_START)) "seconds. Target is: "$TEST_DURATION" seconds."$EBOLD
+    echo "#########################################################################################################"
+    echo ""
+
+   for interface in $AGENT_INTERFACES ; do
+
+      echo "############################################"
+      echo "## Testing using agent interface: $interface ##"
+      echo "############################################"
+
+      if [ $interface == "REST" ]; then
+         use_agent_rest_http
+      else
+         use_agent_dmaap
+      fi
+
+      echo "Create $NUM_INSTANCES instances in each OSC RIC"
+      INSTANCE_ID=200000
+      INSTANCES=0
+      for ((i=1; i<=$NUM_RICS; i++))
+      do
+         if [ $interface == "DMAAP-BATCH" ]; then
+            api_put_policy_batch 201 "serv1" ricsim_g1_$i 1 $INSTANCE_ID testdata/OSC/pi1_template.json $NUM_INSTANCES
+         else
+            api_put_policy 201 "serv1" ricsim_g1_$i 1 $INSTANCE_ID testdata/OSC/pi1_template.json $NUM_INSTANCES
+         fi
+         if [ $interface != "REST" ]; then
+            MR_MESSAGES=$(($MR_MESSAGES+$NUM_INSTANCES))
+         fi
+         sim_equal ricsim_g1_$i num_instances $NUM_INSTANCES
+         INSTANCE_ID=$(($INSTANCE_ID+$NUM_INSTANCES))
+         INSTANCES=$(($INSTANCES+$NUM_INSTANCES))
+      done
+
+      api_equal json:policy_ids $INSTANCES
+
+      echo "Create $NUM_INSTANCES instances in each STD RIC"
+      for ((i=1; i<=$NUM_RICS; i++))
+      do
+         if [ $interface == "DMAAP-BATCH" ]; then
+            api_put_policy_batch 201 "serv1" ricsim_g2_$i NOTYPE $INSTANCE_ID testdata/STD/pi1_template.json $NUM_INSTANCES
+         else
+            api_put_policy 201 "serv1" ricsim_g2_$i NOTYPE $INSTANCE_ID testdata/STD/pi1_template.json $NUM_INSTANCES
+         fi
+         if [ $interface != "REST" ]; then
+            MR_MESSAGES=$(($MR_MESSAGES+$NUM_INSTANCES))
+         fi
+         sim_equal ricsim_g2_$i num_instances $NUM_INSTANCES
+         INSTANCE_ID=$(($INSTANCE_ID+$NUM_INSTANCES))
+         INSTANCES=$(($INSTANCES+$NUM_INSTANCES))
+      done
+
+      api_equal json:policy_ids $INSTANCES
+
+
+      echo "Delete all instances in each OSC RIC"
+
+      INSTANCE_ID=200000
+      for ((i=1; i<=$NUM_RICS; i++))
+      do
+         if [ $interface == "DMAAP-BATCH" ]; then
+            api_delete_policy_batch 204 $INSTANCE_ID $NUM_INSTANCES
+         else
+            api_delete_policy 204 $INSTANCE_ID $NUM_INSTANCES
+         fi
+         if [ $interface != "REST" ]; then
+            MR_MESSAGES=$(($MR_MESSAGES+$NUM_INSTANCES))
+         fi
+         INSTANCES=$(($INSTANCES-$NUM_INSTANCES))
+         sim_equal ricsim_g1_$i num_instances 0
+         INSTANCE_ID=$(($INSTANCE_ID+$NUM_INSTANCES))
+      done
+
+      api_equal json:policy_ids $INSTANCES
+
+      echo "Delete all instances in each STD RIC"
+
+      for ((i=1; i<=$NUM_RICS; i++))
+      do
+         if [ $interface == "DMAAP-BATCH" ]; then
+            api_delete_policy_batch 204 $INSTANCE_ID $NUM_INSTANCES
+         else
+            api_delete_policy 204 $INSTANCE_ID $NUM_INSTANCES
+         fi
+         if [ $interface != "REST" ]; then
+            MR_MESSAGES=$(($MR_MESSAGES+$NUM_INSTANCES))
+         fi
+         INSTANCES=$(($INSTANCES-$NUM_INSTANCES))
+         sim_equal ricsim_g2_$i num_instances 0
+         INSTANCE_ID=$(($INSTANCE_ID+$NUM_INSTANCES))
+      done
+
+      api_equal json:policy_ids 0
+
+      cr_equal received_callbacks 0
+
+      mr_equal requests_submitted $MR_MESSAGES
+      mr_equal requests_fetched $MR_MESSAGES
+      mr_equal responses_submitted $MR_MESSAGES
+      mr_equal responses_fetched $MR_MESSAGES
+      mr_equal current_requests 0
+      mr_equal current_responses 0
+
+
+      for ((i=1; i<=$NUM_RICS; i++))
+      do
+         sim_contains_str ricsim_g1_$i remote_hosts "a1-controller"
+         sim_contains_str ricsim_g2_$i remote_hosts "a1-controller"
+      done
+
+   done
+
+done
+
+check_policy_agent_logs
+
+#### TEST COMPLETE ####
+
+store_logs          END
+
+print_result
+
+auto_clean_containers
\ No newline at end of file