Merge "Add functionality to rAPP Catalogue"
[nonrtric.git] / test / auto-test / FTC110.sh
1 #!/bin/bash
2
3 #  ============LICENSE_START===============================================
4 #  Copyright (C) 2020 Nordix Foundation. All rights reserved.
5 #  ========================================================================
6 #  Licensed under the Apache License, Version 2.0 (the "License");
7 #  you may not use this file except in compliance with the License.
8 #  You may obtain a copy of the License at
9 #
10 #       http://www.apache.org/licenses/LICENSE-2.0
11 #
12 #  Unless required by applicable law or agreed to in writing, software
13 #  distributed under the License is distributed on an "AS IS" BASIS,
14 #  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 #  See the License for the specific language governing permissions and
16 #  limitations under the License.
17 #  ============LICENSE_END=================================================
18 #
19
20
21 TC_ONELINE_DESCR="Testing of service registration timeouts and keepalive"
22
23 #App names to include in the test, space separated list
24 INCLUDED_IMAGES="CBS CONSUL CP CR MR PA RICSIM"
25
26 . ../common/testcase_common.sh  $@
27 . ../common/agent_api_functions.sh
28 . ../common/ricsimulator_api_functions.sh
29
30 generate_uuid
31
32 #Local vars in test script
33 ##########################
34 # Path to callback receiver
35 CR_PATH="http://$CR_APP_NAME:$CR_EXTERNAL_PORT/callbacks"
36
37 use_cr_http
38 use_simulator_http
39 use_mr_http
40 use_agent_rest_http
41
42
43 #### TEST BEGIN ####
44
45 clean_containers
46
47 start_ric_simulators ricsim_g1 1  OSC_2.1.0
48 start_ric_simulators ricsim_g2 1  STD_1.1.3
49 if [ "$PMS_VERSION" == "V2" ]; then
50     start_ric_simulators ricsim_g3 1  STD_2.0.0
51 fi
52
53 start_mr
54
55 start_cr
56
57 start_consul_cbs
58
59 prepare_consul_config      NOSDNC  ".consul_config.json"
60 consul_config_app                  ".consul_config.json"
61
62 start_control_panel
63
64 start_policy_agent
65
66 set_agent_debug
67
68 #Verify no callbacks or dmaap messages has been sent
69 cr_equal received_callbacks 0
70 mr_equal requests_submitted 0
71
72 #Check agent alive
73 api_get_status 200
74
75 #Print simulator interface version
76 sim_print ricsim_g1_1 interface
77 sim_print ricsim_g2_1 interface
78 if [ "$PMS_VERSION" == "V2" ]; then
79     sim_print ricsim_g3_1 interface
80 fi
81
82 api_put_service 201 "service1" 15 "$CR_PATH/service1"
83
84 api_get_services 200 "service1" "service1" 15 "$CR_PATH/service1"
85
86 api_put_service 201 "service2" 120 "$CR_PATH/service2"
87
88 api_get_services 200 "service2" "service2" 120 "$CR_PATH/service2"
89
90 api_put_service 200 "service1" 50 "$CR_PATH/service1"
91 api_put_service 200 "service2" 180 "$CR_PATH/service2"
92
93 api_get_services 200 "service1" "service1" 50 "$CR_PATH/service1"
94 api_get_services 200 "service2" "service2" 180 "$CR_PATH/service2"
95
96 api_get_service_ids 200 "service1" "service2"
97
98 sleep_wait 30 "Waiting for keep alive timeout"
99
100 api_get_services 200 "service1" "service1" 50 "$CR_PATH/service1"
101 api_get_services 200 "service2" "service2" 180 "$CR_PATH/service2"
102
103 sleep_wait 100 "Waiting for keep alive timeout"
104
105 api_get_services 404 "service1"
106 api_get_services 200 "service2" "service2" 180 "$CR_PATH/service2"
107
108 api_delete_services 204 "service2"
109
110 api_get_services 404 "service1"
111 api_get_services 404 "service2"
112
113 api_put_service 201 "service3" 60 "$CR_PATH/service3"
114
115 api_get_services 200 "service3" "service3" 60 "$CR_PATH/service3"
116
117 sleep_wait 30 "Waiting for keep alive timeout"
118
119 api_put_service 200 "service3" 60 "$CR_PATH/service3"
120
121 sleep_wait 100 "Waiting for keep alive timeout"
122
123 api_get_services 404 "service3"
124
125 api_put_service 201 "service4" 120 "$CR_PATH/service4"
126
127 sleep_wait 60 "Waiting for keep alive timeout"
128
129 api_get_services 200 "service4" "service4" 120 "$CR_PATH/service4"
130
131 api_put_services_keepalive 200 "service4"
132
133 sleep_wait 90 "Waiting for keep alive timeout"
134
135 api_get_services 200 "service4" "service4" 120 "$CR_PATH/service4"
136
137 api_delete_services 204 "service4"
138
139 api_get_services 404 "service4"
140
141 api_get_services 404 "service1"
142 api_get_services 404 "service2"
143 api_get_services 404 "service3"
144
145 api_get_service_ids 200
146
147 api_delete_services 404 "service1"
148 api_delete_services 404 "service2"
149 api_delete_services 404 "service3"
150 api_delete_services 404 "service4"
151
152 api_put_services_keepalive 404 "service1"
153 api_put_services_keepalive 404 "service2"
154 api_put_services_keepalive 404 "service3"
155 api_put_services_keepalive 404 "service4"
156
157 # Policy delete after timeout
158 api_put_service 201 "service10" 600 "$CR_PATH/service10"
159
160 sim_put_policy_type 201 ricsim_g1_1 1 testdata/OSC/sim_1.json
161
162 if [ "$PMS_VERSION" == "V2" ]; then
163     api_equal json:rics 3 60
164
165     #api_equal json:policy_schemas 2 120
166
167     api_equal json:policy-types 2 120
168
169     api_equal json:policies 0
170 else
171     api_equal json:rics 2 60
172
173     api_equal json:policy_schemas 2 120
174
175     api_equal json:policy_types 2
176
177     api_equal json:policies 0
178 fi
179
180 if [ "$PMS_VERSION" == "V2" ]; then
181     notificationurl="http://localhost:80"
182 else
183     notificationurl=""
184 fi
185
186 api_put_policy 201 "service10" ricsim_g1_1 1 5000 NOTRANSIENT $notificationurl testdata/OSC/pi1_template.json
187 api_put_policy 201 "service10" ricsim_g2_1 NOTYPE 5100 NOTRANSIENT $notificationurl testdata/STD/pi1_template.json
188
189 api_equal json:policies 2
190
191 sim_equal ricsim_g1_1 num_instances 1
192 sim_equal ricsim_g2_1 num_instances 1
193
194 api_put_policy 201 "service10" ricsim_g1_1 1 5001 true $notificationurl testdata/OSC/pi1_template.json
195 api_put_policy 201 "service10" ricsim_g2_1 NOTYPE 5101 true $notificationurl testdata/STD/pi1_template.json
196
197 api_equal json:policies 4
198
199 sim_equal ricsim_g1_1 num_instances 2
200 sim_equal ricsim_g2_1 num_instances 2
201
202 sim_post_delete_instances 200 ricsim_g1_1
203 sim_post_delete_instances 200 ricsim_g2_1
204
205 #Wait for recreate of non transient policy
206 api_equal json:policies 2 180
207
208 sim_equal ricsim_g1_1 num_instances 1
209 sim_equal ricsim_g2_1 num_instances 1
210
211 api_put_service 200 "service10" 10 "$CR_PATH/service10"
212
213 #Wait for service expiry
214 api_equal json:policies 0 120
215
216 sim_equal ricsim_g1_1 num_instances 0
217 sim_equal ricsim_g2_1 num_instances 0
218
219 api_get_service_ids 200
220
221 deviation "TR18 Agents sends callback with empty body"
222 deviation "TR18 Unclear when callbacks are sent...."
223 #cr_equal received_callbacks 8
224 mr_equal requests_submitted 0
225
226 check_policy_agent_logs
227 check_control_panel_logs
228
229 #### TEST COMPLETE ####
230
231 store_logs          END
232
233 print_result
234
235 auto_clean_containers