blob: 378a6d45b8ecc7a47cd6f9dc2fe98d2724e81ca5 [file] [log] [blame]
BjornMagnussonXA80a92002020-03-19 14:31:06 +01001#!/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# This is a script that contains specific test functions for A1 Controller API
21
22# Generic function to query the RICs via the A1-controller API.
23# args: <operation> <url> [<body>]
24# <operation>: getA1Policy,putA1Policy,getA1PolicyType,deleteA1Policy,getA1PolicyStatus
25# response: <json-body><3-digit-response-code>
26# (Not for test scripts)
27__do_curl_to_controller() {
28 echo " (${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ >> $HTTPLOG
29 if [ $# -ne 2 ] && [ $# -ne 3 ]; then
30 ((RES_CONF_FAIL++))
31 echo "-Incorrect number of parameters to __do_curl_to_controller " $@ >> $HTTPLOG
32 echo "-Expected: <operation> <url> [<body>]" >> $HTTPLOG
33 echo "-Returning response 000" >> $HTTPLOG
34 echo "000"
35 return 1
36 fi
37 if [ $# -eq 2 ]; then
38 json='{"input":{"near-rt-ric-url":"'$2'"}}'
39 else
40 # Escape quotes in the body
41 body=$(echo "$3" | sed 's/"/\\"/g')
42 json='{"input":{"near-rt-ric-url":"'$2'","body":"'"$body"'"}}'
43 fi
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020044 echo "$json" > .sdnc.payload.json
BjornMagnussonXA80a92002020-03-19 14:31:06 +010045 echo " FILE: $json" >> $HTTPLOG
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020046 curlString="curl -skw %{http_code} -X POST $SDNC_HTTPX://$SDNC_USER:$SDNC_PWD@localhost:$SDNC_LOCAL_PORT$SDNC_API_URL$1 -H accept:application/json -H Content-Type:application/json --data-binary @.sdnc.payload.json"
BjornMagnussonXA80a92002020-03-19 14:31:06 +010047 echo " CMD: "$curlString >> $HTTPLOG
48 res=$($curlString)
49 retcode=$?
50 echo " RESP: "$res >> $HTTPLOG
51 if [ $retcode -ne 0 ]; then
52 echo " RETCODE: "$retcode >> $HTTPLOG
53 echo "000"
54 return 1
55 fi
56
57 status=${res:${#res}-3}
58
59 if [ $status -ne 200 ]; then
60 echo "000"
61 return 1
62 fi
63 body=${res:0:${#res}-3}
BjornMagnussonXA70e878f2020-05-11 14:11:30 +020064 echo " JSON: "$body >> $HTTPLOG
BjornMagnussonXA80a92002020-03-19 14:31:06 +010065 echo "$body" > .sdnc-reply.json
BjornMagnussonXA72667f12020-04-24 09:20:18 +020066 res=$(python3 ../common/extract_sdnc_reply.py .sdnc-reply.json)
BjornMagnussonXA80a92002020-03-19 14:31:06 +010067 echo " EXTRACED BODY+CODE: "$res >> $HTTPLOG
68 echo "$res"
69 return 0
70}
71
72# Controller API Test function: getA1Policy (return ids only)
73# arg: <response-code> (OSC <ric-id> <policy-type-id> [ <policy-id> [<policy-id>]* ]) | ( STD <ric-id> [ <policy-id> [<policy-id>]* ] )
74# (Function for test scripts)
75controller_api_get_A1_policy_ids() {
76 echo -e $BOLD"TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ $EBOLD
77 echo "TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ >> $HTTPLOG
78 ((RES_TEST++))
79
80 paramError=1
81 if [ $# -gt 3 ] && [ $2 == "OSC" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +020082 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/a1-p/policytypes/$4/policies"
BjornMagnussonXA80a92002020-03-19 14:31:06 +010083 paramError=0
84 elif [ $# -gt 2 ] && [ $2 == "STD" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +020085 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/A1-P/v1/policies"
BjornMagnussonXA80a92002020-03-19 14:31:06 +010086 paramError=0
87 fi
88
89 if [ $paramError -ne 0 ]; then
90 __print_err "<response-code> (OSC <ric-id> <policy-type-id> [ <policy-id> [<policy-id>]* ]) | ( STD <ric-id> [ <policy-id> [<policy-id>]* ] )" $@
91 return 1
92 fi
93
94 res=$(__do_curl_to_controller getA1Policy "$url")
95 retcode=$?
96 status=${res:${#res}-3}
97
98 if [ $? -ne 0 ]; then
99 echo -e $RED" FAIL. Exepected status "$1", got "$status "(likely remote server error)"$ERED
100 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200101 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100102 return 1
103 fi
104
105 if [ $status -ne $1 ]; then
106 echo -e $RED" FAIL. Exepected status "$1", got "$status $ERED
107 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200108 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100109 return 1
110 fi
111 body=${res:0:${#res}-3}
112
113 targetJson="["
114 start=4
115 if [ $2 == "OSC" ]; then
116 start=5
117 fi
118 for pid in ${@:$start} ; do
119 if [ "$targetJson" != "[" ]; then
120 targetJson=$targetJson","
121 fi
BjornMagnussonXAad047782020-06-08 15:54:11 +0200122 targetJson=$targetJson"\"$UUID$pid\""
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100123 done
124 targetJson=$targetJson"]"
125
126 echo " TARGET JSON: $targetJson" >> $HTTPLOG
127
BjornMagnussonXA72667f12020-04-24 09:20:18 +0200128 res=$(python3 ../common/compare_json.py "$targetJson" "$body")
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100129
130 if [ $res -ne 0 ]; then
131 echo -e $RED" FAIL, returned body not correct"$ERED
132 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200133 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100134 return 1
135 fi
136
137 ((RES_PASS++))
138 echo -e $GREEN" PASS"$EGREEN
139 return 0
140}
141
142
143# Controller API Test function: getA1PolicyType
144# arg: <response-code> OSC <ric-id> <policy-type-id> [<policy-type-file>]
145# (Function for test scripts)
146controller_api_get_A1_policy_type() {
147 echo -e $BOLD"TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ $EBOLD
148 echo "TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ >> $HTTPLOG
149 ((RES_TEST++))
150
151 paramError=1
152 if [ $# -gt 3 ] && [ $2 == "OSC" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +0200153 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/a1-p/policytypes/$4"
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100154 paramError=0
155 fi
156
157 if [ $paramError -ne 0 ]; then
158 __print_err "<response-code> OSC <ric-id> <policy-type-id> [<policy-type-file>]" $@
159 return 1
160 fi
161
162 res=$(__do_curl_to_controller getA1PolicyType "$url")
163 retcode=$?
164 status=${res:${#res}-3}
165
166 if [ $? -ne 0 ]; then
167 echo -e $RED" FAIL. Exepected status "$1", got "$status "(likely remote server error)"$ERED
168 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200169 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100170 return 1
171 fi
172
173 if [ $status -ne $1 ]; then
174 echo -e $RED" FAIL. Exepected status "$1", got "$status $ERED
175 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200176 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100177 return 1
178 fi
179 body=${res:0:${#res}-3}
180
181 if [ $# -eq 5 ]; then
182
183 body=${res:0:${#res}-3}
184
185 targetJson=$(< $5)
186 echo " TARGET JSON: $targetJson" >> $HTTPLOG
BjornMagnussonXA72667f12020-04-24 09:20:18 +0200187 res=$(python3 ../common/compare_json.py "$targetJson" "$body")
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100188
189 if [ $res -ne 0 ]; then
190 echo -e $RED" FAIL, returned body not correct"$ERED
191 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200192 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100193 return 1
194 fi
195 fi
196
197 ((RES_PASS++))
198 echo -e $GREEN" PASS"$EGREEN
199 return 0
200}
201
202# Controller API Test function: deleteA1Policy
203# arg: <response-code> (STD <ric-id> <policy-id>) | (OSC <ric-id> <policy-type-id> <policy-id>)
204# (Function for test scripts)
205controller_api_delete_A1_policy() {
206 echo -e $BOLD"TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ $EBOLD
207 echo "TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ >> $HTTPLOG
208 ((RES_TEST++))
209
210 paramError=1
211 if [ $# -eq 5 ] && [ $2 == "OSC" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +0200212 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/a1-p/policytypes/$4/policies/$UUID$5"
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100213 paramError=0
214 elif [ $# -eq 4 ] && [ $2 == "STD" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +0200215 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/A1-P/v1/policies/$UUID$4"
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100216 paramError=0
217 fi
218
219 if [ $paramError -ne 0 ]; then
220 __print_err "<response-code> (STD <ric-id> <policy-id>) | (OSC <ric-id> <policy-type-id> <policy-id>)" $@
221 return 1
222 fi
223
224 res=$(__do_curl_to_controller deleteA1Policy "$url")
225 retcode=$?
226 status=${res:${#res}-3}
227
228 if [ $? -ne 0 ]; then
229 echo -e $RED" FAIL. Exepected status "$1", got "$status "(likely remote server error)"$ERED
230 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200231 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100232 return 1
233 fi
234
235 if [ $status -ne $1 ]; then
236 echo -e $RED" FAIL. Exepected status "$1", got "$status $ERED
237 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200238 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100239 return 1
240 fi
241
242 ((RES_PASS++))
243 echo -e $GREEN" PASS"$EGREEN
244 return 0
245}
246
247# Controller API Test function: putA1Policy
248# arg: <response-code> (STD <ric-id> <policy-id> <template-file> ) | (OSC <ric-id> <policy-type-id> <policy-id> <template-file>)
249# (Function for test scripts)
250controller_api_put_A1_policy() {
251 echo -e $BOLD"TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ $EBOLD
252 echo "TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ >> $HTTPLOG
253 ((RES_TEST++))
254
255 paramError=1
256 if [ $# -eq 6 ] && [ $2 == "OSC" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +0200257 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/a1-p/policytypes/$4/policies/$UUID$5"
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100258 body=$(sed 's/XXX/'${5}'/g' $6)
259
260 paramError=0
261 elif [ $# -eq 5 ] && [ $2 == "STD" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +0200262 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/A1-P/v1/policies/$UUID$4"
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100263 body=$(sed 's/XXX/'${4}'/g' $5)
264 paramError=0
265 fi
266
267 if [ $paramError -ne 0 ]; then
268 __print_err "<response-code> (STD <ric-id> <policy-id>) | (OSC <ric-id> <policy-type-id> <policy-id>)" $@
269 return 1
270 fi
271
272 res=$(__do_curl_to_controller putA1Policy "$url" "$body")
273 retcode=$?
274 status=${res:${#res}-3}
275
276 if [ $? -ne 0 ]; then
277 echo -e $RED" FAIL. Exepected status "$1", got "$status "(likely remote server error)"$ERED
278 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200279 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100280 return 1
281 fi
282
283 if [ $status -ne $1 ]; then
284 echo -e $RED" FAIL. Exepected status "$1", got "$status $ERED
285 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200286 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100287 return 1
288 fi
289
290 ((RES_PASS++))
291 echo -e $GREEN" PASS"$EGREEN
292 return 0
293}
294
295
296# Controller API Test function: getA1PolicyStatus
297# arg: <response-code> (STD <ric-id> <policy-id> <enforce-status> [<reason>]) | (OSC <ric-id> <policy-type-id> <policy-id> <instance-status> <has-been-deleted>)
298# (Function for test scripts)
299controller_api_get_A1_policy_status() {
300 echo -e $BOLD"TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ $EBOLD
301 echo "TEST(${BASH_LINENO[0]}): ${FUNCNAME[0]}" $@ >> $HTTPLOG
302 ((RES_TEST++))
303
304 targetJson=""
305 paramError=1
306 if [ $# -ge 5 ] && [ $2 == "OSC" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +0200307 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/a1-p/policytypes/$4/policies/$UUID$5/status"
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100308 if [ $# -gt 5 ]; then
309 targetJson="{\"instance_status\":\"$6\""
310 targetJson=$targetJson",\"has_been_deleted\":\"$7\""
311 targetJson=$targetJson",\"created_at\":\"????\"}"
312 fi
313 paramError=0
314 elif [ $# -ge 4 ] && [ $2 == "STD" ]; then
BjornMagnussonXA575869c2020-09-14 21:28:54 +0200315 url="$RIC_SIM_HTTPX://$3:$RIC_SIM_PORT/A1-P/v1/policies/$UUID$4/status"
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100316 if [ $# -gt 4 ]; then
317 targetJson="{\"enforceStatus\":\"$5\""
318 if [ $# -eq 6 ]; then
319 targetJson=$targetJson",\"reason\":\"$6\""
320 fi
321 targetJson=$targetJson"}"
322 fi
323 paramError=0
324 fi
325
326 if [ $paramError -ne 0 ]; then
327 __print_err "<response-code> (STD <ric-id> <policy-id> <enforce-status> [<reason>]) | (OSC <ric-id> <policy-type-id> <policy-id> <instance-status> <has-been-deleted>)" $@
328 return 1
329 fi
330
331 res=$(__do_curl_to_controller getA1PolicyStatus "$url")
332 retcode=$?
333 status=${res:${#res}-3}
334
335 if [ $? -ne 0 ]; then
336 echo -e $RED" FAIL. Exepected status "$1", got "$status "(likely remote server error)"$ERED
337 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200338 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100339 return 1
340 fi
341
342 if [ $status -ne $1 ]; then
343 echo -e $RED" FAIL. Exepected status "$1", got "$status $ERED
344 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200345 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100346 return 1
347 fi
348
349 if [ ! -z "$targetJson" ]; then
350
351 body=${res:0:${#res}-3}
352 echo " TARGET JSON: $targetJson" >> $HTTPLOG
BjornMagnussonXA72667f12020-04-24 09:20:18 +0200353 res=$(python3 ../common/compare_json.py "$targetJson" "$body")
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100354
355 if [ $res -ne 0 ]; then
356 echo -e $RED" FAIL, returned body not correct"$ERED
357 ((RES_FAIL++))
BjornMagnussonXA048aaa12020-06-04 07:48:37 +0200358 __check_stop_at_error
BjornMagnussonXA80a92002020-03-19 14:31:06 +0100359 return 1
360 fi
361 fi
362
363 ((RES_PASS++))
364 echo -e $GREEN" PASS"$EGREEN
365 return 0
366}